:root{--bg:#070711;--bg2:#111022;--card:rgba(255,255,255,.08);--card2:rgba(255,255,255,.13);--text:#fff8ee;--muted:#c5b9d9;--line:rgba(255,255,255,.16);--gold:#f3c877;--pink:#ff4fb7;--cyan:#6de7ff;--violet:#9b7bff;--green:#71f0a5;--red:#ff6f6f;--shadow:0 24px 70px rgba(0,0,0,.38);--radius:24px;--max:1180px}
:root.light{--bg:#faf6ef;--bg2:#f4edff;--card:rgba(255,255,255,.72);--card2:rgba(255,255,255,.92);--text:#20162e;--muted:#665a74;--line:rgba(47,31,68,.16);--gold:#9b6514;--pink:#b71a76;--cyan:#007489;--violet:#5e42c9;--green:#087445;--red:#bd2e2e;--shadow:0 22px 60px rgba(75,55,105,.16)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:radial-gradient(circle at 10% 7%,rgba(255,79,183,.22),transparent 30%),radial-gradient(circle at 86% 9%,rgba(109,231,255,.17),transparent 32%),radial-gradient(circle at 55% 92%,rgba(243,200,119,.13),transparent 36%),linear-gradient(135deg,var(--bg),var(--bg2));color:var(--text);overflow-x:hidden}
body:before{content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;background-image:radial-gradient(circle,rgba(255,255,255,.78) 0 1px,transparent 1.6px),radial-gradient(circle,rgba(255,255,255,.38) 0 1px,transparent 1.5px);background-size:115px 115px,180px 180px;background-position:0 0,42px 74px;opacity:.14;mask-image:linear-gradient(to bottom,black,transparent 88%)}
button,a,input,select{font:inherit}button{border:0;border-radius:999px;color:var(--text);background:linear-gradient(135deg,var(--gold),var(--pink));padding:.88rem 1.1rem;cursor:pointer;box-shadow:0 14px 32px rgba(0,0,0,.24);transition:.2s}button:hover{transform:translateY(-2px);filter:saturate(1.12)}button:focus-visible,a:focus-visible,select:focus-visible,input:focus-visible,[tabindex]:focus-visible{outline:3px solid var(--cyan);outline-offset:3px}button.ghost{background:rgba(255,255,255,.075);border:1px solid var(--line);box-shadow:none}button.small{padding:.55rem .78rem;font-size:.92rem}button[disabled]{opacity:.6;cursor:not-allowed;transform:none}a{color:inherit}.wrap{width:min(var(--max),calc(100% - 28px));margin:0 auto}
.topbar{position:sticky;top:0;z-index:50;background:rgba(7,7,17,.74);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}:root.light .topbar{background:rgba(255,255,255,.74)}.nav{min-height:68px;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.55rem 0}.brand{display:flex;align-items:center;gap:.75rem;text-decoration:none}.logo{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;font-weight:1000;background:conic-gradient(from 160deg,var(--pink),var(--cyan),var(--gold),var(--pink));box-shadow:0 0 34px rgba(255,79,183,.25)}.brand strong{display:block;line-height:1.05}.brand span{font-size:.78rem;color:var(--muted)}.navlinks{display:flex;gap:.45rem;align-items:center;flex-wrap:wrap;justify-content:flex-end}.navlinks a{text-decoration:none;color:var(--muted);font-size:.9rem;padding:.55rem .75rem;border-radius:999px}.navlinks a:hover{background:rgba(255,255,255,.07);color:var(--text)}.navselect{display:none}
select,input[type=date],input[type=range]{width:100%;border:1px solid var(--line);background:rgba(255,255,255,.08);color:var(--text);border-radius:16px;padding:.76rem .85rem}option{color:#14111d}
.hero{min-height:calc(100vh - 72px);display:grid;grid-template-columns:1.03fr .97fr;gap:2rem;align-items:center;padding:70px 0 48px}.kicker{display:inline-flex;align-items:center;gap:.45rem;padding:.42rem .72rem;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.06);color:var(--cyan);font-size:.93rem}h1,h2,h3{letter-spacing:-.045em}h1{font-size:clamp(2.65rem,6vw,6.3rem);line-height:1.03;margin:1rem 0}h2{font-size:clamp(1.9rem,3.6vw,3.5rem);line-height:1.08;margin:.25rem 0 .65rem}h3{font-size:1.28rem;margin:.15rem 0 .65rem}p{line-height:1.62}.lead{font-size:clamp(1.05rem,2vw,1.35rem);color:var(--muted);max-width:760px}.grad{background:linear-gradient(90deg,var(--gold),var(--pink),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}.cta{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.25rem}
.hero-visual{position:relative;min-height:560px;border:1px solid var(--line);border-radius:38px;background:linear-gradient(145deg,var(--card2),rgba(255,255,255,.04));box-shadow:var(--shadow);overflow:hidden}.hero-visual:before{content:"";position:absolute;inset:-20%;background:radial-gradient(circle at 30% 28%,rgba(255,79,183,.20),transparent 22%),radial-gradient(circle at 68% 34%,rgba(109,231,255,.17),transparent 24%),conic-gradient(from 0deg,transparent,rgba(243,200,119,.18),transparent,rgba(255,79,183,.14),transparent);animation:rotateSlow 38s linear infinite}@keyframes rotateSlow{to{transform:rotate(360deg)}}.orbit{position:absolute;border:1px dashed rgba(255,255,255,.22);border-radius:50%;inset:52px;animation:orbit 33s linear infinite}.orbit.o2{inset:112px;animation-duration:24s;animation-direction:reverse}.orbit.o3{inset:172px;animation-duration:50s}@keyframes orbit{to{transform:rotate(360deg)}}.planet{position:absolute;border-radius:50%;display:grid;place-items:center;font-size:2.2rem;font-weight:1000;box-shadow:inset 0 -18px 40px rgba(0,0,0,.22),0 20px 60px rgba(0,0,0,.22)}.p1{width:106px;height:106px;left:42px;top:78px;background:linear-gradient(135deg,var(--pink),var(--gold))}.p2{width:86px;height:86px;right:72px;top:118px;background:linear-gradient(135deg,var(--cyan),var(--violet))}.p3{width:136px;height:136px;left:calc(50% - 68px);top:220px;background:linear-gradient(135deg,var(--gold),var(--red))}.p4{width:76px;height:76px;right:82px;bottom:98px;background:linear-gradient(135deg,var(--green),var(--cyan))}.verdict{position:absolute;left:24px;right:24px;bottom:24px;background:rgba(0,0,0,.34);border:1px solid rgba(255,255,255,.18);border-radius:24px;padding:1rem;backdrop-filter:blur(14px)}:root.light .verdict{background:rgba(255,255,255,.76)}.meter{height:14px;border-radius:999px;background:rgba(255,255,255,.14);overflow:hidden;margin:.65rem 0}.meter span{display:block;height:100%;width:23%;border-radius:999px;background:linear-gradient(90deg,var(--red),var(--gold),var(--green))}
.muted{color:var(--muted)}.badge{display:inline-flex;align-items:center;gap:.35rem;padding:.32rem .58rem;border-radius:999px;border:1px solid var(--line);color:var(--muted);background:rgba(255,255,255,.055);font-size:.84rem}section{padding:50px 0}.panel{border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(145deg,var(--card2),var(--card));box-shadow:var(--shadow);padding:1.15rem}.panel.flat{box-shadow:none;background:rgba(255,255,255,.055)}.grid{display:grid;gap:1rem}.grid.two{grid-template-columns:1fr 1fr}.grid.three{grid-template-columns:repeat(3,1fr)}.grid.four{grid-template-columns:repeat(4,1fr)}.section-head{display:flex;justify-content:space-between;align-items:end;gap:1rem;margin-bottom:1rem}
.scorebar{display:grid;grid-template-columns:repeat(8,1fr);gap:.55rem;margin:1rem 0}.scorebar span{height:8px;background:rgba(255,255,255,.12);border-radius:99px}.scorebar span.done{background:linear-gradient(90deg,var(--gold),var(--green))}.quiz-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:1rem}.quiz-card{min-height:410px;display:grid;align-content:space-between;gap:1rem}.question{font-size:1.35rem;line-height:1.42;padding-left:1rem;border-left:4px solid var(--gold);margin:1rem 0}.options{display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem}.option{width:100%;border-radius:18px;text-align:left;background:rgba(255,255,255,.07);border:1px solid var(--line);box-shadow:none;display:flex;gap:.7rem;align-items:center;justify-content:space-between;min-height:76px}.option .sym{font-size:1.9rem}.option.correct{background:rgba(113,240,165,.12);border-color:rgba(113,240,165,.5)}.option.wrong{background:rgba(255,111,111,.12);border-color:rgba(255,111,111,.5)}.reveal{display:none;border:1px solid var(--line);border-radius:20px;padding:1rem;background:rgba(0,0,0,.24)}:root.light .reveal{background:rgba(255,255,255,.58)}.reveal.show{display:block;animation:pop .25s ease}@keyframes pop{from{opacity:0;transform:translateY(7px)}to{opacity:1;transform:none}}.bigscore{font-size:clamp(2.3rem,5vw,4.9rem);font-weight:1000;letter-spacing:-.07em}
.info,.warn,.danger,.good{border-radius:18px;padding:.9rem;border:1px solid var(--line);background:rgba(255,255,255,.055)}.warn{border-color:rgba(243,200,119,.38);background:rgba(243,200,119,.09)}.danger{border-color:rgba(255,111,111,.38);background:rgba(255,111,111,.09)}.good{border-color:rgba(113,240,165,.38);background:rgba(113,240,165,.08)}
.duel-box{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;align-items:stretch}.person{border:1px solid var(--line);border-radius:22px;background:rgba(255,255,255,.055);padding:1rem;display:flex;flex-direction:column;gap:.65rem;min-height:300px}.avatar{width:76px;height:76px;border-radius:24px;display:grid;place-items:center;font-size:2.45rem;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.48),transparent 34%),linear-gradient(135deg,rgba(255,79,183,.56),rgba(109,231,255,.44))}.name{font-size:1.25rem;font-weight:1000}.vs{display:grid;place-items:center;font-weight:1000;color:var(--gold);text-align:center}.chips{display:flex;gap:.4rem;flex-wrap:wrap}.chip{display:inline-flex;align-items:center;gap:.25rem;border:1px solid var(--line);border-radius:999px;padding:.25rem .48rem;color:var(--muted);background:rgba(255,255,255,.055);font-size:.78rem}
.flip-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.flip-card{min-height:390px;border-radius:22px;perspective:1000px}.flip-inner{position:relative;width:100%;min-height:390px;transition:transform .65s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.flip-card.flipped .flip-inner{transform:rotateY(180deg)}.flip-face{position:absolute;inset:0;backface-visibility:hidden;border:1px solid var(--line);border-radius:22px;background:linear-gradient(145deg,var(--card2),var(--card));padding:1rem;overflow:auto}.flip-front{display:flex;flex-direction:column;justify-content:center;text-align:center;align-items:center}.flip-front .zodiac{font-size:4rem;opacity:.28}.flip-back{transform:rotateY(180deg)}.flip-card button.flip-action{margin-top:auto;border-radius:14px;background:rgba(255,255,255,.07);border:1px solid var(--line);box-shadow:none}
.sign-ring{display:grid;grid-template-columns:repeat(6,1fr);gap:.65rem}.sign-btn{min-height:84px;border-radius:20px;background:rgba(255,255,255,.06);border:1px solid var(--line);box-shadow:none;display:grid;place-items:center;text-align:center;padding:.65rem .4rem}.sign-btn b{font-size:1.75rem}.sign-btn.active{outline:2px solid var(--cyan);box-shadow:0 0 0 6px rgba(109,231,255,.12)}
.barnum-text{margin-top:1rem;border:1px solid var(--line);border-radius:20px;padding:1rem;background:rgba(255,255,255,.065);font-size:1.07rem;line-height:1.74}.rating{display:flex;gap:.55rem;flex-wrap:wrap;margin-top:.7rem}.rating button{width:48px;height:48px;padding:0;background:rgba(255,255,255,.07);border:1px solid var(--line);box-shadow:none}.rating button.active{background:linear-gradient(135deg,var(--gold),var(--pink));color:#16111d}.slider-row{display:grid;grid-template-columns:1fr 92px;gap:.8rem;align-items:center}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(235px,1fr));gap:.85rem}.mini-card{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:22px;padding:1rem;background:rgba(255,255,255,.055)}.mini-card:after{content:attr(data-symbol);position:absolute;right:6px;top:-24px;font-size:6.2rem;opacity:.08;font-weight:1000}
.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:760px}th,td{border-bottom:1px solid var(--line);padding:.85rem;text-align:left;vertical-align:top}th{color:var(--gold);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em}.science-card{border:1px solid var(--line);border-radius:22px;padding:1rem;background:rgba(255,255,255,.055);position:relative;overflow:hidden}.science-card:after{content:attr(data-n);position:absolute;right:12px;top:-22px;font-size:5rem;font-weight:1000;opacity:.06}.sources details{border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.055);padding:1rem;margin:.8rem 0}.sources summary{cursor:pointer;font-weight:900}.sources li{margin:.55rem 0;line-height:1.55;color:var(--muted)}.toast{position:fixed;right:18px;bottom:18px;z-index:100;max-width:430px;border:1px solid var(--line);border-radius:20px;background:rgba(16,12,29,.9);color:var(--text);padding:1rem;box-shadow:var(--shadow);backdrop-filter:blur(14px);display:none}:root.light .toast{background:rgba(255,255,255,.92)}.toast.show{display:block;animation:pop .2s ease}footer{padding:46px 0 70px;color:var(--muted)}.hidden{display:none!important}
@media(max-width:940px){.hero{grid-template-columns:1fr;min-height:auto;padding-top:42px}.hero-visual{min-height:430px}.grid.two,.grid.three,.grid.four,.quiz-layout{grid-template-columns:1fr}.duel-box{grid-template-columns:1fr}.vs{padding:.2rem}.navlinks{display:none}.navselect{display:block;max-width:210px}}@media(max-width:620px){h1{font-size:3rem;line-height:1.08}.options{grid-template-columns:1fr}.sign-ring{grid-template-columns:repeat(3,1fr)}.section-head{display:block}.flip-card,.flip-inner{min-height:430px}}@media(max-width:420px){.sign-ring{grid-template-columns:repeat(2,1fr)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}

/* ==== AJOUTS V3 : modules réellement nouveaux ==== */
.v3-ribbon{display:inline-flex;align-items:center;gap:.45rem;border:1px solid var(--line);border-radius:999px;background:linear-gradient(135deg,rgba(243,200,119,.16),rgba(255,79,183,.11));padding:.35rem .65rem;color:var(--gold);font-size:.86rem}.v3-lab-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:1rem}.v3-tabs{display:flex;gap:.5rem;flex-wrap:wrap;margin:.8rem 0 1rem}.v3-tab.active{background:linear-gradient(135deg,var(--gold),var(--pink));color:#17111d}.v3-score{font-size:clamp(2.2rem,5vw,5rem);font-weight:1000;letter-spacing:-.07em}.v3-traits{display:flex;gap:.5rem;flex-wrap:wrap}.v3-traits button.active{background:linear-gradient(135deg,var(--gold),var(--pink));color:#17111d}.v3-module{position:relative;overflow:hidden}.v3-module:after{content:attr(data-ghost);position:absolute;right:10px;top:-28px;font-size:7rem;font-weight:1000;opacity:.055;pointer-events:none}.v3-source-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.8rem}.v3-mini-report{white-space:pre-wrap;max-height:260px;overflow:auto}.v3-switch-row{display:flex;gap:.5rem;flex-wrap:wrap;margin:.8rem 0}.v3-kpi{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem}.v3-kpi .panel strong{font-size:1.8rem;display:block}.v3-timeline{display:grid;gap:.7rem}.v3-step{display:grid;grid-template-columns:46px 1fr;gap:.7rem;align-items:start}.v3-num{width:46px;height:46px;border-radius:15px;display:grid;place-items:center;font-weight:900;background:linear-gradient(135deg,var(--pink),var(--cyan))}.v3-personal-test textarea{min-height:130px;resize:vertical}.v3-table-compact{min-width:720px}.v3-table-compact td,.v3-table-compact th{font-size:.92rem}.v3-proof{border-left:4px solid var(--cyan);padding-left:1rem}.v3-divider{height:1px;background:var(--line);margin:1rem 0}@media(max-width:900px){.v3-lab-grid,.v3-kpi{grid-template-columns:1fr}.v3-source-grid{grid-template-columns:1fr}}



/* === Enrichissement visuel V4 : typographie plus aérienne et canvas de fond === */
body{font-family:"Inter",ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;line-height:1.72}
h1,h2,h3,.brand strong,.section-title{font-family:"Space Grotesk","Inter",ui-sans-serif,sans-serif}
p,.muted,.lead{line-height:1.75}
#starCanvas,#fxCanvas{position:fixed;inset:0;width:100%;height:100%;pointer-events:none}
#starCanvas{z-index:-3;opacity:.95}
#fxCanvas{z-index:60}
body::before{display:none}

/* === Boutons plus vivants === */
button{position:relative;overflow:hidden}
.btn-fancy::after{content:" ✦";display:inline-block;transition:transform .25s ease, text-shadow .25s ease}
.btn-fancy:hover::after{transform:translateX(4px) rotate(14deg);text-shadow:0 0 14px rgba(255,255,255,.45)}
button:hover{box-shadow:0 18px 36px rgba(0,0,0,.28), 0 0 0 1px rgba(255,255,255,.04) inset}

/* === Avatars générés dynamiquement === */
.avatar{position:relative;overflow:hidden;background:transparent!important;border:1px solid rgba(255,255,255,.15)}
.avatar.avatar-enhanced{display:flex;align-items:center;justify-content:center;padding:0}
.avatar-canvas{width:100%;height:100%;display:block;border-radius:50%}
.avatar-badge{position:absolute;right:4px;bottom:4px;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:.78rem;background:rgba(10,10,20,.72);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(6px)}
:root.light .avatar-badge{background:rgba(255,255,255,.8)}

/* === Illustrations des signes === */
.sign-btn{position:relative;grid-template-columns:auto auto;gap:.5rem;align-items:center;justify-content:center}
.sign-btn b{font-size:1.5rem}
.sign-btn .sign-illustration{width:34px;height:34px;display:inline-grid;place-items:center;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid var(--line)}
.sign-btn .sign-illustration svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;opacity:.95}
.sign-btn span{display:block;font-size:.83rem}

