/* =========================================================================
   TERRA FUTURA · Prototype landing · Direction C "Urbain lumineux / LED RGB"
   Concept : le site est un costume LED. Fond scène noir, spectre RGB vivant.
   ========================================================================= */

:root{
  /* Scène */
  --bg:        #0A0A0B;
  --bg-2:      #111113;
  --surface:   #161618;
  --line:      rgba(255,255,255,.10);
  --line-soft: rgba(255,255,255,.06);

  /* Néons du brief */
  --neon:   #9BF9B3;   /* vert électrique */
  --acid:   #F1FF4F;   /* jaune acide */
  --flash:  #23A455;   /* vert vif */

  /* LED RGB : couleurs par tableau */
  --led-intro:   #5FE3FF;  /* cyan, douceur, violon */
  --led-flammes: #FF5A2C;  /* braise, flammes jumelles */
  --led-eternity:#9B7CFF;  /* violet astral */
  --led-galaxy:  #FF3DAE;  /* magenta explosion */

  /* Texte */
  --ink:    #F4F5F7;
  --ink-dim:#A7A8AD;
  --ink-mut:#6C6D73;

  --maxw: 1240px;
  --ease: cubic-bezier(.22,1,.36,1);

  --font-display: 'Anton', 'Arial Narrow', sans-serif;
  --font-body: 'Kumbh Sans', sans-serif;
  --font-mono: 'Space Mono', monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--bg)}
body{
  background:transparent;
  color:var(--ink);
  font-family:var(--font-body);
  font-weight:400;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* Grain overlay -------------------------------------------------------- */
body::after{
  content:"";
  position:fixed;inset:0;z-index:9999;pointer-events:none;
  opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* Kicker mono "LED tech" ----------------------------------------------- */
.kicker{
  font-family:var(--font-mono);
  font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-dim);display:inline-flex;align-items:center;gap:10px;
}
.kicker::before{
  content:"";width:26px;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--led-intro),var(--led-galaxy));
}

/* ======================================================================
   LED STRIP : bande lumineuse animée (le costume)
   ====================================================================== */
@keyframes ledflow{
  0%{background-position:0% 50%}
  100%{background-position:200% 50%}
}
.led-strip{
  height:4px;width:100%;
  background:linear-gradient(90deg,
    #FF3DAE,#9B7CFF,#5FE3FF,#9BF9B3,#F1FF4F,#FF5A2C,#FF3DAE);
  background-size:200% 100%;
  animation:ledflow 6s linear infinite;
  box-shadow:0 0 24px rgba(155,124,255,.5);
}

/* ======================================================================
   NAV
   ====================================================================== */
header.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  backdrop-filter:blur(14px);
  background:linear-gradient(180deg,rgba(10,10,11,.92),rgba(10,10,11,.55));
  border-bottom:1px solid var(--line-soft);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:68px;
}
.brand{
  font-family:var(--font-display);font-size:1.35rem;letter-spacing:.04em;
  text-transform:uppercase;display:flex;align-items:center;gap:12px;
}
.brand .dot{
  width:11px;height:11px;border-radius:50%;
  background:conic-gradient(from 0deg,#FF3DAE,#9B7CFF,#5FE3FF,#9BF9B3,#F1FF4F,#FF5A2C,#FF3DAE);
  animation:spin 4s linear infinite;
  box-shadow:0 0 14px rgba(95,227,255,.7);
}
@keyframes spin{to{transform:rotate(360deg)}}
.brand-group{display:flex;align-items:center;gap:14px;min-width:0}
.brand-creator{
  display:inline-flex;align-items:center;gap:6px;flex-shrink:0;
  padding:5px 10px 5px 9px;border-radius:999px;
  border:1px solid var(--line);background:rgba(155,124,255,.06);
  color:var(--ink-dim);font-family:var(--font-mono);font-size:.58rem;
  letter-spacing:.14em;text-transform:uppercase;line-height:1;
  transition:border-color .25s var(--ease),color .25s var(--ease),
             background .25s var(--ease)}
.brand-creator__by{opacity:.7}
.brand-creator__name{color:var(--ink);letter-spacing:.12em;font-weight:700}
.brand-creator__arrow{color:var(--led-eternity);transition:transform .25s var(--ease)}
.brand-creator:hover{border-color:var(--led-eternity);color:var(--ink);
  background:rgba(155,124,255,.18)}
.brand-creator:hover .brand-creator__arrow{transform:translate(2px,-2px)}
.nav-meta{display:flex;align-items:center;gap:22px}
.date-chip{
  font-family:var(--font-mono);font-size:.74rem;letter-spacing:.12em;
  color:var(--ink-dim);display:none;
}
.date-chip b{color:var(--neon)}
.sold-pill{
  display:inline-block;padding:2px 8px;border-radius:999px;
  background:#FF3DAE;color:#0a0a0b;font-family:var(--font-mono);
  font-weight:700;font-size:.62rem;letter-spacing:.16em;
  text-transform:uppercase;line-height:1.4;vertical-align:middle;
  box-shadow:0 0 14px rgba(255,61,174,.55);
}
.btn{
  font-family:var(--font-mono);font-weight:700;font-size:.74rem;
  letter-spacing:.14em;text-transform:uppercase;
  padding:11px 20px;border-radius:2px;cursor:pointer;border:none;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.btn-led{
  color:#0A0A0B;
  background:linear-gradient(100deg,var(--neon),var(--acid));
  box-shadow:0 0 0 rgba(155,249,179,0);
}
.btn-led:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(155,249,179,.4)}
.btn-ghost{
  color:var(--ink);background:transparent;border:1px solid var(--line);
}
.btn-ghost:hover{border-color:var(--neon);color:var(--neon)}

/* ======================================================================
   HERO
   ====================================================================== */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  padding:120px 0 80px;overflow:hidden;
}
/* Blooms RGB = costumes LED dans le noir */
.hero .bloom{
  position:absolute;border-radius:50%;filter:blur(90px);opacity:.55;
  pointer-events:none;animation:float 14s ease-in-out infinite;
}
.bloom.b1{width:520px;height:520px;left:-120px;top:-40px;
  background:radial-gradient(circle,var(--led-eternity),transparent 70%);}
.bloom.b2{width:460px;height:460px;right:-80px;top:120px;
  background:radial-gradient(circle,var(--led-galaxy),transparent 70%);animation-delay:-4s;}
.bloom.b3{width:600px;height:600px;left:30%;bottom:-200px;
  background:radial-gradient(circle,var(--led-intro),transparent 70%);animation-delay:-8s;opacity:.4;}
@keyframes float{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(30px,-30px) scale(1.08)}
}

.hero-grid{position:relative;z-index:2}
.hero .kicker{margin-bottom:30px}
.hero h1{
  font-family:var(--font-display);
  font-size:clamp(3.4rem,11vw,9.5rem);
  line-height:.92;letter-spacing:.005em;text-transform:uppercase;
  margin-bottom:8px;
}
.hero h1 .glow{
  background:linear-gradient(92deg,var(--led-intro),var(--neon),var(--acid),var(--led-galaxy));
  background-size:300% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:ledflow 8s linear infinite;
  filter:drop-shadow(0 0 26px rgba(155,124,255,.35));
}
.hero .lede{
  max-width:600px;margin:30px 0 38px;font-size:1.06rem;color:var(--ink-dim);
  font-weight:300;
}
.hero .lede strong{color:var(--ink);font-weight:600}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-cta .note{font-family:var(--font-mono);font-size:.7rem;color:var(--ink-mut);letter-spacing:.1em}

/* Stats */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  margin-top:64px;border-top:1px solid var(--line);
}
.stat{padding:22px 18px 4px;border-right:1px solid var(--line-soft)}
.stat:last-child{border-right:none}
.stat .v{font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.9rem);line-height:1}
.stat:nth-child(1) .v{color:var(--led-intro)}
.stat:nth-child(2) .v{color:var(--neon)}
.stat:nth-child(3) .v{color:var(--acid)}
.stat:nth-child(4) .v{color:var(--led-galaxy)}
.stat .l{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-mut);margin-top:8px}

