:root{
  --bg:#0b0b0f;           /* fallback si image non chargée */
  --ink:#f7f4ea;
  --gold:#d2ae6d;
  --gold-dark:#a88749;
  --accent:#5ec2c9;
  --red:#e03640;
}
*{box-sizing:border-box}
html,body{height:100%}
html,body{margin:0; padding:0; color:var(--ink)}
/* BACKGROUND PLEINE PAGE (image micro) */
body{font-family: Montserrat, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; line-height:1.6;
  background:
    linear-gradient(to bottom, rgba(11,11,15,.8), rgba(11,11,15,.85)),
    url('img/mic.jpeg') center/cover fixed no-repeat;
  background-color: var(--bg);
}
.container{width:min(1100px, 92%); margin-inline:auto}

/* Utils */
.sr-only{position:absolute!important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0}

/* Header */
header{position:sticky; top:0; z-index:1000; backdrop-filter:saturate(140%) blur(8px); background:rgba(11,11,15,.55); border-bottom:1px solid rgba(210,174,109,.25)}
.nav{display:flex; align-items:center; justify-content:space-between; padding:.9rem 0}
.brand{display:flex; align-items:center; gap:.8rem; text-decoration:none; color:var(--ink)}
.brand__logo{position:relative; width:42px; height:42px; display:grid; place-items:center; font-weight:800; letter-spacing:.02em; line-height:1; font-size:1.15rem}
.brand__logo::after{content:""; position:absolute; left:6px; right:6px; height:6px; bottom:6px; background:linear-gradient(90deg, transparent 0 8%, var(--red) 8% 92%, transparent 92% 100%); border-radius:999px; transform:skewX(-12deg)}
.brand__name{font-weight:700; font-size:1.05rem}
nav ul{list-style:none; display:flex; gap:1.2rem; padding:0; margin:0}
nav a{color:var(--ink); text-decoration:none; opacity:.9}
nav a:hover{color:var(--gold)}

/* Hero */
.hero{min-height:72vh; display:grid; place-items:center; text-align:center}
.hero__card{border:1px solid var(--gold-dark); background:rgba(11,11,15,.6); padding:2rem 1.5rem; width:min(820px, 92%); border-radius:18px; box-shadow:0 10px 30px rgba(0,0,0,.35)}
.kicker{letter-spacing:.18em; text-transform:uppercase; font-size:.78rem; color:var(--gold); display:inline-block; margin-bottom:.6rem}
.h1, h1{font-weight:800; font-size:clamp(2rem, 6vw, 3.2rem); line-height:1.15; margin:.2rem 0 .7rem}
.subtitle{opacity:.92; font-size:clamp(1rem, 2.5vw, 1.15rem)}
.cta-row{display:flex; gap:.8rem; flex-wrap:wrap; justify-content:center; margin-top:1.3rem}
.btn{appearance:none; border:none; cursor:pointer; text-decoration:none; padding:.9rem 1.1rem; border-radius:999px; font-weight:700; transition:.2s ease; display:inline-flex; align-items:center; gap:.55rem}
.btn--gold{background:var(--gold); color:#111}
.btn--gold:hover{background:var(--gold-dark)}
.btn--ghost{background:transparent; color:var(--ink); border:1px solid var(--gold-dark)}
.btn--ghost:hover{border-color:var(--gold); color:var(--gold)}

/* Button loading */
.btn__spinner{width:0; height:0; border-radius:50%; border:0; margin-right:.35rem; display:inline-block}
.btn--loading .btn__spinner{width:1em; height:1em; border:.18em solid rgba(0,0,0,.25); border-top-color:#111; border-radius:50%; animation:spin 1s linear infinite}
.btn--loading{opacity:.8; pointer-events:none}
@keyframes spin{to{transform:rotate(360deg)}}

/* Sections */
.section{padding:4rem 0}
.section h2{font-weight:800; font-size:clamp(1.6rem, 4vw, 2.2rem); margin:0 0 1rem}
.lead{opacity:.9}
.center{text-align:center}
.accent{color:var(--accent)}

/* Dates */
.dates{display:grid; grid-template-columns:repeat(auto-fit, minmax(260px, 1fr)); gap:1rem; margin-top:1.2rem}
.date-card{border:1px solid rgba(210,174,109,.3); background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.0)); border-radius:16px; padding:1.1rem; display:flex; flex-direction:column; gap:.6rem}
.date-row{display:flex; align-items:center; justify-content:space-between; gap:.6rem}
.badge{font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; border:1px solid var(--gold-dark); padding:.25rem .5rem; border-radius:999px; color:var(--gold)}
.place{font-weight:700}
.muted{opacity:.72}
.tickets{margin-top:auto}