/* === Aura du mode astrologue === */
#mode{position:relative;isolation:isolate}
#mode.astro-aura::before{content:"";position:absolute;inset:-18px;border-radius:34px;background:radial-gradient(circle at 50% 20%, rgba(243,200,119,.22), transparent 45%), radial-gradient(circle at 50% 70%, rgba(255,79,183,.16), transparent 50%);z-index:-1;filter:blur(14px);animation:auraPulse 2.5s ease-in-out infinite}
@keyframes auraPulse{0%,100%{opacity:.68;transform:scale(.995)}50%{opacity:1;transform:scale(1.01)}}

/* === Flip cards : scintillement lors de la révélation === */
.flip-card{position:relative;overflow:visible}
.card-spark{position:absolute;width:8px;height:8px;border-radius:50%;background:radial-gradient(circle,var(--gold),rgba(255,255,255,0));box-shadow:0 0 14px rgba(243,200,119,.8);pointer-events:none;animation:sparkFly .85s ease-out forwards}
@keyframes sparkFly{0%{opacity:0;transform:translate(0,0) scale(.2)}15%{opacity:1}100%{opacity:0;transform:translate(var(--tx),var(--ty)) scale(1.5)}}

/* === Donut de testabilité === */
.v3-score-panel{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.v3-donut-wrap{position:relative;width:164px;height:164px;flex:0 0 auto}
.v3-donut-wrap canvas{width:164px;height:164px;display:block}
.v3-donut-center{position:absolute;inset:0;display:grid;place-items:center;text-align:center}
.v3-donut-center .score-num{font:800 2.2rem/1 "Space Grotesk",sans-serif;letter-spacing:-.05em}
.v3-donut-center .score-cap{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}

/* === Mini roue zodiacale === */
.asc-visuals{display:grid;grid-template-columns:220px 1fr;gap:1rem;align-items:center;margin-top:1rem}
.asc-wheel-wrap{position:relative;width:220px;height:220px;margin:auto}
.asc-wheel-wrap canvas{width:220px;height:220px;display:block}
.asc-wheel-note{font-size:.92rem;color:var(--muted)}

/* === Divers raffinements === */
.panel,.person,.mini-card,.science-card,.flip-face,.hero-visual{backdrop-filter:blur(8px)}
.option{position:relative;overflow:hidden}
.option::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent,rgba(255,255,255,.1),transparent);transform:translateX(-130%);transition:transform .6s ease}
.option:hover::before{transform:translateX(130%)}
.cta a{text-decoration:none}
@media(max-width:760px){.asc-visuals{grid-template-columns:1fr}.asc-wheel-wrap{width:200px;height:200px}}