/* ======================================================================
   MARQUEE
   ====================================================================== */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--bg-2);overflow:hidden;padding:18px 0;
  display:flex;white-space:nowrap;
}
.marquee .track{display:flex;gap:40px;animation:scroll 28s linear infinite;flex-shrink:0;padding-right:40px}
.marquee span{font-family:var(--font-display);font-size:1.5rem;letter-spacing:.05em;
  text-transform:uppercase;color:var(--ink);display:inline-flex;gap:40px;align-items:center}
.marquee span::after{content:"●";color:var(--led-galaxy);font-size:.7rem}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ======================================================================
   SECTION GENERIC
   ====================================================================== */
section.block{padding:120px 0;position:relative}
.sec-label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.24em;
  text-transform:uppercase;color:var(--led-eternity);margin-bottom:22px}
.sec-title{
  font-family:var(--font-display);text-transform:uppercase;line-height:.95;
  font-size:clamp(2.4rem,6vw,4.6rem);letter-spacing:.01em;margin-bottom:40px;
}
.sec-title em{font-style:normal;color:var(--ink-mut)}

/* Histoire */
.histoire-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.histoire-grid p{margin-bottom:20px;color:var(--ink-dim);font-weight:300}
.histoire-grid p strong{color:var(--ink);font-weight:600}
.histoire-grid p em{color:var(--neon);font-style:italic}

/* ======================================================================
   TABLEAUX : chaque carte = un costume LED d'une couleur
   ====================================================================== */
.tableaux{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.tab-card{
  --led:var(--neon);
  position:relative;padding:38px 34px 42px;border-radius:6px;
  background:linear-gradient(160deg,var(--surface),var(--bg-2));
  border:1px solid var(--line);overflow:hidden;
  transition:transform .5s var(--ease),border-color .5s var(--ease);
}
.tab-card::before{
  content:"";position:absolute;inset:0;opacity:0;transition:opacity .5s var(--ease);
  background:radial-gradient(120% 80% at 0% 0%, color-mix(in srgb,var(--led) 22%, transparent), transparent 60%);
}
.tab-card::after{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--led);
  box-shadow:0 0 24px var(--led);
}
.tab-card:hover{transform:translateY(-6px);border-color:color-mix(in srgb,var(--led) 50%, transparent)}
.tab-card:hover::before{opacity:1}
.tab-num{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.2em;color:var(--led);position:relative}
.tab-card h3{font-family:var(--font-display);font-size:2.2rem;text-transform:uppercase;
  margin:14px 0 14px;letter-spacing:.01em;position:relative}
.tab-card p{color:var(--ink-dim);font-weight:300;position:relative}

/* ======================================================================
   ÉQUIPE
   ====================================================================== */
.equipe-lede{max-width:620px;color:var(--ink-dim);font-weight:300;margin-bottom:48px}
.roster{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;max-width:980px}
.member{
  padding:0;border:1px solid var(--line-soft);border-radius:8px;
  background:var(--bg-2);transition:.4s var(--ease);overflow:hidden;
  display:flex;flex-direction:column}
.member:hover{background:var(--surface);border-color:var(--line);transform:translateY(-3px)}
.member__avatar{
  position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--surface);
  display:flex;align-items:center;justify-content:center}
.member__avatar img{
  width:100%;height:100%;object-fit:cover;object-position:center top;
  display:block;transition:transform .6s var(--ease),filter .6s var(--ease);
  filter:saturate(.9)}
.member:hover .member__avatar img{transform:scale(1.04);filter:saturate(1.05)}
.member__initial{
  font-family:var(--font-display);font-size:clamp(3rem,8vw,5rem);line-height:1;
  text-transform:uppercase;color:transparent;
  -webkit-text-stroke:1.5px color-mix(in srgb,var(--neon) 65%,transparent);
  text-shadow:0 0 40px color-mix(in srgb,var(--neon) 35%,transparent)}
.member__txt{padding:14px 14px 16px}
.member .name{font-family:var(--font-display);font-size:1rem;text-transform:uppercase;
  letter-spacing:.02em;line-height:1.1}
.member .role{font-family:var(--font-mono);font-size:.55rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-mut);margin-top:6px;line-height:1.4}
.member__insta{
  display:inline-block;margin-top:8px;font-family:var(--font-mono);
  font-size:.58rem;letter-spacing:.04em;color:var(--led-intro);
  text-decoration:none;transition:color .2s var(--ease);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.member__insta:hover{color:var(--neon)}

/* Captation & images : section dédiée au même format que le roster équipe */
.captation{
  margin-top:48px;padding-top:32px;
  border-top:1px dashed color-mix(in srgb,var(--ink) 16%,transparent);
  max-width:490px}
.captation__label{
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-dim);margin-bottom:18px;opacity:.85}
/* 2 cards exactement comme .member, format vertical */
.captation__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.captation__person{
  padding:0;border:1px solid var(--line-soft);border-radius:8px;
  background:var(--bg-2);transition:.4s var(--ease);overflow:hidden;
  display:flex;flex-direction:column}
.captation__person:hover{background:var(--surface);border-color:var(--line);transform:translateY(-3px)}
.captation__avatar{
  position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--surface);
  display:flex;align-items:center;justify-content:center}
.captation__avatar img{
  width:100%;height:100%;object-fit:cover;object-position:center top;display:block;
  transition:transform .6s var(--ease),filter .6s var(--ease);filter:saturate(.9)}
.captation__person:hover .captation__avatar img{transform:scale(1.04);filter:saturate(1.05)}
.captation__initial{
  font-family:var(--font-display);font-size:clamp(3rem,8vw,5rem);line-height:1;
  text-transform:uppercase;color:transparent;
  -webkit-text-stroke:1.5px color-mix(in srgb,var(--led-intro) 65%,transparent);
  text-shadow:0 0 40px color-mix(in srgb,var(--led-intro) 35%,transparent)}
.captation__txt{padding:14px 14px 16px}
.captation__name{font-family:var(--font-display);font-size:1rem;
  text-transform:uppercase;letter-spacing:.02em;line-height:1.1}