/* Skeleton loading pour les dates */
.skel{border-radius:14px; border:1px solid rgba(210,174,109,.18); padding:1rem; background:linear-gradient(90deg, rgba(255,255,255,.05) 25%, rgba(255,255,255,.08) 37%, rgba(255,255,255,.05) 63%); background-size:400% 100%; animation:shimmer 1.2s infinite}
.skel .bar{height:10px; margin:.5rem 0; background:rgba(0,0,0,.25); border-radius:6px}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:0 0}}

/* Bio */
.bio{display:grid; grid-template-columns: 1.1fr .9fr; gap:1.2rem; align-items:start}
.bio img{width:100%; border-radius:16px; border:1px solid rgba(210,174,109,.3); object-fit:cover}
@media (max-width: 860px){ .bio{grid-template-columns:1fr} }

/* Vidéo */
.video{position:relative; width:100%; aspect-ratio:16/9; border-radius:16px; overflow:hidden; border:1px solid rgba(210,174,109,.3)}
.video iframe{position:absolute; inset:0; width:100%; height:100%}

/* Formulaire */
form{display:grid; grid-template-columns:1fr 1fr; gap:1rem}
form .full{grid-column:1 / -1}
label{display:block; font-size:.9rem; margin-bottom:.35rem; color:var(--gold)}
input, textarea{width:100%; padding:.85rem .9rem; border-radius:12px; border:1px solid rgba(210,174,109,.35); background:rgba(255,255,255,.02); color:var(--ink)}
input::placeholder, textarea::placeholder{color:#cfcfcf80}
textarea{min-height:130px}
.form-note{font-size:.85rem; opacity:.8}

/* Footer */
footer{margin-top:4rem; padding:2.2rem 0; border-top:1px solid rgba(210,174,109,.25); background:radial-gradient(1200px 260px at 50% 0, rgba(210,174,109,.08), transparent 60%)}
.foot{display:flex; gap:1rem; flex-wrap:wrap; align-items:center; justify-content:space-between}
.social a{color:var(--ink); opacity:.9; text-decoration:none; margin-right:1rem}
.social a:hover{color:var(--gold)}

/* Toast */
.toast{position:fixed; left:50%; bottom:24px; transform:translateX(-50%); background:#111; border:1px solid rgba(210,174,109,.35); color:var(--ink); padding:.8rem 1rem; border-radius:12px; box-shadow:0 10px 30px rgba(0,0,0,.35)}

/* Art déco separators */
.deco{display:grid; place-items:center; margin:2.2rem 0 1.4rem}
.deco .line{height:1px; width:100%; background:linear-gradient(90deg, transparent, var(--gold), transparent)}
.deco .dot{width:10px; height:10px; border:1px solid var(--gold); border-radius:50%; margin-top:.5rem}

/* ======= NAV HAMBURGER (mobile) ======= */
.nav-toggle{display:none; background:transparent; border:1px solid rgba(210,174,109,.35); padding:.55rem .6rem; border-radius:12px; align-items:center; justify-content:center; gap:.35rem}
.nav-toggle__bar{display:block; width:22px; height:2px; background:var(--ink); position:relative}
.nav-toggle__bar + .nav-toggle__bar{margin-top:5px}
.nav-toggle:focus{outline:2px solid var(--gold-dark); outline-offset:2px}

/* state when open */
header.is-open .nav-toggle{border-color:var(--gold)}
header.is-open .nav-toggle__bar{background:var(--gold)}

/* Mobile menu */
@media (max-width: 780px){
  .nav{gap:.8rem}
  .nav-toggle{display:inline-flex}
  nav{position:absolute; top:100%; right:0; left:0; background:rgba(11,11,15,.97); border-bottom:1px solid rgba(210,174,109,.25); transform-origin:top center; transform:scaleY(0); transition:transform .18s ease; will-change:transform}
  nav ul{display:grid; grid-template-columns:1fr; padding: .8rem 1rem 1rem; gap:.4rem}
  nav a{padding:.7rem .3rem; display:block; font-size:1.05rem}
  header.is-open nav{transform:scaleY(1)}
}

/* --- Fix hamburger solid bars --- */

.nav-toggle{color: var(--ink);} /* inherit color for bars */
.nav-toggle__bar{
  background-color: currentColor !important;
  background-image: none !important; /* prevent any repeating background from global styles */
  box-shadow: none !important;
}
header.is-open .nav-toggle{color: var(--gold);} /* bars turn gold when open */


/* === Hamburger alignment + X animation override === */
.nav .nav-toggle{
  position: relative;
  width: 44px;
  height: 34px;
  padding: 0;             /* ensures exact box for centering bars */
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.nav .nav-toggle__bar{
  position: absolute;
  left: 50%;
  width: 24px;
  height: 2px;
  transform: translateX(-50%);
  border-radius: 2px;
  transition: transform .18s ease, opacity .12s ease;
}

/* Place the three bars precisely */
.nav .nav-toggle__bar:nth-child(1){ transform: translate(-50%, -8px); }
.nav .nav-toggle__bar:nth-child(2){ transform: translate(-50%, 0); }
.nav .nav-toggle__bar:nth-child(3){ transform: translate(-50%, 8px); }

/* Morph to X when open (hide the middle) */
header.is-open .nav .nav-toggle__bar:nth-child(1){
  transform: translate(-50%, 0) rotate(45deg);
}
header.is-open .nav .nav-toggle__bar:nth-child(2){
  opacity: 0;
}
header.is-open .nav .nav-toggle__bar:nth-child(3){
  transform: translate(-50%, 0) rotate(-45deg);
}

/* Reduce motion for users preferring less animation */
@media (prefers-reduced-motion: reduce){
  .nav .nav-toggle__bar{ transition: none; }
}


/* --- Ensure hamburger only visible on mobile --- */
.nav .nav-toggle{ display: none; } /* default: hidden on desktop */

/* Scope sizing/alignment + X animation to mobile */
@media (max-width: 780px){
  .nav .nav-toggle{ display:inline-flex; position: relative; width: 44px; height: 34px; padding:0; align-items:center; justify-content:center; }
  .nav .nav-toggle__bar{ position:absolute; left:50%; width:24px; height:2px; transform:translateX(-50%); border-radius:2px; transition: transform .18s ease, opacity .12s ease; }
  .nav .nav-toggle__bar:nth-child(1){ transform: translate(-50%, -8px); }
  .nav .nav-toggle__bar:nth-child(2){ transform: translate(-50%, 0); }
  .nav .nav-toggle__bar:nth-child(3){ transform: translate(-50%, 8px); }
  header.is-open .nav .nav-toggle__bar:nth-child(1){ transform: translate(-50%, 0) rotate(45deg); }
  header.is-open .nav .nav-toggle__bar:nth-child(2){ opacity: 0; }
  header.is-open .nav .nav-toggle__bar:nth-child(3){ transform: translate(-50%, 0) rotate(-45deg); }
}
