:root{
  --noir:#0c0708; --rouge:#a01828; --rouge-vif:#c41e2f;
  --or:#d9b25a; --creme:#ecdcc8; --bord:rgba(200,165,120,.45);
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:#0a0506;color:#e8dcd0;font-family:Georgia,'Times New Roman',serif;-webkit-font-smoothing:antialiased}
a{text-decoration:none}

/* logo chromé */
.logo{font-family:Georgia,serif;font-weight:bold;line-height:1;
  background:linear-gradient(180deg,#fff,#cfd2d6 45%,#7e8488 52%,#b9bdc1 58%,#5b6064);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.rule{height:2px;background:var(--rouge)}

/* ---------- NAV HAUT ---------- */
.topnav{position:relative;z-index:6;height:60px;display:flex;
  align-items:center;justify-content:space-between;padding:0 28px;
  background:#0c0708;border-bottom:2px solid var(--rouge)}
.topnav .brand{font-family:Georgia,serif;font-weight:bold;font-size:24px;color:#cfd2d6}
.topnav .brand a{color:inherit;text-decoration:none}
.topnav nav a{color:#d8cabd;font-size:14px;font-family:Arial,sans-serif;margin-left:26px;text-decoration:none}
.topnav nav a:hover{color:#fff}

/* ---------- HERO ---------- */
.hero{position:relative;width:100%;height:calc(100dvh - 60px - 56px);max-height:calc(100dvh - 60px - 56px);
  min-height:420px;overflow:hidden;
  background:#0a0506 url('/assets/img/hero.jpg') center/cover no-repeat}
.hero-overlay{position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(8,4,5,.15) 0%,transparent 30%,transparent 62%,rgba(8,4,5,.35) 100%)}
.pave{position:absolute;z-index:5;top:44%;right:5%;transform:translateY(-50%);
  width:440px;max-width:46%;padding:32px 36px 34px;text-align:center;
  background:rgba(8,4,6,.42);border:1px solid var(--bord);backdrop-filter:blur(2px);border-radius:5px}
.pave .logo{font-size:46px}
.pave .rule{width:74%;margin:10px auto 14px}
.pave .baseline{font-style:italic;color:#ecdccb;font-size:16px;margin-bottom:24px}
.btns{display:flex;flex-direction:column;gap:12px}
.btn{display:block;text-align:center;padding:15px 18px;font-size:14.5px;
  font-family:Arial,sans-serif;cursor:pointer;transition:.16s;letter-spacing:.02em}
.btn-primary{background:var(--rouge);color:#fff;border:1px solid var(--rouge)}
.btn-primary:hover{background:var(--rouge-vif)}
.btn-ghost{background:transparent;color:#ecd9c5;border:1px solid rgba(220,190,150,.55)}
.btn-ghost:hover{border-color:#fff;color:#fff}

/* ---------- TUILES ---------- */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:#241a1d}
.tile{background:#0d0809;padding:16px 10px;text-align:center;color:#d7c8bb;
  font-family:Arial,sans-serif;font-size:13px;letter-spacing:.03em;border-top:2px solid var(--rouge)}
.tile:hover{background:#160e10;color:#fff}

/* ---------- AGE GATE ---------- */
.gate{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#0a0607}
.gate-bg{position:absolute;inset:0;background:url('/assets/img/gate-bg.jpg') center/cover no-repeat;
  filter:blur(28px) brightness(.45)}
.gate-overlay{position:absolute;inset:0;
  background:radial-gradient(circle at 50% 45%,rgba(12,7,8,.5),rgba(8,5,6,.9))}
.gate-card{position:relative;z-index:2;width:min(440px,90vw);text-align:center;padding:36px 30px 30px;
  background:rgba(14,9,11,.82);border:1px solid var(--bord);border-radius:6px;
  box-shadow:0 20px 60px rgba(0,0,0,.6)}
.gate-card .logo{font-size:38px}
.gate-card .rule{width:120px;margin:12px auto 18px}
.gate-card p{color:#ddd0c4;font-size:15px;line-height:1.5;margin-bottom:22px}
.gate-card .small{font-size:12px;color:#9a8c80;font-style:italic;margin-top:18px;margin-bottom:0}
.btn-enter{display:block;width:100%;padding:14px;background:var(--rouge);color:#fff;border:none;
  font-size:15px;font-family:Arial,sans-serif;cursor:pointer;letter-spacing:.04em;margin-bottom:10px}
.btn-enter:hover{background:var(--rouge-vif)}
.btn-leave{display:block;width:100%;padding:11px;background:transparent;color:#cbb89f;
  border:1px solid rgba(200,165,120,.4);font-size:13px;font-family:Arial,sans-serif}
.btn-leave:hover{color:#fff;border-color:#fff}

/* ---------- RESPONSIVE ---------- */
@media(max-width:720px){
  .topnav{height:52px;background:#0c0708;border-bottom:2px solid var(--rouge)}
  .topnav .brand{font-size:21px}
  .topnav nav a{margin-left:14px}

  /* Le hero devient une colonne : image (haut) + pavé (bas),
     le tout calé pour que nav + hero + tuiles tiennent dans l'écran */
  .hero{height:calc(100dvh - 54px - 52px);   /* écran - header(52+2) - tuiles */
    min-height:0;max-height:none;
    display:flex;flex-direction:column;
    background:#0a0506}
  /* l'image en bloc à hauteur fixe, le reste pour le pavé */
  .hero-overlay{display:none}
  .hero::before{content:"";display:block;height:46%;
    background:url('/assets/img/hero.jpg') center 20%/cover no-repeat}

  .pave{position:static;flex:1;display:flex;flex-direction:column;justify-content:center;
    width:100%;max-width:none;transform:none;margin:0;
    border:0;border-top:1px solid var(--bord);background:rgba(8,4,6,.85);
    padding:14px 22px}
  .pave .logo{font-size:30px}
  .pave .baseline{font-size:13px;margin-bottom:12px}
  .btn{padding:12px 14px}

  .tiles{height:52px}
  .tile{display:flex;align-items:center;justify-content:center;padding:0 6px;font-size:12px}
}

/* ---------- PAGES SIMPLES ---------- */
.page{max-width:900px;margin:0 auto;padding:80px 24px}
.page h1{font-size:30px;color:var(--creme);margin-bottom:18px}
.page p{line-height:1.6;color:#cdbfb2}

/* ---------- FORMULAIRES ---------- */
.page-form{max-width:680px}
.page-form .intro{margin-bottom:24px}
.form{display:flex;flex-direction:column;gap:16px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-family:Arial,sans-serif;font-size:13px;color:#cbb89f;letter-spacing:.03em}
.field input,.field textarea{
  background:#160f11;border:1px solid #3a2b2f;border-radius:4px;color:#e8dcd0;
  padding:12px 14px;font-family:Arial,sans-serif;font-size:14px;width:100%}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--rouge);background:#1a1113}
.field textarea{resize:vertical;min-height:120px}
.form .btn{align-self:flex-start;min-width:220px;border:none}
/* honeypot caché */
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* messages flash */
.flash{padding:14px 16px;border-radius:4px;margin-bottom:18px;font-family:Arial,sans-serif;font-size:14px}
.flash-success{background:rgba(28,90,40,.25);border:1px solid #2f7d3f;color:#bfe6c5}
.flash-error{background:rgba(140,24,40,.25);border:1px solid var(--rouge);color:#f0c8cd}

/* ---------- MODALE ---------- */
.modal{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;
  background:rgba(6,3,4,.78);padding:20px}
.modal.open{display:flex}
.modal-box{position:relative;width:min(640px,100%);max-height:90vh;overflow-y:auto;
  background:#0e090b;border:1px solid var(--bord);border-radius:8px;padding:34px 32px;
  box-shadow:0 24px 70px rgba(0,0,0,.6)}
.modal-box h2{font-size:26px;color:var(--creme);margin-bottom:8px}
.modal-box .intro{font-size:14px;color:#cdbfb2;margin-bottom:22px}
.modal-close{position:absolute;top:14px;right:16px;background:none;border:none;color:#cbb89f;
  font-size:26px;cursor:pointer;line-height:1}
.modal-close:hover{color:#fff}

/* ---------- CHOIX DE PROFIL (radios stylés) ---------- */
.profil-choice{display:flex;flex-direction:column;gap:10px}
.radio-pill{display:flex;align-items:center;gap:10px;cursor:pointer;
  background:#160f11;border:1px solid #3a2b2f;border-radius:4px;padding:12px 14px;
  font-family:Arial,sans-serif;font-size:14px;color:#e8dcd0;transition:.15s}
.radio-pill:hover{border-color:var(--bord)}
.radio-pill input{accent-color:var(--rouge);width:18px;height:18px;cursor:pointer}
.radio-pill input:checked ~ span{color:#fff}
.radio-pill:has(input:checked){border-color:var(--rouge);background:#1a1113}
@media(min-width:560px){.profil-choice{flex-direction:row}.radio-pill{flex:1}}

/* ====================== ÉVÉNEMENTS (castings/productions) ====================== */
.evt-head{text-align:center;padding:46px 20px 10px}
.evt-surtitle{font-family:Arial,sans-serif;font-size:13px;letter-spacing:.25em;text-transform:uppercase;color:var(--or)}
.evt-head h1{font-size:40px;margin:10px 0;color:var(--creme)}
.evt-head h1 .accent{color:var(--rouge-vif)}
.evt-sub{font-style:italic;color:#a99}

.evt-filters{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;padding:24px 20px 10px}
.evt-filter{padding:10px 26px;font-family:Arial,sans-serif;font-size:13px;letter-spacing:.08em;text-transform:uppercase;
  background:transparent;border:1px solid var(--bord);color:#cbb89f;cursor:pointer;border-radius:2px;text-decoration:none}
.evt-filter:hover{color:#fff}
.evt-filter.on{background:rgba(160,24,40,.15);border-color:var(--rouge);color:#fff}
.evt-count{text-align:center;font-family:Arial,sans-serif;font-size:12px;letter-spacing:.15em;text-transform:uppercase;
  color:#8c7d72;padding:18px 0}

.evt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:1180px;margin:0 auto;padding:10px 24px 70px}
.evt-empty{grid-column:1/-1;text-align:center;color:#a99;font-style:italic;padding:40px 0}
.evt-card{background:#100a0c;border:1px solid #2a1f22;border-radius:8px;overflow:hidden;display:flex;flex-direction:column;transition:.18s}
.evt-card:hover{border-color:var(--bord);transform:translateY(-3px)}
.evt-card-img{position:relative;height:200px;background-size:cover;background-position:center}
.evt-noimg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:60px;color:rgba(217,178,90,.25);font-weight:bold;font-family:Georgia,serif}
.evt-badge{position:absolute;bottom:12px;left:12px;background:rgba(8,4,5,.8);border:1px solid var(--or);
  color:var(--or);font-family:Arial,sans-serif;font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px}
.evt-dates{position:absolute;top:12px;right:12px;display:flex;gap:6px}
.evt-date{background:rgba(8,4,5,.85);border-radius:4px;text-align:center;padding:6px 9px;min-width:46px}
.evt-date.start{border:1px solid #2f7d3f}
.evt-date.end{border:1px solid var(--rouge)}
.evt-date .d{font-family:Arial,sans-serif;font-weight:bold;font-size:17px;color:#fff;line-height:1}
.evt-date .m{font-family:Arial,sans-serif;font-size:10px;text-transform:uppercase;color:#cbb89f}
.evt-card-body{padding:18px 18px 20px;flex:1;display:flex;flex-direction:column}
.evt-card-body h3{font-size:21px;color:var(--creme);margin-bottom:12px}
.evt-meta{font-family:Arial,sans-serif;font-size:13px;color:#bba;margin:3px 0}
.evt-org{font-family:Arial,sans-serif;font-size:12px;color:#8c7d72;margin-top:10px;padding-top:12px;border-top:1px solid #2a1f22}
.evt-foot{display:flex;justify-content:space-between;align-items:center;margin-top:14px;gap:10px}
.evt-places{font-family:Arial,sans-serif;font-size:13px;color:#bfe6c5}
.evt-places b{color:#fff}
.evt-cta{font-family:Arial,sans-serif;font-size:13px;color:var(--or);text-decoration:none;letter-spacing:.03em;white-space:nowrap}
.evt-cta:hover{color:#fff}
@media(max-width:900px){.evt-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.evt-grid{grid-template-columns:1fr}.evt-head h1{font-size:30px}}

/* ---------- RUBANS DIAGONAUX (statut événement) ---------- */
.evt-card-img{overflow:hidden}
.evt-ruban{position:absolute;top:40px;left:-72px;z-index:3;
  width:260px;transform:rotate(-45deg);text-align:center;
  display:flex;align-items:center;justify-content:center;
  font-family:Arial,sans-serif;font-size:11px;font-weight:bold;letter-spacing:.02em;
  text-transform:uppercase;color:#fff;padding:8px 0;
  box-shadow:0 2px 8px rgba(0,0,0,.5)}
.evt-ruban-rouge{background:linear-gradient(135deg,#c41e2f,#7a0f1b)}
.evt-ruban-orange{background:linear-gradient(135deg,#e08a1e,#b5620a)}
.evt-ruban-vert{background:linear-gradient(135deg,#2f9d4f,#1c6e34)}