.captation__role{font-family:var(--font-mono);font-size:.55rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-mut);margin-top:6px;line-height:1.4}
.captation__insta{
  display:inline-block;margin-top:8px;font-family:var(--font-mono);
  font-size:.58rem;letter-spacing:.04em;color:var(--led-intro);
  text-decoration:none;transition:color .2s var(--ease);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.captation__insta:hover{color:var(--neon)}

@media(max-width:600px){
  .captation__grid{grid-template-columns:1fr 1fr}
}
.crew-showcase{
  margin:48px 0 0;position:relative;overflow:hidden;border-radius:10px;
  border:1px solid var(--line);max-width:980px}
.crew-showcase img{
  width:100%;height:auto;display:block;
  filter:saturate(.95);transition:transform .8s var(--ease),filter .8s var(--ease)}
.crew-showcase:hover img{transform:scale(1.02);filter:saturate(1.05)}
.crew-showcase__tag{
  position:absolute;left:0;right:0;bottom:0;padding:18px 22px 16px;
  background:linear-gradient(180deg,transparent 0%,rgba(10,10,11,.85) 80%);
  font-family:var(--font-mono);font-size:.75rem;letter-spacing:.1em;color:var(--neon);
  text-transform:uppercase}
.crew-tag{
  display:inline-block;margin-top:48px;font-family:var(--font-mono);font-size:.8rem;
  letter-spacing:.1em;color:var(--neon);border:1px solid color-mix(in srgb,var(--neon) 40%,transparent);
  padding:10px 18px;border-radius:2px;
}

/* ======================================================================
   DATE / BILLETTERIE
   ====================================================================== */
.date-sec{position:relative;overflow:hidden;background:var(--bg-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.date-sec .bloom{position:absolute;width:700px;height:700px;border-radius:50%;
  filter:blur(110px);opacity:.3;left:50%;top:50%;transform:translate(-50%,-50%);
  background:conic-gradient(from 0deg,#FF3DAE,#9B7CFF,#5FE3FF,#9BF9B3,#F1FF4F,#FF5A2C,#FF3DAE);
  animation:spin 22s linear infinite}
.date-inner{position:relative;text-align:center;z-index:2}
.date-big{font-family:var(--font-display);text-transform:uppercase;line-height:.9;
  font-size:clamp(3rem,9vw,7.5rem);margin:18px 0}
.date-big .num{
  background:linear-gradient(92deg,var(--led-intro),var(--neon),var(--acid));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.date-place{font-family:var(--font-mono);letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-dim);font-size:.86rem;margin-bottom:36px}
.date-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-lg{padding:16px 30px;font-size:.8rem}

/* Countdown */
.countdown{display:flex;gap:14px;justify-content:center;margin:34px 0 8px;flex-wrap:wrap}
.cd-cell{min-width:96px;padding:18px 10px;border:1px solid var(--line);border-radius:6px;
  background:rgba(10,10,11,.5);backdrop-filter:blur(6px)}
.cd-cell .n{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.2rem);line-height:1;
  background:linear-gradient(92deg,var(--led-intro),var(--neon));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.cd-cell .u{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-mut);margin-top:8px}

/* Infos pratiques */
.infos{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:54px;text-align:left}
.info{padding:22px 20px;border:1px solid var(--line-soft);border-radius:4px;background:var(--bg)}
.info .k{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--led-galaxy);margin-bottom:10px}
.info .val{font-size:1.02rem;color:var(--ink);font-weight:500}
.info .tbd{color:var(--ink-mut);font-style:italic;font-weight:400;font-size:.92rem}

/* ======================================================================
   FOOTER
   ====================================================================== */
footer{padding:70px 0 50px;background:var(--bg)}
.foot-grid{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap}
.foot-brand{font-family:var(--font-display);font-size:2.6rem;text-transform:uppercase;letter-spacing:.03em}
.foot-tag{font-family:var(--font-mono);font-size:.74rem;color:var(--ink-mut);letter-spacing:.12em;margin-top:8px}
.foot-links{display:flex;gap:20px;font-family:var(--font-mono);font-size:.74rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim)}
.foot-links a:hover{color:var(--neon)}

/* ======================================================================
   REVEAL
   ====================================================================== */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ======================================================================
   NICE-TO-HAVE MODULES
   ====================================================================== */

/* Scroll-spectre : calque de fond fixe dont la teinte suit le scroll */
#spectrum{
  position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 0%,
    hsla(var(--spec,190),90%,55%,.10), transparent 55%),
    var(--bg);
  transition:background .4s linear;
}

/* Curseur traînée RGB */
#trail{position:fixed;inset:0;z-index:998;pointer-events:none}
@media(hover:none){#trail{display:none}}

/* Loader théâtral */
#loader{
  position:fixed;inset:0;z-index:10000;background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;
  transition:opacity .8s var(--ease),visibility .8s;
}
#loader.done{opacity:0;visibility:hidden}
.loader-logo{width:clamp(180px,32vw,260px);height:auto;
  filter:drop-shadow(0 0 38px rgba(95,227,255,.4));
  animation:loader-logo-pulse 2.4s var(--ease) infinite}
@keyframes loader-logo-pulse{
  0%,100%{filter:drop-shadow(0 0 28px rgba(95,227,255,.35)) drop-shadow(0 0 4px rgba(155,124,255,0));transform:scale(1)}
  50%{filter:drop-shadow(0 0 42px rgba(155,124,255,.55)) drop-shadow(0 0 8px rgba(255,61,174,.25));transform:scale(1.04)}
}
.loader-word{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.06em;
  font-size:clamp(1.6rem,5vw,2.6rem);color:var(--ink);opacity:.88;
  text-shadow:0 0 18px rgba(95,227,255,.25)}
.loader-bars{display:flex;gap:7px}
.loader-bars i{width:6px;height:42px;border-radius:3px;background:#222;display:block;
  animation:bootled .9s var(--ease) forwards}
.loader-bars i:nth-child(1){--c:#FF3DAE;animation-delay:.05s}
.loader-bars i:nth-child(2){--c:#9B7CFF;animation-delay:.15s}
.loader-bars i:nth-child(3){--c:#5FE3FF;animation-delay:.25s}
.loader-bars i:nth-child(4){--c:#9BF9B3;animation-delay:.35s}
.loader-bars i:nth-child(5){--c:#F1FF4F;animation-delay:.45s}
.loader-bars i:nth-child(6){--c:#FF5A2C;animation-delay:.55s}
.loader-bars i:nth-child(7){--c:#FF3DAE;animation-delay:.65s}
@keyframes bootled{
  0%{background:#222;box-shadow:none;height:42px}
  60%{height:64px}
  100%{background:var(--c);box-shadow:0 0 18px var(--c);height:42px}
}
.loader-sub{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.24em;
  text-transform:uppercase;color:var(--ink-mut)}

/* (teaser sonore retiré : remplacé par .sticky-audio dans le footer) */

/* Carte partageable : modal */
#share-modal{position:fixed;inset:0;z-index:10001;display:none;
  align-items:center;justify-content:center;padding:24px;
  background:rgba(5,5,6,.82);backdrop-filter:blur(8px)}
#share-modal.open{display:flex}
.share-box{text-align:center;max-width:440px;width:100%}
.share-box canvas{width:100%;max-width:400px;border-radius:10px;
  border:1px solid var(--line);box-shadow:0 20px 80px rgba(155,124,255,.3)}
.share-actions{display:flex;gap:10px;justify-content:center;margin-top:18px;flex-wrap:wrap}
.share-close{position:absolute;top:20px;right:24px;font-family:var(--font-mono);
  font-size:.8rem;color:var(--ink-dim);cursor:pointer;letter-spacing:.1em}
.share-close:hover{color:var(--neon)}

/* boutons secondaires sous la date */
.date-mini{display:flex;gap:12px;justify-content:center;margin-top:18px;flex-wrap:wrap}
.btn-mini{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-dim);border:1px solid var(--line);padding:9px 16px;border-radius:2px;cursor:pointer;
  background:transparent;transition:.3s var(--ease)}
.btn-mini:hover{border-color:var(--neon);color:var(--neon)}

/* ======================================================================
   MOBILE PREMIUM : burger, drawer plein écran, barre CTA collante
   ====================================================================== */
.burger{display:none;width:44px;height:44px;border:1px solid var(--line);border-radius:8px;
  background:rgba(20,20,22,.6);position:relative;cursor:pointer;flex-shrink:0}
.burger span{position:absolute;left:11px;right:11px;height:2px;border-radius:2px;background:var(--ink);
  transition:.35s var(--ease)}
.burger span:nth-child(1){top:15px}.burger span:nth-child(2){top:21px}.burger span:nth-child(3){top:27px}
.burger.open span:nth-child(1){top:21px;transform:rotate(45deg);background:var(--neon)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){top:21px;transform:rotate(-45deg);background:var(--neon)}

#m-menu{position:fixed;inset:0;z-index:999;background:rgba(8,8,9,.97);backdrop-filter:blur(20px);
  display:flex;flex-direction:column;justify-content:center;padding:0 30px;
  opacity:0;visibility:hidden;transform:translateY(-12px);transition:.5s var(--ease)}
#m-menu.open{opacity:1;visibility:visible;transform:none}
#m-menu a.m-link{font-family:var(--font-display);text-transform:uppercase;font-size:2.4rem;
  letter-spacing:.02em;padding:14px 0;border-bottom:1px solid var(--line-soft);
  display:flex;align-items:baseline;gap:16px;color:var(--ink);
  opacity:0;transform:translateX(-20px);transition:.5s var(--ease)}
#m-menu.open a.m-link{opacity:1;transform:none}
#m-menu.open a.m-link:nth-child(1){transition-delay:.08s}
#m-menu.open a.m-link:nth-child(2){transition-delay:.14s}
#m-menu.open a.m-link:nth-child(3){transition-delay:.20s}
#m-menu.open a.m-link:nth-child(4){transition-delay:.26s}
#m-menu a.m-link .idx{font-family:var(--font-mono);font-size:.8rem;color:var(--led-galaxy);letter-spacing:.1em}
#m-menu a.m-link:active{color:var(--neon)}
#m-menu .m-foot{margin-top:42px;display:flex;flex-direction:column;gap:16px;
  opacity:0;transition:.5s var(--ease) .34s}
#m-menu.open .m-foot{opacity:1}
#m-menu .m-foot .btn{justify-content:center;text-align:center}
#m-menu .m-soc{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-mut);text-align:center}

/* Barre de réservation collante (mobile) */
#m-cta{position:fixed;left:0;right:0;bottom:0;z-index:950;display:none;
  align-items:center;gap:10px;padding:10px 14px calc(10px + env(safe-area-inset-bottom,0));
  background:rgba(12,12,14,.92);backdrop-filter:blur(16px);border-top:1px solid var(--line)}
#m-cta .info-mini{flex:1;min-width:0;overflow:hidden}
#m-cta .l1{font-family:var(--font-display);text-transform:uppercase;font-size:1rem;line-height:1;letter-spacing:.02em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#m-cta .l1 .sold-pill{font-size:.52rem;padding:2px 6px}
#m-cta .l2{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.08em;color:var(--ink-dim);
  margin-top:5px;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  display:flex;align-items:center;gap:6px}
#m-cta .l2 b{color:var(--neon)}
#m-cta .m-cta__sep{opacity:.5}
#m-cta .btn{flex-shrink:0;padding:11px 16px;font-size:.66rem;letter-spacing:.1em}

/* Très petits écrans (iPhone SE etc.) : encore plus compact */
@media(max-width:380px){
  #m-cta{gap:8px;padding-left:12px;padding-right:12px}
  #m-cta .l1{font-size:.92rem}
  #m-cta .l2{font-size:.54rem}
  #m-cta .btn{padding:10px 12px;font-size:.6rem}
}

/* ======================================================================
   RESPONSIVE
   ====================================================================== */
@media(min-width:720px){.date-chip{display:block}}

@media(max-width:860px){
  .histoire-grid{grid-template-columns:1fr;gap:0}
  .tableaux{grid-template-columns:1fr}
  .roster{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line-soft)}
  .infos{grid-template-columns:1fr 1fr}
}

