/* =========================================================
   LGE Lyon Est x OnlyDream — dossier confidentiel
   Feuille de style partagée (sommaire + 7 pages-questions)
   ========================================================= */
:root{
  --bg:#0a0816;
  --bg2:#121026;
  --bg3:#1a1633;
  --ink:#ece8f6;
  --ink-dim:#a79fc4;
  --cyan:#33e6ff;
  --magenta:#ff3da0;
  --gold:#d9a84e;
  --gold-soft:#f0cd8a;
  --radius:18px;
  --shadow:0 10px 40px rgba(0,0,0,.45);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Outfit',system-ui,sans-serif;
  font-weight:300;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.display{font-family:'Cinzel',serif;line-height:1.15}
h2{font-size:clamp(1.5rem,6vw,2.6rem);font-weight:700}
h3{font-size:clamp(1.05rem,4.2vw,1.4rem);font-weight:700}
strong{font-weight:600;color:var(--ink)}
a{color:var(--cyan)}
section{padding:clamp(56px,10vh,104px) 20px;position:relative}
.wrap{max-width:680px;margin:0 auto}
.eyebrow{
  display:inline-block;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-soft);font-weight:600;margin-bottom:14px;
}
.lead{color:var(--ink-dim);font-size:clamp(1rem,3.8vw,1.15rem)}
.accent-c{color:var(--cyan)}
.accent-g{color:var(--gold-soft)}
.accent-m{color:var(--magenta)}