/* ==========================================================
   INTÉGRATION IMAGES V6 — 17 sections illustrées sombre/clair
   Images locales WebP, sans URL externe, synchronisées au thème.
   ========================================================== */
.section-art{margin-top:1.1rem;margin-bottom:1.25rem;position:relative}
.section-art.hero-art{padding-top:0;margin-top:-22px;margin-bottom:18px}
.art-frame{position:relative;overflow:hidden;border-radius:30px;border:1px solid var(--line);background:linear-gradient(145deg,var(--card2),var(--card));box-shadow:var(--shadow);isolation:isolate}
.art-frame::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 18% 12%,rgba(255,255,255,.18),transparent 30%),linear-gradient(180deg,transparent,rgba(0,0,0,.28));z-index:1;pointer-events:none}
:root.light .art-frame::before{background:radial-gradient(circle at 18% 12%,rgba(255,255,255,.48),transparent 30%),linear-gradient(180deg,transparent,rgba(255,255,255,.18))}
.art-img{display:block;width:100%;height:clamp(220px,38vw,430px);object-fit:cover;filter:saturate(1.05) contrast(1.03);transition:opacity .32s ease,transform .55s ease,filter .32s ease}
.art-frame:hover .art-img{transform:scale(1.025);filter:saturate(1.14) contrast(1.05)}
.art-caption{position:absolute;left:18px;right:18px;bottom:16px;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;color:#fff;text-shadow:0 2px 18px rgba(0,0,0,.55)}
:root.light .art-caption{color:#21172f;text-shadow:0 2px 18px rgba(255,255,255,.75)}
.art-caption strong{font-family:"Space Grotesk",Inter,sans-serif;font-size:clamp(1rem,2vw,1.45rem);letter-spacing:-.02em}
.art-caption span{font-size:.85rem;border:1px solid rgba(255,255,255,.26);background:rgba(0,0,0,.22);padding:.3rem .56rem;border-radius:999px;backdrop-filter:blur(8px)}
:root.light .art-caption span{border-color:rgba(47,31,68,.16);background:rgba(255,255,255,.62)}
.art-mini-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem;margin-top:.8rem}
.art-mini-grid .art-thumb{height:96px;border-radius:18px;overflow:hidden;border:1px solid var(--line);background:var(--card)}
.art-mini-grid img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:640px){.art-img{height:220px}.art-caption{position:relative;left:auto;right:auto;bottom:auto;padding:1rem;background:rgba(0,0,0,.12)}.art-frame::before{opacity:.55}}