/* ---- MOBILE PREMIUM ---- */
@media(max-width:760px){
  .wrap{padding:0 20px}
  section.block{padding:78px 0}
  section.block[style*="padding-top:40px"]{padding-top:24px !important}

  /* Nav : on bascule sur burger + barre collante */
  .nav-inner{height:60px}
  .brand{font-size:1.15rem}
  .nav-meta .btn{display:none}
  .date-chip{display:none}
  .brand-creator__by,.brand-creator__name{display:none}
  .brand-creator{padding:6px 7px}
  .burger{display:block}
  #m-cta{display:flex}
  body{padding-bottom:74px} /* place pour la barre collante */
  /* (teaser mobile retiré) */

  /* Hero : respire, ne force pas 100vh */
  .hero{min-height:auto;padding:104px 0 56px}
  .hero .kicker{margin-bottom:22px;font-size:.66rem}
  .hero h1{font-size:clamp(3rem,17vw,5rem)}
  .hero .lede{font-size:1rem;margin:24px 0 30px}
  .hero-cta{gap:10px}
  .hero-cta .btn-lg{flex:1;text-align:center;justify-content:center;min-width:140px}
  .hero-cta .note{flex-basis:100%;text-align:center}
  .stats{margin-top:46px}
  .stat{padding:18px 14px 4px}

  .bloom.b1,.bloom.b2,.bloom.b3{filter:blur(70px);opacity:.45}

  .marquee span{font-size:1.2rem}
  .sec-title{font-size:clamp(2.1rem,9vw,3rem)}

  /* Tableaux : padding plus serré */
  .tab-card{padding:30px 26px 34px}
  .tab-card h3{font-size:1.9rem}

  /* Countdown : une seule ligne, cellules compactes */
  .countdown{gap:8px;flex-wrap:nowrap}
  .cd-cell{min-width:0;flex:1;padding:14px 4px}
  .cd-cell .n{font-size:clamp(1.5rem,8vw,2.2rem)}
  .cd-cell .u{font-size:.54rem;letter-spacing:.1em}

  .date-cta{gap:10px}
  .date-cta .btn-lg{flex:1;min-width:0;text-align:center;justify-content:center;
    padding:14px 14px;font-size:.66rem;letter-spacing:.08em;line-height:1.25}
  /* Très petits écrans (iPhone SE) : on stacke */
  @media(max-width:380px){
    .date-cta{flex-direction:column}
    .date-cta .btn-lg{width:100%}
  }
  .infos{grid-template-columns:1fr 1fr;gap:10px}
  .info{padding:18px 16px}

  .foot-grid{flex-direction:column;align-items:flex-start;gap:24px}
  .foot-brand{font-size:2.1rem}
}

@media(max-width:480px){
  .roster{grid-template-columns:1fr}
  .infos{grid-template-columns:1fr}
  #m-menu a.m-link{font-size:2rem}
}

/* ======================================================================
   AJOUTS PHP : footer légal, cause, moments, formulaire contact
   ====================================================================== */
.foot-links{flex-wrap:wrap}
.foot-legal{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
  margin-top:40px;padding-top:24px;border-top:1px solid var(--line-soft);
  font-family:var(--font-mono);font-size:.66rem;letter-spacing:.08em;color:var(--ink-mut)}
.foot-legal a:hover{color:var(--neon)}
.foot-credit{opacity:.7}
.foot-by{font-family:var(--font-mono);letter-spacing:.1em;color:var(--ink-mut)}
.foot-by a{color:var(--ink-dim);transition:color .25s var(--ease)}
.foot-by a:hover{color:var(--neon)}

/* Cause / message */
.cause-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:start}
.cause-lede{color:var(--ink-dim);font-weight:300;font-size:1.08rem}
.cause-lede strong{color:var(--ink);font-weight:600}
.cause-points{display:flex;flex-direction:column;gap:18px}
.cause-point{padding:22px 24px;border:1px solid var(--line-soft);border-radius:6px;background:var(--bg-2);
  position:relative;overflow:hidden;transition:.4s var(--ease)}
.cause-point::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(var(--led-intro),var(--led-galaxy))}
.cause-point:hover{border-color:var(--line);transform:translateX(4px)}
.cause-point .k{font-family:var(--font-display);text-transform:uppercase;font-size:1.3rem;margin-bottom:6px}
.cause-point .v{color:var(--ink-dim);font-weight:300;font-size:.98rem}
.cause-cta{margin-top:30px}

/* Moments captés : média */
.media-frame{position:relative;border-radius:10px;overflow:hidden;border:1px solid var(--line);
  background:linear-gradient(160deg,var(--surface),var(--bg-2));aspect-ratio:16/9;
  display:flex;align-items:center;justify-content:center}
.media-frame video{width:100%;height:100%;object-fit:cover;display:block}
.media-ph{text-align:center;padding:30px}
.media-ph .ico{font-size:2.4rem;display:block;margin-bottom:14px;
  background:linear-gradient(92deg,var(--led-intro),var(--led-galaxy));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.media-ph .t{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-mut)}
.media-cap{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;
  color:var(--ink-mut);margin-top:16px;text-transform:uppercase}

/* Formulaire contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-aside p{color:var(--ink-dim);font-weight:300;margin-bottom:16px}
.contact-aside a{color:var(--neon)}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-mut);margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;padding:14px 16px;background:var(--bg-2);
  border:1px solid var(--line);border-radius:4px;color:var(--ink);font-family:var(--font-body);font-size:1rem}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--neon)}
.field textarea{min-height:140px;resize:vertical}
.form-note{font-family:var(--font-mono);font-size:.64rem;color:var(--ink-mut);letter-spacing:.06em;margin-top:14px}
.form-alert{padding:14px 18px;border-radius:4px;margin-bottom:20px;font-size:.95rem}
.form-alert.ok{background:rgba(35,164,85,.15);border:1px solid var(--flash);color:var(--neon)}
.form-alert.err{background:rgba(255,90,44,.12);border:1px solid var(--led-flammes);color:var(--led-flammes)}

/* Pages légales : prose */
.prose{max-width:760px}
.prose h2{font-family:var(--font-display);text-transform:uppercase;font-size:1.6rem;margin:34px 0 14px}
.prose p{color:var(--ink-dim);font-weight:300;margin-bottom:14px}
.prose a{color:var(--neon)}