/* ---------- reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
.reveal.d5{transition-delay:.40s}.reveal.d6{transition-delay:.48s}
.reveal.d7{transition-delay:.56s}.reveal.d8{transition-delay:.64s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .beam,.dot,.scroll-hint span{animation:none !important}
}

/* ---------- top bar (pages internes) ---------- */
.topbar{
  position:sticky;top:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 18px;gap:12px;
  background:rgba(10,8,22,.82);backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(124,92,255,.18);
}
.topbar .brand{
  font-family:'Cinzel',serif;font-weight:700;font-size:.82rem;
  letter-spacing:.06em;color:var(--gold-soft);text-decoration:none;
}
.topbar .brand small{display:block;font-family:'Outfit',sans-serif;font-weight:300;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:#6f679a}
.topbar .home{
  font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;
  color:var(--cyan);text-decoration:none;
  border:1px solid rgba(51,230,255,.35);border-radius:99px;padding:7px 14px;white-space:nowrap;
}
.topbar .home:active{transform:scale(.97)}

/* ---------- en-tête de page-question ---------- */
.qhead{
  text-align:center;padding:clamp(56px,11vh,120px) 22px clamp(30px,6vh,60px);
  background:
    radial-gradient(ellipse 110% 60% at 50% -10%, #221a4d 0%, transparent 60%),
    var(--bg);
}
.qhead .num{
  font-family:'Cinzel',serif;font-weight:700;color:var(--cyan);
  font-size:.9rem;letter-spacing:.2em;margin-bottom:14px;
}
.qhead h1{
  font-size:clamp(1.7rem,7vw,3rem);font-weight:900;max-width:20ch;margin:0 auto;
  background:linear-gradient(180deg,#fff 30%,#bdb2e6 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.qhead p{margin:18px auto 0;max-width:42ch;color:var(--ink-dim);font-size:clamp(1rem,3.9vw,1.18rem)}

/* ---------- hero (sommaire) ---------- */
.hero{
  min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;padding:24px 22px 90px;
  background:
    radial-gradient(ellipse 120% 60% at 50% -10%, #221a4d 0%, transparent 60%),
    radial-gradient(ellipse 80% 50% at 80% 110%, #2a0f33 0%, transparent 55%),
    var(--bg);
  overflow:hidden;
}
.beam{position:absolute;width:200vmax;height:2px;left:50%;top:50%;transform-origin:0 0;pointer-events:none;opacity:.5}
.beam.b1{background:linear-gradient(90deg,transparent,var(--cyan),transparent);animation:sweep1 11s ease-in-out infinite}
.beam.b2{background:linear-gradient(90deg,transparent,var(--magenta),transparent);animation:sweep2 14s ease-in-out infinite}
.beam.b3{background:linear-gradient(90deg,transparent,#7c5cff,transparent);animation:sweep3 17s ease-in-out infinite}
@keyframes sweep1{0%,100%{transform:rotate(8deg)}50%{transform:rotate(-14deg)}}
@keyframes sweep2{0%,100%{transform:rotate(178deg)}50%{transform:rotate(196deg)}}
@keyframes sweep3{0%,100%{transform:rotate(99deg)}50%{transform:rotate(76deg)}}
.dot{position:absolute;border-radius:50%;background:var(--cyan);pointer-events:none;opacity:.7;animation:float 9s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-26px)}}
.hero-badge{
  position:relative;z-index:2;
  font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;
  border:1px solid rgba(217,168,78,.45);color:var(--gold-soft);
  padding:7px 14px;border-radius:99px;margin-bottom:26px;
  background:rgba(10,8,22,.55);backdrop-filter:blur(4px);
}
.hero h1{
  position:relative;z-index:2;
  font-size:clamp(1.9rem,8.4vw,3.6rem);font-weight:900;max-width:18ch;
  background:linear-gradient(180deg,#fff 30%,#bdb2e6 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero p{position:relative;z-index:2;margin-top:20px;max-width:36ch;color:var(--ink-dim);font-size:clamp(.98rem,3.9vw,1.2rem)}
.hero .who{margin-top:14px;font-size:.8rem;letter-spacing:.08em;color:#6f679a}
.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);width:24px;height:40px;border:1.5px solid rgba(167,159,196,.5);border-radius:14px;z-index:2}
.scroll-hint span{position:absolute;top:7px;left:50%;width:4px;height:8px;margin-left:-2px;background:var(--cyan);border-radius:3px;animation:hint 1.8s ease-in-out infinite}
@keyframes hint{0%{opacity:0;transform:translateY(0)}35%{opacity:1}100%{opacity:0;transform:translateY(14px)}}

/* ---------- grille de hub (sommaire) ---------- */
.hubgrid{display:grid;gap:14px;margin-top:30px}
@media (min-width:760px){.hubgrid{grid-template-columns:1fr 1fr}}
.hubcard{
  display:block;text-decoration:none;color:inherit;position:relative;
  background:linear-gradient(160deg,var(--bg3),var(--bg2));
  border:1px solid rgba(124,92,255,.20);border-radius:var(--radius);
  padding:24px 22px;box-shadow:var(--shadow);
  transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease;
  overflow:hidden;
}
.hubcard::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--cyan),var(--magenta));opacity:.7;
}
.hubcard:hover{transform:translateY(-4px);border-color:rgba(51,230,255,.5);box-shadow:0 16px 46px rgba(0,0,0,.55)}
.hubcard .q-num{font-family:'Cinzel',serif;font-weight:700;font-size:.78rem;letter-spacing:.18em;color:var(--gold-soft)}
.hubcard h3{margin-top:8px;color:#fff}
.hubcard p{margin-top:8px;color:var(--ink-dim);font-size:.9rem}
.hubcard .go{
  display:inline-flex;align-items:center;gap:6px;margin-top:14px;
  font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:var(--cyan);
}
.hubcard .go::after{content:'\2192';transition:transform .25s ease}
.hubcard:hover .go::after{transform:translateX(4px)}

/* ---------- cartes constat ---------- */
.cards{display:grid;gap:14px;margin-top:34px}
.card{background:linear-gradient(160deg,var(--bg3),var(--bg2));border:1px solid rgba(124,92,255,.18);border-radius:var(--radius);padding:22px 20px;box-shadow:var(--shadow)}
.card .k{font-family:'Cinzel',serif;font-weight:700;font-size:1.25rem;color:var(--cyan)}
.card.gold .k{color:var(--gold-soft)}
.card p{color:var(--ink-dim);margin-top:6px;font-size:.95rem}
@media (min-width:760px){.cards{grid-template-columns:1fr 1fr}}

/* ---------- vision ---------- */
.vision{min-height:62svh;display:flex;align-items:center;text-align:center;background:radial-gradient(ellipse 90% 70% at 50% 50%, #1c1240 0%, transparent 70%),var(--bg)}
.vision .display{font-size:clamp(2rem,9vw,4rem);font-weight:900;background:linear-gradient(120deg,var(--gold-soft),#fff,var(--gold-soft));-webkit-background-clip:text;background-clip:text;color:transparent}
.vision p{margin-top:22px;font-size:clamp(1.05rem,4.4vw,1.4rem);color:var(--ink-dim)}

/* ---------- balance 10k ---------- */
.balance-zone{background:linear-gradient(180deg,var(--bg) 0%,#0d0a1e 100%)}
.scale-beam{height:6px;border-radius:3px;margin:30px 6px 8px;background:linear-gradient(90deg,var(--gold) 0%,var(--gold) 18%,#3a3360 18%,var(--cyan) 100%);transform-origin:18% 50%;transform:rotate(0deg);transition:transform 1s cubic-bezier(.22,1,.36,1);box-shadow:0 0 18px rgba(51,230,255,.25)}
.balance-cols{display:grid;grid-template-columns:88px 1fr;gap:14px;margin-top:18px;align-items:start}
.cash-chip{background:linear-gradient(160deg,#2a2113,#1c160c);border:1px solid rgba(217,168,78,.5);border-radius:14px;padding:14px 8px;text-align:center;position:sticky;top:74px}
.cash-chip .amt{font-family:'Cinzel',serif;font-weight:700;color:var(--gold-soft);font-size:1.02rem;line-height:1.2}
.cash-chip small{display:block;color:#9b8a63;font-size:.62rem;margin-top:4px;letter-spacing:.08em;text-transform:uppercase}
.stack{display:grid;gap:10px}
.brick{background:linear-gradient(160deg,#16203a,#101a30);border:1px solid rgba(51,230,255,.22);border-left:3px solid var(--cyan);border-radius:12px;padding:13px 15px}
.brick b{display:block;font-weight:600;font-size:.95rem;color:#dff7ff}
.brick span{color:var(--ink-dim);font-size:.82rem}
.punch{margin-top:30px;padding:24px 22px;border-radius:var(--radius);background:linear-gradient(135deg,rgba(217,168,78,.12),rgba(255,61,160,.07));border:1px solid rgba(217,168,78,.35);font-size:clamp(1rem,4vw,1.2rem);font-weight:400}
.punch strong{color:var(--gold-soft)}

/* ---------- deux colonnes "qui amène quoi" ---------- */
.bring{display:grid;gap:16px;margin-top:32px}
@media (min-width:760px){.bring{grid-template-columns:1fr 1fr}}
.bring-col{border-radius:var(--radius);padding:24px 22px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.08)}
.bring-col.od{background:linear-gradient(160deg,#16203a,#0e1626);border-top:3px solid var(--cyan)}
.bring-col.lge{background:linear-gradient(160deg,#241433,#160d20);border-top:3px solid var(--magenta)}
.bring-col .who{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;margin-bottom:6px}
.bring-col.od .who{color:var(--cyan)}
.bring-col.lge .who{color:var(--magenta)}
.bring-col h3{color:#fff}
.bring-col ul{list-style:none;margin-top:14px}
.bring-col li{padding:9px 0 9px 22px;position:relative;color:var(--ink-dim);font-size:.92rem;border-top:1px solid rgba(255,255,255,.06)}
.bring-col li:first-child{border-top:none}
.bring-col li::before{content:'';position:absolute;left:2px;top:18px;width:7px;height:7px;border-radius:2px;transform:rotate(45deg)}
.bring-col.od li::before{background:var(--cyan)}
.bring-col.lge li::before{background:var(--magenta)}
.bring-col li b{color:#fff;font-weight:600}

/* ---------- preuve par le monde ---------- */
.worlds{display:grid;gap:16px;margin-top:32px}
.world{border-radius:var(--radius);overflow:hidden;background:var(--bg2);border:1px solid rgba(255,255,255,.08);box-shadow:var(--shadow)}
.world img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block;background:#1a1633}
.world .in{padding:18px 20px 20px}
.world .place{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);font-weight:600}
.world h3{margin-top:4px;color:#fff}
.world p{color:var(--ink-dim);font-size:.88rem;margin-top:6px}
.credit{margin-top:14px;font-size:.64rem;color:#564f78;text-align:center}
@media (min-width:760px){.worlds{grid-template-columns:1fr 1fr 1fr}}

/* ---------- now strip (photos centre) ---------- */
.now-strip{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-top:22px}
.now-strip figure{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:1;border:1px solid rgba(255,255,255,.08)}
.now-strip img{width:100%;height:100%;object-fit:cover;display:block}
.now-strip figcaption{position:absolute;left:0;right:0;bottom:0;padding:8px 9px;font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;background:linear-gradient(180deg,transparent,rgba(0,0,0,.85));color:rgba(255,255,255,.85)}

/* ---------- saisons ---------- */
.seasons{display:grid;gap:14px;margin-top:32px}
.season{border-radius:var(--radius);padding:24px 22px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.08)}
.season .when{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:rgba(255,255,255,.6);margin-bottom:8px}
.season h3{color:#fff}
.season p{color:var(--ink-dim);font-size:.9rem;margin-top:8px}
.s-paques{background:radial-gradient(ellipse 90% 80% at 80% 10%,rgba(64,255,170,.22),transparent 60%),linear-gradient(165deg,#15301f,#0a1812)}
.s-ete{background:radial-gradient(ellipse 90% 80% at 20% 15%,rgba(51,230,255,.22),transparent 60%),linear-gradient(165deg,#0e2438,#081420)}
.s-halloween{background:radial-gradient(ellipse 90% 80% at 70% 90%,rgba(255,122,61,.25),transparent 60%),linear-gradient(165deg,#2a160a,#140a05)}
.s-noel{background:radial-gradient(ellipse 90% 80% at 30% 90%,rgba(217,168,78,.25),transparent 60%),linear-gradient(165deg,#231634,#120b1d)}
@media (min-width:760px){.seasons{grid-template-columns:1fr 1fr}}

/* ---------- jalons ---------- */
.jalons{display:grid;gap:8px;margin-top:28px}
.jalon{display:flex;align-items:center;gap:12px;background:var(--bg2);border:1px solid rgba(124,92,255,.18);border-radius:12px;padding:12px 14px;font-size:.88rem;color:var(--ink-dim)}
.jalon .d{flex:0 0 92px;font-family:'Cinzel',serif;font-weight:700;font-size:.78rem;color:var(--cyan);line-height:1.25}
.jalon b{color:var(--ink);font-weight:600}
.jalon.gold{background:linear-gradient(135deg,rgba(217,168,78,.16),rgba(217,168,78,.05));border-color:rgba(217,168,78,.5)}
.jalon.gold .d{color:var(--gold-soft)}

/* ---------- risques ---------- */
.risks{display:grid;gap:11px;margin-top:26px}
.risk{background:var(--bg2);border:1px solid rgba(255,61,160,.2);border-left:3px solid var(--magenta);border-radius:12px;padding:14px 16px;font-size:.86rem;color:var(--ink-dim)}
.risk b{display:block;color:var(--ink);font-weight:600;margin-bottom:3px}
.risk .parade{color:#7ee8c7}
@media (min-width:760px){.risks{grid-template-columns:1fr 1fr 1fr}}

/* ---------- comparateur avant/après ---------- */
.compare{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;margin-top:30px;box-shadow:var(--shadow);touch-action:pan-y;user-select:none}
.compare .layer{position:absolute;inset:0;display:flex;align-items:flex-end;padding:16px}
.layer.before{background:linear-gradient(180deg,rgba(10,8,22,.05),rgba(10,8,22,.45)),url('img/hall-avant.jpg') center/cover no-repeat,linear-gradient(150deg,#3b3b45,#23232b 60%,#1a1a20)}
.layer.after{background:linear-gradient(180deg,rgba(10,8,22,.05),rgba(10,8,22,.45)),url('img/hall-apres.jpg') center/cover no-repeat,linear-gradient(150deg,#241a4d,#160f33 65%,#0d0a22);clip-path:inset(0 0 0 50%)}
.compare.v2 .layer.after{background:linear-gradient(180deg,rgba(10,8,22,.05),rgba(10,8,22,.45)),url('img/hall-apres-2.jpg') center/cover no-repeat,linear-gradient(150deg,#241a13,#1a0f0a 65%,#0d0805);clip-path:inset(0 0 0 50%)}
.layer .tag{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;background:rgba(0,0,0,.55);padding:6px 12px;border-radius:99px;backdrop-filter:blur(3px)}
.layer.after .tag{margin-left:auto;color:var(--cyan)}
.compare .ph-hint{position:absolute;top:14px;left:0;right:0;text-align:center;font-size:.68rem;color:rgba(255,255,255,.5);letter-spacing:.1em;text-transform:uppercase}
.handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:#fff;box-shadow:0 0 14px rgba(255,255,255,.8)}
.handle::after{content:'\2194';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%;background:#fff;color:#0a0816;display:flex;align-items:center;justify-content:center;font-size:1.15rem;font-weight:700}

/* ---------- galerie / logos ---------- */
.gallery{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:26px}
.g-item{aspect-ratio:1;border-radius:14px;display:flex;align-items:flex-end;padding:12px;font-size:.78rem;font-weight:600;color:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.08)}
figure.g-item{position:relative;padding:0;overflow:hidden}
figure.g-item img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
figure.g-item figcaption{position:relative;z-index:1;width:100%;padding:10px 12px;font-size:.76rem;font-weight:600;color:#fff;background:linear-gradient(180deg,transparent,rgba(0,0,0,.88))}
.g1{background:linear-gradient(160deg,#33405e,#171d31)}
.g2{background:linear-gradient(160deg,#2c4a3a,#13241c)}
.g3{background:linear-gradient(160deg,#4d3a22,#241a0e)}
.g4{background:linear-gradient(160deg,#42284d,#1d1024)}
.logos{display:flex;flex-wrap:wrap;gap:8px;margin-top:26px;justify-content:center}
.logos span{font-size:.72rem;letter-spacing:.05em;color:var(--ink-dim);border:1px solid rgba(167,159,196,.25);border-radius:99px;padding:7px 13px}
.deco-cta{display:inline-block;margin-top:24px;font-weight:600;font-size:.92rem}
@media (min-width:760px){.gallery{grid-template-columns:repeat(4,1fr)}}

/* ---------- double moteur ---------- */
.motors{display:grid;gap:16px;margin-top:32px}
.motor{border-radius:var(--radius);padding:26px 22px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.07)}
.motor.laser{background:linear-gradient(160deg,#1c1240,#120c2c)}
.motor.after-w{background:linear-gradient(160deg,#241433,#160d20)}
.motor .when{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;margin-bottom:10px}
.motor.laser .when{color:var(--cyan)}
.motor.after-w .when{color:var(--magenta)}
.motor ul{list-style:none;margin-top:12px}
.motor li{padding:6px 0 6px 22px;position:relative;color:var(--ink-dim);font-size:.92rem}
.motor li::before{content:'';position:absolute;left:2px;top:14px;width:7px;height:7px;border-radius:2px;transform:rotate(45deg)}
.motor.laser li::before{background:var(--cyan)}
.motor.after-w li::before{background:var(--magenta)}
.motor-msg{text-align:center;margin-top:24px;font-size:1.05rem}
@media (min-width:760px){.motors{grid-template-columns:1fr 1fr}}

/* ---------- univers flip ---------- */
.unis{display:grid;gap:16px;margin-top:32px}
.uni{perspective:1200px;height:268px;cursor:pointer;-webkit-tap-highlight-color:transparent}
.uni-inner{position:relative;width:100%;height:100%;transition:transform .7s cubic-bezier(.3,.9,.3,1);transform-style:preserve-3d}
.uni.flipped .uni-inner{transform:rotateY(180deg)}
.uni-face{position:absolute;inset:0;border-radius:var(--radius);backface-visibility:hidden;-webkit-backface-visibility:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:22px;border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow)}
.uni-back{transform:rotateY(180deg);justify-content:center;background:var(--bg3);overflow:auto}
.uni-back h3{font-size:1.1rem}
.uni-back p{color:var(--ink-dim);font-size:.86rem;margin-top:8px}
.uni-back .mood{margin-top:10px;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600}
.uni .tap{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:8px}
.uni-front{background-position:center;background-size:cover;background-repeat:no-repeat}
.u-foret .uni-front{background-image:linear-gradient(180deg,rgba(8,7,28,0) 28%,rgba(8,7,28,.9) 100%),url('img/uni-foret.svg')}
.u-temple .uni-front{background-image:linear-gradient(180deg,rgba(8,10,6,0) 28%,rgba(8,10,6,.9) 100%),url('img/uni-temple.svg')}
.u-egypte .uni-front{background-image:linear-gradient(180deg,rgba(14,10,4,0) 28%,rgba(14,10,4,.92) 100%),url('img/uni-egypte.svg')}
.uni-front h3{color:#fff;font-size:clamp(1.05rem,4vw,1.32rem);text-shadow:0 2px 10px rgba(0,0,0,.7)}
.uni-front .sub{color:rgba(255,255,255,.8);font-size:.82rem;text-shadow:0 1px 8px rgba(0,0,0,.7)}
.flag{position:absolute;top:14px;right:14px;font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.2);padding:5px 10px;border-radius:99px;color:var(--gold-soft)}
.aug{margin-top:24px;padding:20px;border-radius:var(--radius);border:1px dashed rgba(124,92,255,.45);background:rgba(124,92,255,.06);font-size:.92rem;color:var(--ink-dim)}
@media (min-width:760px){.unis{grid-template-columns:repeat(3,1fr)}.uni{height:300px}}

/* ---------- humain ---------- */
.quote{font-family:'Cinzel',serif;font-weight:700;font-size:clamp(1.25rem,5.4vw,1.9rem);line-height:1.35;border-left:3px solid var(--gold);padding-left:18px;margin-top:28px}
.chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:26px}
.chips span{font-size:.8rem;border-radius:99px;padding:8px 15px;color:var(--ink);background:rgba(217,168,78,.1);border:1px solid rgba(217,168,78,.35)}

/* ---------- timeline ---------- */
.tl{position:relative;margin-top:36px;padding-left:30px}
.tl::before{content:'';position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:#2a2447}
.tl-fill{position:absolute;left:9px;top:6px;width:2px;height:0;background:linear-gradient(180deg,var(--gold),var(--cyan));transition:height .25s linear;box-shadow:0 0 10px rgba(51,230,255,.5)}
.step{position:relative;margin-bottom:14px}
.step::before{content:'';position:absolute;left:-27px;top:16px;width:12px;height:12px;border-radius:50%;background:var(--bg);border:2px solid #4a4280;transition:.4s}
.step.open::before,.step.passed::before{background:var(--cyan);border-color:var(--cyan);box-shadow:0 0 10px rgba(51,230,255,.7)}
.step-head{width:100%;text-align:left;background:var(--bg2);color:var(--ink);border:1px solid rgba(124,92,255,.2);border-radius:14px;padding:15px 44px 15px 16px;font-family:'Outfit',sans-serif;font-size:.98rem;font-weight:600;cursor:pointer;position:relative;-webkit-tap-highlight-color:transparent}
.step-head small{display:block;font-weight:300;color:var(--ink-dim);font-size:.76rem;margin-top:2px}
.step-head::after{content:'+';position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:1.3rem;color:var(--cyan);transition:transform .3s}
.step.open .step-head::after{transform:translateY(-50%) rotate(45deg)}
.step-body{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.22,1,.36,1)}
.step-body-in{padding:14px 16px;color:var(--ink-dim);font-size:.9rem}
.step-body-in p+p{margin-top:8px}

/* ---------- bonus + demande ---------- */
.bonus{text-align:center;background:radial-gradient(ellipse 80% 60% at 50% 50%,#190f38 0%,transparent 75%),var(--bg)}
.bonus .display{font-size:clamp(1.6rem,7vw,2.8rem);font-weight:900;color:var(--gold-soft)}
.asks{display:grid;gap:11px;margin-top:30px}
.ask{display:flex;gap:14px;align-items:flex-start;background:var(--bg2);border:1px solid rgba(124,92,255,.18);border-radius:14px;padding:16px}
.ask .n{flex:0 0 30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Cinzel',serif;font-weight:700;font-size:.85rem;background:rgba(217,168,78,.14);color:var(--gold-soft);border:1px solid rgba(217,168,78,.4)}
.ask p{font-size:.92rem;color:var(--ink-dim)}
.ask p b{color:var(--ink);font-weight:600}

/* ---------- cta ---------- */
.cta{text-align:center;min-height:70svh;display:flex;align-items:center;background:radial-gradient(ellipse 100% 70% at 50% 110%,#241a4d 0%,transparent 65%),var(--bg)}
.cta .display{font-size:clamp(1.7rem,7.5vw,3rem);font-weight:900}
.btn{display:inline-block;margin-top:34px;padding:18px 42px;border-radius:99px;font-weight:800;font-size:1.05rem;text-decoration:none;color:#0a0816;background:linear-gradient(120deg,var(--gold-soft),var(--gold));box-shadow:0 8px 30px rgba(217,168,78,.35);transition:transform .2s}
.btn:active{transform:scale(.96)}
.sig{margin-top:30px;color:var(--ink-dim);font-size:.9rem}
.sig b{color:var(--ink);font-weight:600}

/* ---------- navigation bas de page (précédent / suivant) ---------- */
.pagenav{max-width:680px;margin:0 auto;padding:8px 20px 10px;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pagenav a{
  text-decoration:none;color:var(--ink);
  background:var(--bg2);border:1px solid rgba(124,92,255,.2);border-radius:14px;
  padding:16px 18px;transition:border-color .25s ease,transform .25s ease;
}
.pagenav a:hover{border-color:rgba(51,230,255,.5);transform:translateY(-3px)}
.pagenav .dir{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim);font-weight:600}
.pagenav .ttl{display:block;margin-top:5px;font-family:'Cinzel',serif;font-weight:700;font-size:.92rem;color:#fff}
.pagenav .next{text-align:right}
.pagenav a.disabled{opacity:.35;pointer-events:none}
.sommaire-link{display:block;text-align:center;margin:6px auto 0;max-width:680px;padding:0 20px}
.sommaire-link a{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--gold-soft);text-decoration:none}

footer{text-align:center;padding:34px 20px 50px;font-size:.7rem;color:#564f78;letter-spacing:.06em}

#top-btn{position:fixed;right:16px;bottom:16px;width:46px;height:46px;border-radius:50%;background:rgba(26,22,51,.9);border:1px solid rgba(124,92,255,.4);color:var(--cyan);font-size:1.1rem;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .3s;z-index:50;backdrop-filter:blur(4px)}
#top-btn.show{opacity:1;pointer-events:auto}

/* ---------- encart "débat / fausse bonne idée" ---------- */
.debate{
  margin-top:26px;border-radius:var(--radius);padding:22px 22px;box-shadow:var(--shadow);
  background:linear-gradient(135deg,rgba(255,61,160,.10),rgba(217,168,78,.07));
  border:1px solid rgba(255,61,160,.32);border-left:3px solid var(--magenta);
}
.debate .tag{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--magenta)}
.debate h3{color:#fff;margin-top:8px}
.debate p{color:var(--ink-dim);font-size:.92rem;margin-top:10px}
.debate p strong{color:var(--gold-soft)}

/* ---------- verrou d'accès (gate.js) ---------- */
html.lge-locked body{visibility:hidden}
html.lge-locked{overflow:hidden}
#lge-gate{
  position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:24px;
  background:
    radial-gradient(ellipse 120% 70% at 50% -10%, #221a4d 0%, transparent 60%),
    radial-gradient(ellipse 80% 50% at 80% 110%, #2a0f33 0%, transparent 55%),
    #0a0816;
  font-family:'Outfit',system-ui,sans-serif;
}
.lge-gate-card{
  width:100%;max-width:380px;text-align:center;
  background:linear-gradient(160deg,#1a1633,#121026);
  border:1px solid rgba(124,92,255,.25);border-radius:18px;
  padding:34px 28px;box-shadow:0 18px 60px rgba(0,0,0,.6);
}
.lge-gate-card.shake{animation:lge-shake .4s}
@keyframes lge-shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-7px)}40%,80%{transform:translateX(7px)}}
.lge-gate-eyebrow{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:#f0cd8a;font-weight:600}
.lge-gate-title{font-family:'Cinzel',serif;font-weight:900;font-size:1.35rem;color:#fff;margin-top:12px;line-height:1.2}
.lge-gate-title span{display:block;font-size:.8rem;font-weight:500;color:#a79fc4;letter-spacing:.08em;margin-top:4px}
.lge-gate-sub{color:#a79fc4;font-size:.9rem;margin-top:14px}
#lge-gate-form{display:flex;gap:8px;margin-top:22px}
#lge-gate-input{
  flex:1;min-width:0;background:#0a0816;color:#ece8f6;
  border:1px solid rgba(124,92,255,.4);border-radius:12px;
  padding:13px 15px;font-size:1rem;font-family:inherit;outline:none;
}
#lge-gate-input:focus{border-color:#33e6ff;box-shadow:0 0 0 2px rgba(51,230,255,.18)}
#lge-gate-form button{
  flex:0 0 auto;border:none;cursor:pointer;border-radius:12px;
  padding:13px 20px;font-weight:800;font-size:.95rem;color:#0a0816;
  background:linear-gradient(120deg,#f0cd8a,#d9a84e);font-family:inherit;
}
#lge-gate-form button:active{transform:scale(.96)}
#lge-gate-err{display:none;margin-top:14px;color:#ff3da0;font-size:.84rem;font-weight:600}