/* V7 : image dédiée pour la section mode astrologue + miniatures dans les cartes */
#modeCards .mini-card{padding-top:92px}
#modeCards .mini-card .mode-thumb{position:absolute;left:14px;top:14px;width:84px;height:62px;border-radius:14px;border:1px solid var(--line);background-size:cover;background-position:center center;box-shadow:0 12px 28px rgba(0,0,0,.22), inset 0 0 0 1px rgba(255,255,255,.05)}
#modeCards .mini-card .mode-thumb::after{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(180deg,transparent,rgba(0,0,0,.18))}
#modeCards .mini-card .name{padding-left:96px;min-height:48px;display:flex;align-items:center}
@media(max-width:680px){#modeCards .mini-card{padding-top:86px}#modeCards .mini-card .mode-thumb{width:76px;height:56px}}


/* V8 : magnifique fond d'accueil sombre/clair intégré directement dans la hero section */
.hero{
  position:relative;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:42px;
  padding:70px 24px 48px;
  background:linear-gradient(145deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow:var(--shadow);
  isolation:isolate;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  background-image:
    linear-gradient(90deg, rgba(7,7,17,.82) 0%, rgba(7,7,17,.60) 38%, rgba(7,7,17,.34) 62%, rgba(7,7,17,.22) 100%),
    url('../images/hero_bg_dark.webp');
  background-size:cover;
  background-position:center center;
  opacity:.98;
  transform:scale(1.02);
}
:root.light .hero::before{
  background-image:
    linear-gradient(90deg, rgba(255,255,255,.88) 0%, rgba(255,255,255,.70) 36%, rgba(255,255,255,.42) 62%, rgba(255,255,255,.28) 100%),
    url('../images/hero_bg_light.webp');
}
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:
    radial-gradient(circle at 18% 24%, rgba(255,255,255,.16), transparent 25%),
    radial-gradient(circle at 75% 28%, rgba(109,231,255,.15), transparent 22%),
    linear-gradient(180deg, transparent 0%, rgba(0,0,0,.10) 100%);
  pointer-events:none;
}
:root.light .hero::after{
  background:
    radial-gradient(circle at 18% 24%, rgba(255,255,255,.38), transparent 24%),
    radial-gradient(circle at 75% 28%, rgba(109,231,255,.10), transparent 22%),
    linear-gradient(180deg, transparent 0%, rgba(255,255,255,.08) 100%);
}
.hero > *{
  position:relative;
  z-index:2;
}
.hero .lead, .hero .muted{
  max-width:760px;
}
.hero .kicker{
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.16);
}
:root.light .hero .kicker{
  background:rgba(255,255,255,.70);
}
@media(max-width:940px){
  .hero{
    padding:42px 18px 28px;
    border-radius:30px;
  }
  .hero::before{
    background-image:
      linear-gradient(180deg, rgba(7,7,17,.76) 0%, rgba(7,7,17,.52) 38%, rgba(7,7,17,.36) 100%),
      url('../images/hero_bg_dark.webp');
  }
  :root.light .hero::before{
    background-image:
      linear-gradient(180deg, rgba(255,255,255,.86) 0%, rgba(255,255,255,.62) 40%, rgba(255,255,255,.40) 100%),
      url('../images/hero_bg_light.webp');
  }
}


/* V10 : les images des boutons d'introduction occupent toute la carte */
.intro-grid .panel.flat{
  position:relative;
  overflow:hidden;
  min-height:238px;
  padding:18px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  isolation:isolate;
}
.intro-grid .intro-thumb{
  position:absolute;
  inset:0;
  height:auto;
  border-radius:inherit;
  border:none;
  background-size:cover;
  background-position:center;
  box-shadow:none;
}
.intro-grid .intro-thumb::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:linear-gradient(180deg, rgba(0,0,0,.08) 0%, rgba(0,0,0,.18) 34%, rgba(0,0,0,.62) 100%);
}
:root.light .intro-grid .intro-thumb::after{
  background:linear-gradient(180deg, rgba(255,255,255,.05) 0%, rgba(255,255,255,.16) 36%, rgba(255,255,255,.72) 100%);
}
.intro-grid .panel.flat > *:not(.intro-thumb){
  position:relative;
  z-index:1;
}
.intro-grid .panel.flat h3{
  margin-top:auto;
  text-shadow:0 2px 16px rgba(0,0,0,.28);
}
.intro-grid .panel.flat p{
  margin-bottom:0;
  max-width:40ch;
}
.intro-grid .panel.flat .badge{
  align-self:flex-start;
  background:rgba(255,255,255,.16);
  backdrop-filter:blur(8px);
}
:root.light .intro-grid .panel.flat .badge{
  background:rgba(255,255,255,.72);
}
@media(max-width:680px){
  .intro-grid .panel.flat{min-height:220px;padding:16px}
}

/* V9 : portraits découpés pour la section "Comment sauver une contradiction ?" */
#modeCards .mini-card{
  padding-top:176px;
}
#modeCards .mini-card .portrait-thumb{
  position:absolute;
  left:14px;
  top:14px;
  width:132px;
  height:132px;
  border-radius:22px;
  border:1px solid var(--line);
  background-size:cover;
  background-position:center;
  box-shadow:0 18px 42px rgba(0,0,0,.28), inset 0 0 0 1px rgba(255,255,255,.07);
}
#modeCards .mini-card .portrait-thumb::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:radial-gradient(circle at 35% 18%, rgba(255,255,255,.20), transparent 35%), linear-gradient(180deg, transparent 55%, rgba(0,0,0,.25));
}
#modeCards .mini-card .mode-thumb{
  display:none !important;
}
#modeCards .mini-card .name{
  padding-left:146px;
  min-height:78px;
  display:flex;
  align-items:center;
}
@media(max-width:680px){
  .intro-grid .panel.flat{min-height:220px;padding-top:110px}
  #modeCards .mini-card{padding-top:156px}
  #modeCards .mini-card .portrait-thumb{width:118px;height:118px}
  #modeCards .mini-card .name{padding-left:132px}
}


/* V12 : vidéos locales pour l'accueil sur PC, avec images en secours */
.hero-bg-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
  opacity:.98;
  transform:scale(1.02);
  pointer-events:none;
}
.hero-bg-video.hero-light{
  display:none;
}
:root.light .hero-bg-video.hero-dark{
  display:none;
}
:root.light .hero-bg-video.hero-light{
  display:block;
}
.hero.video-ready::before{
  opacity:0;
}
.hero.video-ready::after{
  z-index:1;
}
.hero > *{
  position:relative;
  z-index:2;
}

/* Sur mobile/tablette : on garde les images WebP, les vidéos restent non affichées */
@media(max-width:940px), (pointer:coarse){
  .hero-bg-video{
    display:none !important;
  }
  .hero.video-ready::before{
    opacity:.98;
  }
}
@media(prefers-reduced-motion:reduce){
  .hero-bg-video{
    display:none !important;
  }
  .hero.video-ready::before{
    opacity:.98;
  }
}