@media(max-width:860px){
  .cause-grid{grid-template-columns:1fr;gap:34px}
  .contact-grid{grid-template-columns:1fr;gap:34px}
}

/* ======================================================================
   MANIFESTE (full-bleed)
   ====================================================================== */
.manifeste{position:relative;overflow:hidden;padding:130px 0;text-align:center;
  border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);background:var(--bg-2)}
.mf-halo{position:absolute;width:780px;height:780px;left:50%;top:50%;transform:translate(-50%,-50%);
  border-radius:50%;filter:blur(120px);opacity:.22;pointer-events:none;
  background:conic-gradient(from 0deg,#FF3DAE,#9B7CFF,#5FE3FF,#9BF9B3,#F1FF4F,#FF5A2C,#FF3DAE);
  animation:spin 26s linear infinite}
.mf-inner{position:relative;z-index:2}
.manifeste .kicker{justify-content:center;margin-bottom:30px}
.manifeste blockquote{font-family:var(--font-display);text-transform:uppercase;line-height:.95;
  font-size:clamp(2.6rem,8vw,6rem);letter-spacing:.01em}
.mf-line{display:block}
.mf-em,.closer-title .glow{
  background:linear-gradient(92deg,var(--led-intro),var(--neon),var(--acid),var(--led-galaxy));
  background-size:300% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:ledflow 8s linear infinite;filter:drop-shadow(0 0 26px rgba(155,124,255,.3))}
.mf-sub{max-width:540px;margin:30px auto 0;color:var(--ink-dim);font-weight:300;font-size:1.06rem}
.mf-sub em{color:var(--neon);font-style:italic}

/* ======================================================================
   TABLEAUX : bandes immersives pleine largeur
   ====================================================================== */
.tab-bands-sec{padding:120px 0 0}
.tab-bands{margin-top:54px}
.tab-band{position:relative;overflow:hidden}
.tab-band + .tab-band{border-top:1px solid var(--line-soft)}
.tab-band-bg{position:absolute;inset:0;opacity:.5;transition:opacity .6s var(--ease);pointer-events:none;
  background:radial-gradient(80% 130% at 0% 50%, color-mix(in srgb,var(--led) 26%, transparent), transparent 62%)}
.tab-band:nth-child(even) .tab-band-bg{
  background:radial-gradient(80% 130% at 100% 50%, color-mix(in srgb,var(--led) 26%, transparent), transparent 62%)}
.tab-band:hover .tab-band-bg{opacity:.9}
.tab-band-inner{position:relative;z-index:2;display:flex;align-items:center;gap:54px;padding-top:74px;padding-bottom:74px}
.tab-band:nth-child(even) .tab-band-inner{flex-direction:row-reverse}
.tab-band-no{flex-shrink:0;font-family:var(--font-display);line-height:.78;
  font-size:clamp(5rem,15vw,12rem);color:transparent;
  -webkit-text-stroke:2px color-mix(in srgb,var(--led) 65%, transparent);
  text-shadow:0 0 60px color-mix(in srgb,var(--led) 35%, transparent)}
.tab-band-txt{max-width:560px}
.tab-band-txt h3{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.01em;
  font-size:clamp(2.4rem,6vw,4rem);margin:12px 0 16px}
.tab-band-txt p{color:var(--ink-dim);font-weight:300;font-size:1.05rem}

/* Photo background + LED tint overlay quand has-photo */
.tab-band.has-photo{padding:0;min-height:480px}
.tab-band.has-photo .tab-band-inner{padding-top:96px;padding-bottom:96px}
.tab-band-photo{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  z-index:0;opacity:.32;filter:grayscale(.15) saturate(.85)}
.tab-band.has-photo .tab-band-bg{opacity:1;mix-blend-mode:multiply;
  background:
    linear-gradient(90deg, var(--bg) 0%, rgba(10,10,11,.55) 35%, transparent 70%),
    radial-gradient(60% 110% at 0% 50%, color-mix(in srgb,var(--led) 55%, transparent), transparent 65%)}
.tab-band:nth-child(even).has-photo .tab-band-bg{
  background:
    linear-gradient(270deg, var(--bg) 0%, rgba(10,10,11,.55) 35%, transparent 70%),
    radial-gradient(60% 110% at 100% 50%, color-mix(in srgb,var(--led) 55%, transparent), transparent 65%)}
.tab-band.has-photo:hover .tab-band-photo{opacity:.42;transition:opacity .6s var(--ease)}
.tab-band.has-photo .tab-band-no{
  text-shadow:0 0 80px color-mix(in srgb,var(--led) 60%, transparent)}
.tab-band.has-photo .tab-band-txt h3{
  text-shadow:0 2px 24px rgba(10,10,11,.7)}

@media(max-width:760px){
  .tab-band.has-photo{min-height:380px}
  .tab-band.has-photo .tab-band-inner{padding-top:64px;padding-bottom:64px}
  .tab-band-photo{opacity:.22}
}

/* ======================================================================
   CLOSER émotionnel (full-bleed)
   ====================================================================== */
.closer{position:relative;overflow:hidden;padding:132px 0 120px;text-align:center;background:var(--bg)}
.closer-strip{position:absolute;top:0;left:0;right:0;height:3px;background-size:200% 100%;
  animation:ledflow 6s linear infinite;
  background-image:linear-gradient(90deg,#FF3DAE,#9B7CFF,#5FE3FF,#9BF9B3,#F1FF4F,#FF5A2C,#FF3DAE)}
.closer-inner{position:relative;z-index:2}
.closer .kicker{justify-content:center;margin-bottom:26px}
.closer-title{font-family:var(--font-display);text-transform:uppercase;line-height:.95;
  font-size:clamp(2.6rem,8vw,6rem);letter-spacing:.01em}
.closer-sub{font-family:var(--font-mono);font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-mut);margin-top:26px}

/* ---- Responsive (manifeste / bandes / closer) ---- */
@media(max-width:760px){
  .manifeste{padding:88px 0}
  .tab-bands-sec{padding-top:78px}
  .tab-band-inner,.tab-band:nth-child(even) .tab-band-inner{flex-direction:column;align-items:flex-start;gap:6px;padding-top:52px;padding-bottom:52px}
  .tab-band-no{font-size:clamp(4rem,22vw,7rem);-webkit-text-stroke-width:1.5px}
  .closer{padding:88px 0 80px}
}

/* ======================================================================
   PARCOURS : quick-facts, ligne pro, FAQ, rappel email
   ====================================================================== */

/* Bandeau infos clés sous le hero */
.qfacts{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.qfacts-grid{display:grid;grid-template-columns:repeat(5,1fr)}
.qf{padding:22px 20px;border-right:1px solid var(--line-soft);display:flex;flex-direction:column;gap:6px}
.qf:last-child{border-right:none}
.qf-k{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--led-galaxy)}
.qf-v{font-family:var(--font-display);text-transform:uppercase;font-size:1.18rem;letter-spacing:.01em;line-height:1.05}
.qf-v small{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.06em;color:var(--ink-mut);text-transform:none}

/* Ligne pro (double entrée) dans le hero */
.hero-pro{display:inline-block;margin-top:22px;font-family:var(--font-mono);font-size:.74rem;
  letter-spacing:.06em;color:var(--ink-mut);border-bottom:1px solid var(--line);padding-bottom:3px;transition:.3s var(--ease)}
.hero-pro span{color:var(--ink-dim)}
.hero-pro:hover{color:var(--neon)}
.hero-pro:hover span{color:var(--neon)}

/* FAQ */
.faq-list{margin-top:46px;max-width:820px}
.faq-item{border-top:1px solid var(--line-soft)}
.faq-item:last-child{border-bottom:1px solid var(--line-soft)}
.faq-item summary{list-style:none;cursor:pointer;padding:24px 0;display:flex;align-items:center;
  justify-content:space-between;gap:20px;font-family:var(--font-display);text-transform:uppercase;
  font-size:1.25rem;letter-spacing:.01em;color:var(--ink);transition:color .3s var(--ease)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--neon)}
.faq-plus{position:relative;width:18px;height:18px;flex-shrink:0}
.faq-plus::before,.faq-plus::after{content:"";position:absolute;background:var(--led-intro);
  transition:transform .35s var(--ease)}
.faq-plus::before{left:0;right:0;top:8px;height:2px}
.faq-plus::after{top:0;bottom:0;left:8px;width:2px}
.faq-item[open] .faq-plus::after{transform:scaleY(0)}
.faq-a{padding:0 0 26px;color:var(--ink-dim);font-weight:300;max-width:680px}
.faq-a strong{color:var(--ink);font-weight:600}

/* Rappel : capture email douce */
.rappel{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.rappel-inner{display:flex;align-items:center;justify-content:space-between;gap:40px;
  padding-top:54px;padding-bottom:54px;flex-wrap:wrap}
.rappel-txt h3{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(1.6rem,4vw,2.4rem);
  line-height:1;letter-spacing:.01em;margin-top:10px}
.rappel-form{display:flex;gap:10px;flex-wrap:wrap;align-items:center;position:relative}
.rappel-form input[type=email]{padding:14px 18px;min-width:260px;background:var(--bg);
  border:1px solid var(--line);border-radius:3px;color:var(--ink);font-family:var(--font-body);font-size:1rem}
.rappel-form input[type=email]:focus{outline:none;border-color:var(--neon)}

/* Stagger menu mobile : 5e lien */
#m-menu.open a.m-link:nth-child(5){transition-delay:.32s}

@media(max-width:860px){
  .qfacts-grid{grid-template-columns:repeat(2,1fr)}
  .qf{border-right:none;border-bottom:1px solid var(--line-soft)}
  .qf:nth-child(odd){border-right:1px solid var(--line-soft)}
  .qf:last-child{grid-column:1/-1}
}
@media(max-width:760px){
  .rappel-inner{flex-direction:column;align-items:flex-start;gap:20px;padding-top:44px;padding-bottom:44px}
  .rappel-form{width:100%}
  .rappel-form input[type=email]{flex:1;min-width:0}
}

/* Réassurance sous le CTA billetterie */
.reassure{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.08em;
  color:var(--ink-mut);margin-top:16px}

/* ===========================================================================
   TRAILER · poster + play overlay, lecture inline au clic
   =========================================================================== */
.trailer-sec{position:relative}
.trailer-frame{position:relative;margin:28px auto 0;border-radius:8px;overflow:hidden;
  background:var(--bg-2);aspect-ratio:4/5;cursor:pointer;
  border:1px solid var(--line);max-width:560px}
.trailer-frame img{
  width:100%;height:100%;object-fit:cover;display:block}
/* La vidéo, elle, reste en 16:9 quand on lance la lecture */
.trailer-frame.is-playing{aspect-ratio:16/9;max-width:none}
.trailer-frame video{
  width:100%;height:100%;object-fit:contain;display:block;background:var(--bg)}
.trailer-play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:84px;height:84px;border-radius:999px;
  border:1.5px solid var(--ink);background:rgba(10,10,11,.55);
  color:var(--ink);font-size:1.7rem;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:transform .25s var(--ease),border-color .25s var(--ease),color .25s var(--ease);z-index:2}
.trailer-frame:hover .trailer-play{
  transform:translate(-50%,-50%) scale(1.06);
  border-color:var(--neon);color:var(--neon)}
.trailer-frame.is-playing .trailer-play,
.trailer-frame.is-playing > img{display:none}

/* ===========================================================================
   COULISSES · carousel horizontal scroll-snap multi-types
   =========================================================================== */
.coulisses-lede{
  max-width:60ch;margin:14px 0 24px;font-family:var(--font-body);
  font-size:1rem;line-height:1.55;color:var(--ink-dim)}

.coulisses-carousel{
  --co-slide-w:88vw;
  display:flex;gap:14px;overflow-x:auto;overflow-y:hidden;
  scroll-snap-type:x mandatory;scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;
  padding:6px max(4vw,calc((100vw - var(--co-slide-w))/2));
  margin:24px 0 28px}
.coulisses-carousel::-webkit-scrollbar{display:none}
.coulisses-carousel{scrollbar-width:none;-ms-overflow-style:none}

.coulisses-slide{
  flex:0 0 var(--co-slide-w);margin:0;position:relative;display:block;
  overflow:hidden;border-radius:8px;background:var(--bg-2);
  border:1px solid var(--line);aspect-ratio:3/2;
  scroll-snap-align:center}
.coulisses-slide img{
  width:100%;height:100%;object-fit:cover;display:block}

.coulisses-slide--cover{
  flex-basis:calc(var(--co-slide-w) * 0.6);aspect-ratio:4/5}

/* Portrait (photos Vincent Sauvignon) : 2:3, encore plus étroit */
.coulisses-slide--portrait{
  flex-basis:calc(var(--co-slide-w) * 0.52);aspect-ratio:2/3}

.coulisses-slide--video{cursor:pointer}
.coulisses-video-frame{position:relative;width:100%;height:100%}
.coulisses-video-frame img,.coulisses-video-frame video{
  width:100%;height:100%;object-fit:cover;display:block}
.coulisses-play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:64px;height:64px;border-radius:999px;
  border:1.5px solid var(--ink);background:rgba(10,10,11,.55);
  color:var(--ink);font-size:1.3rem;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:transform .25s var(--ease),border-color .25s var(--ease),color .25s var(--ease);z-index:2}
.coulisses-video-frame:hover .coulisses-play{
  transform:translate(-50%,-50%) scale(1.06);
  border-color:var(--led-galaxy);color:var(--led-galaxy)}
.coulisses-video-frame.is-playing .coulisses-play,
.coulisses-video-frame.is-playing > img{display:none}

.coulisses-caption{
  position:absolute;left:0;right:0;bottom:0;
  padding:36px 18px 14px;display:flex;flex-direction:column;gap:4px;
  background:linear-gradient(180deg,transparent 0%,rgba(10,10,11,.85) 90%);
  pointer-events:none;z-index:3}
.coulisses-kicker{
  font-family:var(--font-mono);font-size:.62rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--neon)}
.coulisses-txt{
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(1.1rem,1.6vw,1.4rem);line-height:1.15;color:var(--ink);
  letter-spacing:.01em}
/* Crédit photographe en coin bas-droite de chaque slide */
.coulisses-by{
  position:absolute;right:12px;bottom:10px;z-index:4;pointer-events:none;
  font-family:var(--font-mono);font-size:.56rem;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(255,255,255,.78);
  padding:3px 7px;border-radius:3px;
  background:rgba(10,10,11,.45);backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px)}
/* Portraits Vincent : signature burnt-in en bas-droite -> crédit en haut-droite */
.coulisses-slide--portrait .coulisses-by{bottom:auto;top:10px}

.coulisses-controls{
  display:flex;align-items:center;justify-content:center;gap:14px;
  flex-wrap:nowrap;margin-top:12px}
.coulisses-nav{
  flex-shrink:0;width:40px;height:40px;border-radius:999px;
  border:1px solid var(--line);background:transparent;
  color:var(--ink);font-family:var(--font-mono);font-size:1.1rem;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  transition:border-color .2s var(--ease),color .2s var(--ease),background .2s var(--ease)}
.coulisses-nav:hover,.coulisses-nav:focus-visible{
  border-color:var(--neon);color:var(--neon);background:rgba(155,249,179,.06);outline:none}
.coulisses-dots{
  display:flex;gap:8px;align-items:center;
  justify-content:center;flex:1;min-width:0;max-width:60ch;
  overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;
  padding:6px 4px}
.coulisses-dots::-webkit-scrollbar{display:none}
.coulisses-dot{flex-shrink:0}
.coulisses-dot{
  width:8px;height:8px;border-radius:999px;border:none;padding:0;
  background:rgba(244,245,247,.22);cursor:pointer;
  transition:background .2s var(--ease),width .25s var(--ease)}