/* V13 : le bloc sous la vidéo devient un bandeau large et peu haut */
.hero{
  grid-template-columns:1fr !important;
  gap:1.2rem !important;
}
.hero > div:first-child{
  max-width:980px;
}
.hero .hero-visual{
  min-height:170px !important;
  height:170px !important;
  width:100% !important;
  max-width:none !important;
  border-radius:30px !important;
  margin-top:.35rem;
}
.hero .hero-visual::before{
  opacity:.72;
}
.hero .orbit{
  inset:18px !important;
}
.hero .orbit.o2{
  inset:52px !important;
}
.hero .orbit.o3{
  inset:86px !important;
}
.hero .planet.p1{
  width:72px !important;
  height:72px !important;
  left:34px !important;
  top:34px !important;
  font-size:1.55rem !important;
}
.hero .planet.p2{
  width:58px !important;
  height:58px !important;
  right:48px !important;
  top:26px !important;
  font-size:1.35rem !important;
}
.hero .planet.p3{
  width:90px !important;
  height:90px !important;
  left:auto !important;
  right:185px !important;
  top:56px !important;
  font-size:1.8rem !important;
}
.hero .planet.p4{
  width:54px !important;
  height:54px !important;
  right:88px !important;
  bottom:26px !important;
  font-size:1.15rem !important;
}
.hero .verdict{
  left:auto !important;
  right:18px !important;
  bottom:14px !important;
  width:min(430px, calc(100% - 36px)) !important;
  padding:.78rem .9rem !important;
  border-radius:20px !important;
}
.hero .verdict p{
  line-height:1.5 !important;
  font-size:.94rem !important;
}
.hero .meter{
  margin:.45rem 0 !important;
}
@media(max-width:940px){
  .hero .hero-visual{
    min-height:150px !important;
    height:150px !important;
  }
  .hero .planet.p3{
    right:130px !important;
    top:48px !important;
  }
  .hero .verdict{
    width:calc(100% - 24px) !important;
    right:12px !important;
    bottom:10px !important;
    padding:.68rem .78rem !important;
  }
}
@media(max-width:620px){
  .hero .hero-visual{
    min-height:138px !important;
    height:138px !important;
    border-radius:24px !important;
  }
  .hero .orbit{inset:16px !important}
  .hero .orbit.o2{inset:44px !important}
  .hero .orbit.o3{inset:72px !important}
  .hero .planet.p1{width:56px !important;height:56px !important;left:22px !important;top:28px !important}
  .hero .planet.p2{width:46px !important;height:46px !important;right:24px !important;top:22px !important}
  .hero .planet.p3{width:70px !important;height:70px !important;right:98px !important;top:45px !important}
  .hero .planet.p4{width:40px !important;height:40px !important;right:40px !important;bottom:20px !important}
  .hero .verdict{
    font-size:.9rem !important;
  }
}


/* V14 : amélioration de lisibilité des flip cards "Retourne les cartes." */
.flip-card{
  isolation:isolate;
}
.flip-inner{
  transform-style:preserve-3d;
}
.flip-face{
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
}

/* Face avant : garde l'effet verre, mais plus maîtrisé */
.flip-front{
  background:
    linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.06)),
    linear-gradient(145deg,var(--card2),var(--card));
}
:root.light .flip-front{
  background:
    linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,255,255,.62)),
    linear-gradient(145deg,var(--card2),var(--card));
}

/* Face arrière : bien plus opaque pour supprimer l'effet de transparence parasite */
.flip-back{
  background:
    linear-gradient(180deg, rgba(10,8,24,.96), rgba(18,14,32,.94)),
    radial-gradient(circle at 20% 15%, rgba(243,200,119,.10), transparent 26%),
    radial-gradient(circle at 80% 20%, rgba(109,231,255,.08), transparent 24%);
  border-color:rgba(255,255,255,.18);
  box-shadow:
    0 24px 60px rgba(0,0,0,.35),
    inset 0 0 0 1px rgba(255,255,255,.03);
}
:root.light .flip-back{
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,244,255,.94)),
    radial-gradient(circle at 20% 15%, rgba(243,200,119,.12), transparent 26%),
    radial-gradient(circle at 80% 20%, rgba(109,231,255,.08), transparent 24%);
  border-color:rgba(47,31,68,.16);
  box-shadow:
    0 20px 48px rgba(75,55,105,.14),
    inset 0 0 0 1px rgba(255,255,255,.22);
}

/* Renforce le contraste du contenu retourné */
.flip-back h3,
.flip-back strong{
  color:var(--text);
}
.flip-back p,
.flip-back .muted{
  color:var(--text);
}
.flip-back .danger,
.flip-back .good{
  background:rgba(255,255,255,.07);
  backdrop-filter:blur(6px);
}
:root.light .flip-back .danger,
:root.light .flip-back .good{
  background:rgba(255,255,255,.72);
}

/* Lorsque la carte se retourne, on masque plus fortement la face opposée */
.flip-card.flipped .flip-front{
  opacity:0.02;
}
.flip-card:not(.flipped) .flip-back{
  opacity:0.02;
}

/* Légère amélioration typographique */
.flip-back p{
  line-height:1.65;
}


/* ==========================================================
   V22 — Retourne les cartes : flip fiable en carte flottante
   Principe :
   - on ne modifie plus la carte d'origine ni la grille
   - au clic, une carte flottante part de la carte originale
   - elle grossit, tourne en deux temps, puis affiche le dos opaque
   - aucune ligne ne descend, aucune face arrière invisible
   ========================================================== */

#mur .flip-grid{
  overflow:visible !important;
}

#mur .flip-card{
  cursor:pointer;
}

/* Carte source légèrement atténuée pendant l'ouverture */
#mur .flip-card.v22-source{
  opacity:.38;
  filter:blur(.4px) saturate(.85);
}

/* Voile discret */
.v22-dim{
  position:fixed;
  inset:0;
  z-index:8000;
  opacity:0;
  background:rgba(0,0,0,.24);
  backdrop-filter:blur(2px);
  transition:opacity .22s ease;
}
:root.light .v22-dim{
  background:rgba(255,255,255,.28);
}
.v22-dim.show{
  opacity:1;
}

/* Carte flottante indépendante */
.v22-overlay{
  position:fixed;
  z-index:8010;
  perspective:1400px;
  transform-origin:center center;
  transition:
    left .44s cubic-bezier(.2,.72,.18,1),
    top .44s cubic-bezier(.2,.72,.18,1),
    width .44s cubic-bezier(.2,.72,.18,1),
    height .44s cubic-bezier(.2,.72,.18,1),
    opacity .22s ease;
}

.v22-shell{
  position:relative;
  width:100%;
  height:100%;
  transform-style:preserve-3d;
  transition:transform .32s cubic-bezier(.22,.7,.25,1);
  filter:drop-shadow(0 34px 86px rgba(0,0,0,.42));
}

.v22-face{
  position:absolute;
  inset:0;
  border:1px solid var(--line);
  border-radius:30px;
  overflow:hidden;
  box-shadow:var(--shadow);
}

/* Face avant copiée depuis la carte originale */
.v22-front{
  display:block;
  background:linear-gradient(145deg,var(--card2),var(--card));
}
.v22-front .flip-front{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  min-height:0 !important;
  border:0 !important;
  border-radius:30px !important;
  box-shadow:none !important;
  display:flex !important;
  opacity:1 !important;
  overflow:hidden !important;
}

/* Face arrière normale, non inversée : aucun risque de backface invisible */
.v22-back{
  display:none;
  padding:1.18rem;
  background:
    linear-gradient(180deg, rgba(8,7,20,.992), rgba(17,13,31,.975)),
    radial-gradient(circle at 18% 13%, rgba(243,200,119,.14), transparent 30%),
    radial-gradient(circle at 82% 18%, rgba(109,231,255,.11), transparent 28%);
  color:var(--text);
  flex-direction:column;
  gap:.6rem;
}
:root.light .v22-back{
  background:
    linear-gradient(180deg, rgba(255,255,255,.995), rgba(248,244,255,.975)),
    radial-gradient(circle at 18% 13%, rgba(243,200,119,.15), transparent 30%),
    radial-gradient(circle at 82% 18%, rgba(109,231,255,.10), transparent 28%);
}

.v22-back h3{
  margin:.15rem 0 .35rem;
  color:var(--text);
  font-size:1.42rem;
}
.v22-back p,
.v22-back .muted{
  color:var(--text) !important;
  font-size:.98rem;
  line-height:1.54;
  margin:.42rem 0;
}
.v22-back .danger,
.v22-back .good{
  padding:.78rem .86rem;
  margin-top:.62rem;
  border-radius:17px;
  background:rgba(255,255,255,.085);
  backdrop-filter:blur(8px);
}
:root.light .v22-back .danger,
:root.light .v22-back .good{
  background:rgba(255,255,255,.78);
}
.v22-back small{
  display:block;
  margin-top:.25rem;
  color:var(--muted);
  line-height:1.35;
}

.v22-close{
  position:absolute;
  right:12px;
  top:12px;
  z-index:10;
  width:40px;
  height:40px;
  padding:0;
  border-radius:50%;
  border:1px solid var(--line);
  background:rgba(255,255,255,.16);
  box-shadow:none;
  backdrop-filter:blur(10px);
}
:root.light .v22-close{
  background:rgba(255,255,255,.76);
}

/* Animation en 2 temps :
   1. front tourne jusqu'à 90°
   2. on affiche le back et on revient à 0°
*/
.v22-overlay.turn-out .v22-shell{
  transform:rotateY(88deg) scale(1.035);
}
.v22-overlay.back-start .v22-shell{
  transition:none;
  /* V23 : on garde le même sens de rotation visuelle */
  transform:rotateY(88deg) scale(1.035);
}
.v22-overlay.back-visible .v22-shell{
  transition:transform .34s cubic-bezier(.22,.72,.2,1);
  transform:rotateY(0deg) scale(1);
}
.v22-overlay.back-visible .v22-front{
  display:none;
}
.v22-overlay.back-visible .v22-back,
.v22-overlay.back-start .v22-back{
  display:flex;
}

.v22-overlay.closing{
  opacity:0;
}

/* Neutralisation douce des vieux états si un ancien handler tente encore de passer */
#mur .flip-card.flipped .flip-inner{
  transform:none !important;
}
#mur .flip-card.flipped .flip-front{
  opacity:1 !important;
}
#mur .flip-card.flipped .flip-back{
  opacity:0 !important;
  pointer-events:none !important;
}

@media(max-width:620px){
  .v22-back{
    padding:1rem;
  }
  .v22-back h3{
    font-size:1.22rem;
  }
  .v22-back p,
  .v22-back .muted{
    font-size:.92rem;
    line-height:1.45;
  }
  .v22-back .danger,
  .v22-back .good{
    padding:.65rem .7rem;
  }
}


/* ==========================================================
   Portraits dans les flip-cards (Mur des contradictions)
   ========================================================== */
.flip-portrait{
  display:block;
  width:80px;
  height:80px;
  border-radius:18px;
  object-fit:cover;
  margin:.2rem auto .6rem;
  box-shadow:0 10px 26px rgba(0,0,0,.32), 0 0 0 1px rgba(255,255,255,.08) inset;
  border:1px solid var(--line);
}
:root.light .flip-portrait{
  box-shadow:0 8px 22px rgba(75,55,105,.18), 0 0 0 1px rgba(255,255,255,.6) inset;
}
.flip-portrait-mini{
  width:96px;
  height:96px;
  border-radius:14px;
  margin:.1rem auto .55rem;
  box-shadow:0 6px 16px rgba(0,0,0,.30);
}
.flip-front .zodiac{
  position:absolute;
  right:14px;
  top:10px;
  font-size:2.4rem;
  opacity:.22;
  pointer-events:none;
}
.flip-back h3{
  text-align:center;
  margin-top:0;
}
@media(max-width:620px){
  .flip-portrait{width:70px;height:70px}
  .flip-portrait-mini{width:90px;height:90px}
}


/* ==========================================================
   Bouton "Activer le mode astrologue" — halo pulsant magnétique
   ========================================================== */
#astroMode{
  background: linear-gradient(135deg, var(--gold), var(--pink)) !important;
  border: 1px solid rgba(255,255,255,.20) !important;
  color: #17111d !important;
  font-weight: 800;
  letter-spacing: .02em;
  position: relative;
  isolation: isolate;
  z-index: 1;
  padding: .95rem 1.4rem;
  transition: transform .25s ease, filter .25s ease, box-shadow .25s ease;
  animation: astroBtnPulse 2.4s ease-in-out infinite;
}

/* Halo (calque ::before) */
#astroMode::before{
  content: "";
  position: absolute;
  inset: -14px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 30% 30%, rgba(243,200,119,.55), transparent 55%),
    radial-gradient(circle at 70% 70%, rgba(255,79,183,.45), transparent 60%);
  z-index: -1;
  filter: blur(16px);
  animation: astroBtnHalo 2.4s ease-in-out infinite;
  pointer-events: none;
  transition: filter .35s ease, transform .35s ease, opacity .35s ease;
}

/* État ON (mode astrologue activé) — palette verte/cyan apaisée */
#astroMode[aria-pressed="true"]{
  background: linear-gradient(135deg, var(--green), var(--cyan)) !important;
  animation-name: astroBtnPulseOn;
}
#astroMode[aria-pressed="true"]::before{
  background:
    radial-gradient(circle at 30% 30%, rgba(113,240,165,.55), transparent 55%),
    radial-gradient(circle at 70% 70%, rgba(109,231,255,.45), transparent 60%);
}

/* Niveau 1 : souris à proximité (dans le .section-head du mode) */
#mode .section-head:hover #astroMode{
  transform: translateY(-1px) scale(1.03);
  filter: saturate(1.10) brightness(1.05);
}
#mode .section-head:hover #astroMode::before{
  filter: blur(20px);
  transform: scale(1.18);
  opacity: 1;
}

/* Niveau 2 : survol direct du bouton — effet maximal */
#astroMode:hover{
  transform: translateY(-3px) scale(1.06) !important;
  filter: saturate(1.25) brightness(1.10) !important;
  box-shadow: 0 22px 50px rgba(255,79,183,.55), 0 0 0 1px rgba(255,255,255,.30) inset !important;
}
#astroMode[aria-pressed="true"]:hover{
  box-shadow: 0 22px 50px rgba(109,231,255,.55), 0 0 0 1px rgba(255,255,255,.30) inset !important;
}
#astroMode:hover::before{
  filter: blur(24px) !important;
  transform: scale(1.42) !important;
  opacity: 1 !important;
}

/* Active (clic) */
#astroMode:active{
  transform: translateY(0) scale(1.02) !important;
  transition-duration: .05s !important;
}

/* Animations */
@keyframes astroBtnPulse{
  0%,100% { box-shadow: 0 12px 32px rgba(255,79,183,.30), 0 0 0 1px rgba(255,255,255,.10) inset; }
  50%     { box-shadow: 0 18px 46px rgba(255,79,183,.55), 0 0 0 1px rgba(255,255,255,.22) inset; }
}
@keyframes astroBtnPulseOn{
  0%,100% { box-shadow: 0 12px 32px rgba(109,231,255,.30), 0 0 0 1px rgba(255,255,255,.10) inset; }
  50%     { box-shadow: 0 18px 46px rgba(109,231,255,.55), 0 0 0 1px rgba(255,255,255,.22) inset; }
}
@keyframes astroBtnHalo{
  0%,100% { opacity: .55; transform: scale(.94); }
  50%     { opacity: 1;   transform: scale(1.10); }
}