.coulisses-dot:hover{background:rgba(244,245,247,.4)}
.coulisses-dot.is-active{background:var(--neon);width:22px}

.coulisses-credit{
  margin-top:16px;text-align:center;font-family:var(--font-mono);
  font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-mut)}

@media(min-width:700px){
  .coulisses-carousel{--co-slide-w:78vw;gap:20px}
}
@media(min-width:1024px){
  .coulisses-carousel{--co-slide-w:68vw;max-width:none}
}
@media(min-width:1440px){
  .coulisses-carousel{--co-slide-w:920px}
}

/* ===========================================================================
   HERO BG VIDEO · loop muet compositing 3 plans
   =========================================================================== */
.hero.has-bg{position:relative;isolation:isolate}
.hero-bg{
  position:absolute;inset:0;z-index:-2;
  width:100%;height:100%;object-fit:cover;
  /* gros flou cinéma + désaturation légère pour laisser respirer le texte */
  filter:saturate(.85);
}
.hero-scrim{
  position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 50% 30%, rgba(10,10,11,.45), transparent 70%),
    linear-gradient(180deg, rgba(10,10,11,.55) 0%, rgba(10,10,11,.72) 55%, rgba(10,10,11,.92) 100%);
}
/* Blooms RGB plus discrets sur video bg (sinon le mix devient sale) */
.hero.has-bg .bloom{opacity:.22}
.hero.has-bg .bloom.b1{mix-blend-mode:screen}
.hero.has-bg .bloom.b2{mix-blend-mode:screen}
.hero.has-bg .bloom.b3{mix-blend-mode:screen;opacity:.16}

/* prefers-reduced-motion : on n'autoplay pas, on garde le poster */
@media (prefers-reduced-motion: reduce){
  .hero-bg{display:none}
  .hero.has-bg{background-image:url('/assets/img/hero-poster.jpg');background-size:cover;background-position:center}
}

/* ===========================================================================
   HABILLAGE PHOTO · Histoire (figure intercalaire) + Équipe + Manifeste
   =========================================================================== */

/* Histoire : photo intercalée entre titre et grille texte */
.histoire-photo{
  margin:24px 0 32px;border-radius:10px;overflow:hidden;
  border:1px solid var(--line);position:relative;aspect-ratio:21/9;
  background:var(--bg-2)}
.histoire-photo img{width:100%;height:100%;object-fit:cover;display:block;
  filter:saturate(.9)}
.histoire-photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(10,10,11,.55) 0%,transparent 50%)}

/* Équipe : photo de fond pleine largeur + scrim sombre */
.equipe-sec.has-photo{position:relative;isolation:isolate;
  padding:96px 0 64px;overflow:hidden}
.equipe-bg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  z-index:-2;opacity:.30;filter:grayscale(.1) saturate(.85)}
.equipe-scrim{
  position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(80% 70% at 50% 30%,rgba(10,10,11,.4),transparent 70%),
    linear-gradient(180deg,rgba(10,10,11,.55) 0%,rgba(10,10,11,.85) 100%)}

/* Manifeste : photo flou heavy + heavy scrim — atmosphère cinéma */
.manifeste.has-photo{position:relative;isolation:isolate;overflow:hidden}
.mf-bg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  z-index:-2;opacity:.35;filter:blur(18px) saturate(1.05);
  transform:scale(1.12)}
.mf-scrim{
  position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 60% at 50% 50%,rgba(10,10,11,.5),transparent 70%),
    linear-gradient(180deg,rgba(10,10,11,.6) 0%,rgba(10,10,11,.85) 100%)}

@media(max-width:760px){
  .histoire-photo{aspect-ratio:4/3;margin:20px 0 24px}
  .equipe-sec.has-photo{padding:72px 0 52px}
  .mf-bg{opacity:.28}
}

/* ===========================================================================
   MICRO-INTERACTIONS · hover photo zoom · pulse ring · ken burns · parallax
   =========================================================================== */

/* 1. Tableaux hover : photo zoom + LED glow + numéro scale */
.tab-band.has-photo .tab-band-photo{
  transition:opacity .6s var(--ease),transform .8s var(--ease),filter .8s var(--ease)}
.tab-band.has-photo:hover .tab-band-photo{
  opacity:.46;transform:scale(1.05);filter:grayscale(0) saturate(1)}
.tab-band.has-photo .tab-band-no{
  transition:transform .8s var(--ease),text-shadow .6s var(--ease)}
.tab-band.has-photo:hover .tab-band-no{
  transform:scale(1.04);
  text-shadow:0 0 110px color-mix(in srgb,var(--led) 80%, transparent)}

/* 2. Cover trailer : parallax 3D (JS dépose --rx --ry, CSS applique le transform) */
.trailer-frame{perspective:1000px}
.trailer-frame img{
  transition:transform .35s var(--ease),opacity .3s var(--ease);
  will-change:transform;transform-origin:center}
.trailer-frame[data-tilt] img{
  transform:rotateY(calc(var(--rx,0) * 1deg)) rotateX(calc(var(--ry,0) * 1deg)) scale(1.03)}

/* 3. Play buttons : pulse ring infini quand idle */
@keyframes play-pulse-neon{
  0%,100%{box-shadow:0 0 0 0 rgba(155,249,179,.45)}
  50%{box-shadow:0 0 0 16px rgba(155,249,179,0)}
}
@keyframes play-pulse-magenta{
  0%,100%{box-shadow:0 0 0 0 rgba(255,61,174,.45)}
  50%{box-shadow:0 0 0 14px rgba(255,61,174,0)}
}
.trailer-play{animation:play-pulse-neon 2.6s var(--ease) infinite}
.coulisses-play{animation:play-pulse-magenta 2.4s var(--ease) infinite}
.trailer-frame.is-playing .trailer-play,
.coulisses-video-frame.is-playing .coulisses-play{animation:none}

/* 4. Ken Burns slow zoom sur photos équipe + manifeste */
@keyframes ken-burns{
  0%{transform:scale(1) translate(0,0);transform-origin:50% 50%}
  50%{transform:scale(1.08) translate(-1%,-1%);transform-origin:55% 45%}
  100%{transform:scale(1) translate(0,0);transform-origin:50% 50%}
}
@keyframes ken-burns-mf{
  0%{transform:scale(1.12) translate(0,0)}
  50%{transform:scale(1.18) translate(1%,-1%)}
  100%{transform:scale(1.12) translate(0,0)}
}
.equipe-bg{animation:ken-burns 38s ease-in-out infinite}
.mf-bg{animation:ken-burns-mf 42s ease-in-out infinite}

@media (prefers-reduced-motion: reduce){
  .equipe-bg,.mf-bg,.trailer-play,.coulisses-play,
  .tab-band-photo,.tab-band-no,.trailer-frame img{animation:none !important;transition:none !important}
  .trailer-frame[data-tilt] img{transform:none}
}

/* ===========================================================================
   AUDIO EXTRACT · player custom Symphony Future
   =========================================================================== */
.audio-extract{
  margin-top:40px;padding:24px 24px 22px;
  border:1px solid var(--line);border-radius:10px;
  background:linear-gradient(135deg,rgba(95,227,255,.04),rgba(155,124,255,.06));
  position:relative;overflow:hidden}
.audio-extract::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--led-intro),var(--led-eternity))}
.audio-extract__head{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}
.audio-extract__label{
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--led-intro)}
.audio-extract__title{
  font-family:var(--font-display);font-size:1.4rem;text-transform:uppercase;
  letter-spacing:.02em;color:var(--ink)}
.audio-extract__credit{
  font-family:var(--font-body);font-size:.85rem;color:var(--ink-dim);font-weight:300}

.audio-extract__player{display:flex;align-items:center;gap:16px}
.audio-extract__play{
  flex-shrink:0;width:52px;height:52px;border-radius:999px;
  border:1.5px solid var(--led-intro);background:rgba(95,227,255,.08);
  color:var(--led-intro);cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:.9rem;line-height:1;
  transition:transform .25s var(--ease),background .25s var(--ease),
             border-color .25s var(--ease),box-shadow .25s var(--ease)}