@media (prefers-reduced-motion: reduce){
  #astroMode, #astroMode::before { animation: none !important; transition: none !important; }
}


/* ==========================================================
   Section "Références & position" — typographie réduite (÷1.7)
   ========================================================== */
#references{
  font-size: 0.764em;
}
#references h2{
  font-size: clamp(1.46rem, 2.76vw, 2.68rem) !important;
  line-height: 1.18;
}
#references h3{
  font-size: 1.24rem !important;
  line-height: 1.3;
  margin: .5rem 0 .35rem;
}
#references p,
#references li,
#references span,
#references small,
#references strong,
#references em,
#references a{
  font-size: inherit;
}
#references .badge,
#references .chip{
  font-size: .75em;
  padding: .22rem .5rem;
}
#references .panel{
  padding: .9rem;
}
#references ul,
#references ol{
  line-height: 1.7;
}
#references ol > li{
  margin-bottom: .35rem;
}


/* FINAL : sous-visuels narratifs dans "De la croyance partagée au verrou logique" */
.subvisual-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
  gap:.85rem;
  margin:1.1rem 0 1.25rem;
}
.subvisual-card{
  position:relative;
  overflow:hidden;
  min-height:210px;
  border:1px solid var(--line);
  border-radius:22px;
  background:linear-gradient(145deg,var(--card2),var(--card));
  box-shadow:0 18px 48px rgba(0,0,0,.20);
  isolation:isolate;
}
.subvisual-card img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:scale(1.015);
  transition:transform .5s ease, filter .35s ease;
}
.subvisual-card:hover img{
  transform:scale(1.055);
  filter:saturate(1.12) contrast(1.04);
}
.subvisual-card::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:linear-gradient(180deg,rgba(0,0,0,.06) 0%,rgba(0,0,0,.22) 42%,rgba(0,0,0,.72) 100%);
}
:root.light .subvisual-card::after{
  background:linear-gradient(180deg,rgba(255,255,255,.04) 0%,rgba(255,255,255,.20) 38%,rgba(255,255,255,.82) 100%);
}
.subvisual-content{
  position:absolute;
  left:14px;
  right:14px;
  bottom:14px;
  z-index:2;
}
.subvisual-content strong{
  display:block;
  font-family:"Space Grotesk","Inter",sans-serif;
  font-size:1.02rem;
  letter-spacing:-.02em;
  color:#fff;
  text-shadow:0 2px 14px rgba(0,0,0,.45);
}
:root.light .subvisual-content strong{
  color:var(--text);
  text-shadow:0 2px 16px rgba(255,255,255,.70);
}
.subvisual-content p{
  margin:.25rem 0 0;
  font-size:.88rem;
  line-height:1.38;
  color:rgba(255,255,255,.82);
}
:root.light .subvisual-content p{
  color:var(--muted);
}

/* FINAL : petites illustrations dans les étapes 1 à 7 du dossier-preuves */
#dossier-preuves .panel.has-mini-illustration{
  position:relative;
  overflow:hidden;
}
#dossier-preuves .mini-step-illustration{
  display:flex;
  align-items:flex-start;
  gap:.85rem;
  margin:.75rem 0 .55rem;
}
#dossier-preuves .mini-step-thumb{
  position:relative;
  flex:0 0 112px;
  width:112px;
  height:84px;
  overflow:hidden;
  border-radius:16px;
  border:1px solid var(--line);
  box-shadow:0 10px 28px rgba(0,0,0,.18);
  background:linear-gradient(145deg,var(--card2),var(--card));
}
#dossier-preuves .mini-step-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
#dossier-preuves .mini-step-caption{
  min-width:0;
  flex:1 1 auto;
  padding-top:.1rem;
}
#dossier-preuves .mini-step-caption strong{
  display:block;
  font-family:"Space Grotesk","Inter",sans-serif;
  font-size:.98rem;
  line-height:1.15;
  margin:0 0 .22rem;
}
#dossier-preuves .mini-step-caption p{
  margin:0;
  color:var(--muted);
  font-size:.88rem;
  line-height:1.36;
}
@media(max-width:700px){
  .subvisual-card{min-height:185px}
  #dossier-preuves .mini-step-illustration{gap:.7rem}
  #dossier-preuves .mini-step-thumb{flex-basis:86px;width:86px;height:68px;border-radius:14px}
  #dossier-preuves .mini-step-caption strong{font-size:.92rem}
  #dossier-preuves .mini-step-caption p{font-size:.82rem}
}


/* ==========================================================
   Tableau comparatif — petits portraits dans les colonnes A et B
   ========================================================== */
.cmp-cell{
  display:flex;
  align-items:center;
  gap:.7rem;
}
.cmp-portrait{
  width:48px;
  height:48px;
  border-radius:12px;
  object-fit:cover;
  flex-shrink:0;
  box-shadow:0 4px 12px rgba(0,0,0,.28);
  border:1px solid var(--line);
}
:root.light .cmp-portrait{
  box-shadow:0 4px 10px rgba(75,55,105,.16);
}
@media(max-width:620px){
  .cmp-portrait{width:40px;height:40px}
  .cmp-cell{gap:.5rem}
}


/* ==========================================================
   Illustrations du dossier-preuves + bannière références
   ========================================================== */
.dossier-step-img{
  display:block;
  width:100%;
  max-height:180px;
  object-fit:cover;
  border-radius:18px;
  margin-bottom:.9rem;
  border:1px solid var(--line);
  box-shadow:0 10px 24px rgba(0,0,0,.32);
  filter:saturate(1.05);
}
:root.light .dossier-step-img{
  box-shadow:0 8px 20px rgba(75,55,105,.16);
}
.references-banner{
  display:block;
  width:100%;
  max-height:160px;
  object-fit:cover;
  border-radius:22px;
  margin-bottom:1.1rem;
  border:1px solid var(--line);
  box-shadow:0 12px 28px rgba(0,0,0,.32);
}
:root.light .references-banner{
  box-shadow:0 10px 24px rgba(75,55,105,.16);
}
@media(max-width:620px){
  .dossier-step-img{max-height:130px}
  .references-banner{max-height:110px}
}


/* ==========================================================
   Navigation avec dropdowns (CSS-only via <details>)
   ========================================================== */
.navlinks{
  display:flex;
  gap:.4rem;
  align-items:center;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.navdrop{
  position:relative;
}
.navdrop > summary{
  list-style:none;
  cursor:pointer;
  padding:.55rem .85rem;
  border-radius:999px;
  color:var(--muted);
  font-size:.92rem;
  user-select:none;
  display:inline-flex;
  align-items:center;
  gap:.3rem;
  transition:background .15s ease, color .15s ease;
}
.navdrop > summary::-webkit-details-marker{display:none}
.navdrop > summary::after{
  content:⌄;
  font-size:.85rem;
  opacity:.7;
  transition:transform .2s ease;
}
.navdrop[open] > summary::after{transform:rotate(180deg)}
.navdrop > summary:hover,
.navdrop[open] > summary{
  background:rgba(255,255,255,.07);
  color:var(--text);
}
:root.light .navdrop > summary:hover,
:root.light .navdrop[open] > summary{
  background:rgba(47,31,68,.06);
}
.navdrop-menu{
  position:absolute;
  top:calc(100% + .5rem);
  right:0;
  min-width:240px;
  background:rgba(7,7,17,.96);
  border:1px solid var(--line);
  border-radius:18px;
  padding:.5rem;
  box-shadow:0 18px 48px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.06) inset;
  backdrop-filter:blur(20px);
  display:flex;
  flex-direction:column;
  gap:.18rem;
  z-index:200;
  animation:navdropOpen .18s ease-out;
}
:root.light .navdrop-menu{
  background:rgba(255,255,255,.96);
  box-shadow:0 18px 40px rgba(75,55,105,.18), 0 0 0 1px rgba(255,255,255,.6) inset;
}
.navdrop-menu a{
  display:block;
  padding:.55rem .8rem;
  border-radius:12px;
  text-decoration:none;
  color:var(--muted);
  font-size:.92rem;
  transition:background .12s ease, color .12s ease;
}
.navdrop-menu a:hover,
.navdrop-menu a:focus-visible{
  background:rgba(255,255,255,.07);
  color:var(--text);
  outline:none;
}
:root.light .navdrop-menu a:hover,
:root.light .navdrop-menu a:focus-visible{
  background:rgba(47,31,68,.07);
}
@keyframes navdropOpen{
  from{opacity:0;transform:translateY(-6px)}
  to{opacity:1;transform:translateY(0)}
}

/* Sur mobile, on cache la nav desktop et on garde le select */
@media(max-width:940px){
  .navlinks{display:none}
}


/* ==========================================================
   Section 'Mentions légales' — typographie réduite (cohérence avec #references)
   ========================================================== */
#mentions-legales{
  font-size: 0.764em;
}
#mentions-legales h2{
  font-size: clamp(1.46rem, 2.76vw, 2.68rem) !important;
  line-height: 1.18;
}
#mentions-legales h3{
  font-size: 1.24rem !important;
  line-height: 1.3;
  margin: .5rem 0 .35rem;
}
#mentions-legales p,
#mentions-legales li,
#mentions-legales span,
#mentions-legales small,
#mentions-legales strong,
#mentions-legales em,
#mentions-legales a,
#mentions-legales code{
  font-size: inherit;
}
#mentions-legales .badge{
  font-size: .75em;
  padding: .22rem .5rem;
}
#mentions-legales .panel,
#mentions-legales .warn{
  padding: .9rem;
}
#mentions-legales ul,
#mentions-legales ol{
  line-height: 1.7;
}
#mentions-legales ul > li{
  margin-bottom: .35rem;
}


/* Art-video : prend exactement la même boîte que .art-img */
.art-video{
  display:block;
  width:100%;
  height:clamp(220px,38vw,430px);
  object-fit:cover;
  filter:saturate(1.05) contrast(1.03);
  transition:opacity .32s ease, transform .55s ease, filter .32s ease;
  background:var(--card);
}
.art-frame:hover .art-video{
  transform:scale(1.025);
  filter:saturate(1.14) contrast(1.05);
}
@media(max-width:640px){
  .art-video{height:220px}
}


/* ==========================================================
   Constellation parallèle — grille de cartes vers les sites soeurs
   ========================================================== */
.constellation-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:1rem;
  margin-top:1.4rem;
}
.constellation-card{
  display:flex;
  flex-direction:column;
  background:linear-gradient(160deg,var(--card2),var(--card));
  border:1px solid var(--line);
  border-radius:18px;
  text-decoration:none;
  color:inherit;
  overflow:hidden;
  transition:transform .35s cubic-bezier(.16,1,.3,1), border-color .35s, box-shadow .35s;
}
.constellation-card:hover{
  transform:translateY(-4px);
  border-color:rgba(243,200,119,.5);
  box-shadow:0 0 0 1px rgba(243,200,119,.15), 0 18px 40px rgba(0,0,0,.35), 0 0 30px rgba(243,200,119,.08);
}
:root.light .constellation-card:hover{
  box-shadow:0 0 0 1px rgba(155,101,20,.18), 0 16px 36px rgba(75,55,105,.16);
}
.constellation-thumb{
  position:relative;
  width:100%;
  aspect-ratio:16/10;
  overflow:hidden;
  background:var(--card);
  border-bottom:1px solid var(--line);
}
.constellation-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:top center;
  display:block;
  transition:transform .6s, filter .4s;
  filter:saturate(.92) brightness(.94);
}
.constellation-card:hover .constellation-thumb img{
  transform:scale(1.05);
  filter:saturate(1.05) brightness(1);
}
.constellation-thumb::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(7,7,17,.85) 100%);
  pointer-events:none;
}
:root.light .constellation-thumb::after{
  background:linear-gradient(180deg,transparent 60%,rgba(255,255,255,.78) 100%);
}
.constellation-icon{
  font-size:1.9rem;
  line-height:1;
  margin:1rem 1.4rem .5rem;
  color:var(--gold);
  opacity:.9;
}
.constellation-name{
  font-family:'Space Grotesk',Inter,sans-serif;
  font-size:1.18rem;
  font-weight:700;
  margin:0 1.4rem .55rem;
  color:var(--text);
  line-height:1.3;
}
.constellation-desc{
  font-size:.88rem;
  line-height:1.55;
  margin:0 1.4rem 1rem;
  flex-grow:1;
}
.constellation-url{
  font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace;
  font-size:.74rem;
  letter-spacing:.04em;
  color:var(--cyan);
  margin:0 1.4rem 1.1rem;
  padding-top:.7rem;
  border-top:1px dashed var(--line);
  transition:color .25s;
}
.constellation-card:hover .constellation-url{color:var(--gold)}
.constellation-footnote{
  margin:2.5rem auto 0;
  max-width:540px;
  text-align:center;
  font-style:italic;
  padding:1.5rem 0;
  border-top:1px dashed var(--line);
}

/* ==========================================================
   Bloc invitation partage
   ========================================================== */
#constellation .share-invite{
  margin-top:2rem;
  padding:2.4rem 1.6rem;
  text-align:center;
  background:radial-gradient(ellipse at top,rgba(109,231,255,.08) 0%,transparent 60%), linear-gradient(160deg,var(--card2),var(--card));
  border:1px solid rgba(109,231,255,.3);
  border-radius:18px;
}
:root.light #constellation .share-invite{
  background:radial-gradient(ellipse at top,rgba(0,116,137,.06) 0%,transparent 60%), linear-gradient(160deg,var(--card2),var(--card));
  border-color:rgba(0,116,137,.25);
}
.share-title{
  font-family:'Space Grotesk',Inter,sans-serif;
  font-size:clamp(1.2rem,2.4vw,1.7rem);
  font-weight:600;
  line-height:1.4;
  margin:.6rem auto 1rem;
  max-width:520px;
}
.share-title em{color:var(--cyan); font-style:italic}
.share-invite p{max-width:560px;margin:0 auto 1.4rem;color:var(--muted);font-size:.94rem;line-height:1.65}
.share-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
  justify-content:center;
  margin-bottom:.8rem;
}
.share-btn{
  padding:.6rem 1.1rem;
  border-radius:999px;
  font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace;
  font-size:.78rem;
  letter-spacing:.04em;
  text-decoration:none;
  cursor:pointer;
  transition:all .2s ease;
  border:1px solid var(--line);
  background:rgba(255,255,255,.05);
  color:var(--text);
  display:inline-flex;
  align-items:center;
  gap:.4rem;
}
:root.light .share-btn{background:rgba(47,31,68,.04)}
.share-btn:hover{
  border-color:var(--cyan);
  background:rgba(109,231,255,.12);
  transform:translateY(-1px);
}
.share-btn-primary{
  border-color:var(--cyan);
  background:rgba(109,231,255,.16);
  color:var(--text);
  font-weight:700;
}
.share-feedback{
  min-height:1.4rem;
  font-family:ui-monospace,monospace;
  font-size:.82rem;
  color:var(--green);
  opacity:0;
  transition:opacity .3s;
  margin-top:.6rem;
}
.share-feedback.is-visible{opacity:1}

@media(max-width:620px){
  .constellation-grid{grid-template-columns:1fr;gap:.8rem}
  #constellation .share-invite{padding:1.8rem 1rem}
}