.audio-extract__play:hover{
  transform:scale(1.05);background:rgba(95,227,255,.15);
  border-color:var(--led-eternity);color:var(--led-eternity);
  box-shadow:0 0 24px rgba(155,124,255,.35)}
.audio-extract__play .ico-pause{display:none}
.audio-extract__player.is-playing .ico-play{display:none}
.audio-extract__player.is-playing .ico-pause{display:inline}
.audio-extract__player.is-playing .audio-extract__play{
  border-color:var(--led-eternity);color:var(--led-eternity);
  animation:audio-pulse 2.2s var(--ease) infinite}
@keyframes audio-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(155,124,255,.4)}
  50%{box-shadow:0 0 0 12px rgba(155,124,255,0)}
}

.audio-extract__bar{
  flex:1;height:4px;border-radius:999px;background:rgba(255,255,255,.08);
  overflow:hidden;cursor:pointer;position:relative}
.audio-extract__progress{
  height:100%;width:0;border-radius:999px;
  background:linear-gradient(90deg,var(--led-intro),var(--led-eternity));
  transition:width .12s linear}
.audio-extract__time{
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;
  color:var(--ink-dim);min-width:48px;text-align:right}

@media(max-width:640px){
  .audio-extract{padding:20px 18px 18px;margin-top:32px}
  .audio-extract__title{font-size:1.2rem}
  .audio-extract__player{gap:12px}
  .audio-extract__play{width:44px;height:44px;font-size:.85rem}
}

/* ===========================================================================
   STICKY AUDIO BUTTON · floating play Symphony Future (1 min)
   =========================================================================== */
.sticky-audio{
  position:fixed;right:18px;bottom:18px;z-index:980;
  display:inline-flex;align-items:center;gap:0;
  height:52px;padding:0 0 0 0;
  border:1.5px solid var(--led-intro);border-radius:999px;
  background:rgba(10,10,11,.78);backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  color:var(--ink);cursor:pointer;
  box-shadow:0 8px 30px rgba(0,0,0,.4);
  transition:transform .25s var(--ease),border-color .25s var(--ease),
             padding-right .35s var(--ease),box-shadow .25s var(--ease);
  overflow:hidden}
.sticky-audio:hover{
  border-color:var(--led-eternity);transform:translateY(-2px);
  padding-right:18px;
  box-shadow:0 12px 38px rgba(155,124,255,.35)}

.sticky-audio__ring{
  position:relative;width:52px;height:52px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center}
.sticky-audio__ring svg{position:absolute;inset:4px;transform:rotate(-90deg)}
.sticky-audio__track{
  fill:none;stroke:rgba(255,255,255,.12);stroke-width:2}
.sticky-audio__progress{
  fill:none;stroke:var(--led-intro);stroke-width:2;stroke-linecap:round;
  stroke-dasharray:119.4;stroke-dashoffset:119.4;
  transition:stroke-dashoffset .12s linear,stroke .25s var(--ease)}
.sticky-audio.is-playing .sticky-audio__progress{stroke:var(--led-eternity)}

.sticky-audio__icon{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-size:.8rem;line-height:1;color:var(--led-intro);
  transition:color .25s var(--ease)}
.sticky-audio.is-playing .sticky-audio__icon{color:var(--led-eternity)}
.sticky-audio .ico-pause,.sticky-audio .ico-arrow{display:none}
.sticky-audio.is-playing .ico-play{display:none}
.sticky-audio.is-playing .ico-pause{display:inline}
.sticky-audio.is-done .ico-play{display:none}
.sticky-audio.is-done .ico-arrow{display:inline}
.sticky-audio__label--done{display:none}
.sticky-audio.is-done .sticky-audio__label--default{display:none}
.sticky-audio.is-done .sticky-audio__label--done{display:inline}

/* Mode CTA post-écoute : palette neon/acid, label visible d'office */
.sticky-audio.is-done{
  border-color:var(--neon);
  background:linear-gradient(135deg,rgba(155,249,179,.15),rgba(241,255,79,.10),rgba(10,10,11,.78));
  animation:none;
  box-shadow:0 8px 30px rgba(0,0,0,.4),0 0 0 3px rgba(155,249,179,.15)}
.sticky-audio.is-done .sticky-audio__icon{color:var(--neon)}
.sticky-audio.is-done .sticky-audio__progress{stroke:var(--neon)}
.sticky-audio.is-done .sticky-audio__label{max-width:260px;padding-left:14px;color:var(--neon)}

.sticky-audio__label{
  display:inline-block;max-width:0;overflow:hidden;white-space:nowrap;
  font-family:var(--font-mono);font-size:.66rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink);
  transition:max-width .35s var(--ease),padding-left .35s var(--ease)}
.sticky-audio:hover .sticky-audio__label,
.sticky-audio.is-playing .sticky-audio__label{max-width:240px;padding-left:14px}

.sticky-audio audio{display:none}

/* Pulse subtil quand idle pour signaler la présence */
@keyframes sticky-pulse{
  0%,100%{box-shadow:0 8px 30px rgba(0,0,0,.4),0 0 0 0 rgba(95,227,255,.35)}
  50%{box-shadow:0 8px 30px rgba(0,0,0,.4),0 0 0 12px rgba(95,227,255,0)}
}
.sticky-audio:not(.is-playing){animation:sticky-pulse 3s var(--ease) infinite}
.sticky-audio:hover{animation:none}

@media(max-width:760px){
  .sticky-audio{right:14px;bottom:calc(74px + 12px + env(safe-area-inset-bottom,0))}
}

@media (prefers-reduced-motion: reduce){
  .sticky-audio{animation:none !important;transition:none}
}

/* ===========================================================================
   SCROLL PROGRESS INDICATOR · barre LED sous la led-strip
   =========================================================================== */
.scroll-prog{
  position:fixed;left:0;right:0;top:4px;height:2px;
  z-index:999;pointer-events:none;background:rgba(255,255,255,.04)}
.scroll-prog__bar{
  height:100%;width:0;
  background:linear-gradient(90deg,var(--led-intro),var(--neon),var(--acid),var(--led-galaxy));
  background-size:300% 100%;
  box-shadow:0 0 12px rgba(155,124,255,.45);
  transition:width .08s linear;
  animation:ledflow 6s linear infinite}
@media(prefers-reduced-motion:reduce){
  .scroll-prog__bar{animation:none;transition:none}
}

/* ===========================================================================
   SIDE NAV verticale (scroll-spy) · dots LED qui s'allument selon section
   =========================================================================== */
.side-nav{
  position:fixed;right:18px;top:50%;transform:translateY(-50%);z-index:920;
  display:flex;flex-direction:column;gap:14px;pointer-events:none}
.side-nav__dot{
  position:relative;width:16px;height:16px;display:inline-flex;
  align-items:center;justify-content:center;pointer-events:auto;
  text-decoration:none;outline:none}
.side-nav__bullet{
  width:6px;height:6px;border-radius:50%;
  background:rgba(255,255,255,.22);
  transition:width .35s var(--ease),height .35s var(--ease),
             background .35s var(--ease),box-shadow .35s var(--ease)}
.side-nav__dot:hover .side-nav__bullet{
  width:9px;height:9px;background:rgba(155,249,179,.55)}
.side-nav__dot.is-active .side-nav__bullet{
  width:10px;height:10px;background:var(--neon);
  box-shadow:0 0 14px rgba(155,249,179,.7)}
/* Tooltip label apparaît au hover */
.side-nav__dot::after{
  content:attr(data-label);position:absolute;right:24px;top:50%;
  transform:translate(-6px,-50%);
  font-family:var(--font-mono);font-size:.58rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink);white-space:nowrap;
  padding:5px 9px;border-radius:3px;
  background:rgba(10,10,11,.85);border:1px solid var(--line);
  opacity:0;pointer-events:none;
  transition:opacity .25s var(--ease),transform .25s var(--ease)}
.side-nav__dot:hover::after{opacity:1;transform:translate(0,-50%)}

@media(max-width:1024px){.side-nav{display:none}}
@media(prefers-reduced-motion:reduce){
  .side-nav__bullet,.side-nav__dot::after{transition:none}
}
