/* ============================================================
   OPERIX — Système de design V4 "Flux"
   Fil conducteur : un canvas de particules fixe (#flux) en fond,
   sections blanches éditoriales par-dessus, bandes transparentes
   qui laissent réapparaître le courant. Acide rare. Zéro tiret cadratin.
   ============================================================ */
:root{
  --ink:#06060a;--ink-2:#13131a;--paper:#fff;--paper-2:#f5f5f2;
  --acid:#c8ff00;--forest:#15803d;--acid-ink:#3d6b00;
  --soft:#b3b2bf;--soft-2:#54525f;--line:#ececef;
  --ease:cubic-bezier(.16,1,.3,1);
  --display:'Bricolage Grotesque',sans-serif;--sans:'Hanken Grotesk',system-ui,sans-serif;--mono:'Spline Sans Mono',monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--ink);color:#fff;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
::selection{background:var(--acid);color:var(--ink-2)}
:focus-visible{outline:2px solid var(--forest);outline-offset:3px;border-radius:4px}

#flux{position:fixed;inset:0;z-index:0;pointer-events:none}
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.045;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 160 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
main{position:relative;z-index:2}
.wrap{max-width:1200px;margin:0 auto;padding:0 44px}
@media(max-width:760px){.wrap{padding:0 22px}}

/* ---------- NAV ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:60;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);color:#13131a;display:flex;align-items:center;justify-content:space-between;padding:13px 44px;border-bottom:1px solid var(--line)}
.logo{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:700;font-size:1.22rem;letter-spacing:-.02em}
.logo .mk{width:30px;height:30px;border-radius:8px;background:var(--ink-2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.logo .mk::after{content:'';width:13px;height:13px;border-radius:50%;background:var(--acid);box-shadow:0 0 10px rgba(200,255,0,.6)}
.logo .ix{color:var(--acid);-webkit-text-stroke:.5px var(--acid-ink);paint-order:stroke}
.nav-links{display:flex;gap:28px;align-items:center;font-size:.9rem;color:var(--soft-2)}
.nav-links a:not(.nav-cta){position:relative}
.nav-links a:not(.nav-cta):hover{color:var(--ink-2)}
.nav-links a.active{color:var(--ink-2);font-weight:600}
.nav-cta{background:var(--ink-2);color:#fff!important;font-weight:700;padding:10px 20px;border-radius:100px;transition:transform .25s var(--ease)}
.nav-cta:hover{transform:translateY(-2px)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:var(--ink-2);border-radius:2px;transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile{position:fixed;inset:0;z-index:55;background:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:26px;opacity:0;pointer-events:none;transition:opacity .3s}
.mobile.open{opacity:1;pointer-events:auto}
.mobile a{font-family:var(--display);font-size:1.5rem;font-weight:600;color:#13131a}
@media(max-width:860px){.nav-links{display:none}.burger{display:flex}nav{padding:12px 22px}}

/* ---------- HOME HERO (plein écran) ---------- */
.hero{position:relative;height:100svh;min-height:600px}
.hero-top{position:absolute;top:96px;left:44px;z-index:5}
.eyebrow{display:inline-flex;align-items:center;gap:11px;font-family:var(--mono);font-size:.9rem;letter-spacing:.08em;text-transform:uppercase;color:var(--acid);flex-wrap:wrap}
.eyebrow::before{content:'';width:9px;height:9px;border-radius:50%;background:var(--acid);box-shadow:0 0 14px var(--acid)}
.hero-bottom{position:absolute;left:44px;right:44px;bottom:50px;z-index:5;display:flex;align-items:flex-end;justify-content:space-between;gap:40px;flex-wrap:wrap}
.hero h1{font-family:var(--display);font-weight:700;font-size:clamp(2.5rem,7.4vw,7rem);line-height:.9;letter-spacing:-.045em;color:#fff}
.hero h1 .l{display:block;overflow:hidden}
.hero h1 .l span{display:block;transform:translateY(110%);animation:rise .9s var(--ease) forwards}
.hero h1 .l:nth-child(2) span{animation-delay:.1s}
.hero h1 em{font-style:normal;color:var(--acid)}
@keyframes rise{to{transform:none}}
.rc{max-width:400px;opacity:0;animation:fade 1s var(--ease) .6s forwards}
.panel{background:rgba(8,8,12,.55);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:24px;backdrop-filter:blur(12px);box-shadow:0 30px 70px -30px rgba(0,0,0,.7)}
.panel .lead{font-size:1.08rem;color:#dedde5;line-height:1.55}.panel .lead b{color:#fff;font-weight:600}
.cta-row{display:flex;align-items:center;gap:18px;margin-top:20px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:1rem;padding:14px 24px;border-radius:100px;transition:transform .3s var(--ease),box-shadow .3s;cursor:pointer;border:none;font-family:inherit}
.btn-acid{background:var(--acid);color:var(--ink-2)}
.btn-acid:hover{transform:translateY(-3px);box-shadow:0 16px 40px -12px rgba(200,255,0,.5)}
.btn-dark{background:var(--ink-2);color:#fff}
.btn-dark:hover{transform:translateY(-3px);box-shadow:0 16px 40px -16px rgba(6,6,10,.6)}
.btn-ghost{font-weight:600;color:#fff;opacity:.9;border-bottom:1px solid rgba(255,255,255,.35);padding-bottom:3px;font-size:.96rem}
.btn-ghost:hover{border-color:var(--acid)}
.btn-ghost.dk{color:var(--ink-2);border-color:rgba(19,19,26,.3)}
.btn-ghost.dk:hover{border-color:var(--forest)}
.trust{display:flex;gap:22px;margin-top:20px;flex-wrap:wrap}
.trust span{font-size:.92rem;color:#cbcad5;display:flex;align-items:center;gap:8px}
.trust span::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--acid)}
@keyframes fade{to{opacity:1}}
.scrollcue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:5;font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.45);display:flex;flex-direction:column;align-items:center;gap:9px}
.scrollcue .bar{width:1px;height:30px;background:linear-gradient(var(--acid),transparent);animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
@media(max-width:820px){.hero-top{left:22px;top:84px}.eyebrow{font-size:.74rem;gap:8px}.hero-bottom{left:22px;right:22px;bottom:30px;flex-direction:column;align-items:flex-start;gap:22px}.rc{max-width:none;width:100%}}

/* ---------- PAGE HERO (pages internes, compact, sur le flux) ---------- */
.phero{position:relative;z-index:2;min-height:64svh;display:flex;align-items:flex-end;padding:128px 0 60px;overflow:hidden}
.phero .wrap{width:100%}
.phero .eyebrow{color:var(--acid)}
.phero h1{font-family:var(--display);font-weight:700;font-size:clamp(2.4rem,6vw,5.4rem);line-height:.95;letter-spacing:-.04em;color:#fff;margin-top:20px;text-wrap:balance;max-width:17ch}
.phero h1 em{font-style:normal;color:var(--acid)}
.phero .plead{max-width:54ch;margin-top:22px;color:#cbcad5;font-size:1.14rem;line-height:1.62;text-wrap:pretty}
.phero .plead b{color:#fff;font-weight:600}
.phero .cta-row{margin-top:28px}
.pgbot{position:absolute;left:0;right:0;bottom:0;height:34px;z-index:1;pointer-events:none;background:linear-gradient(transparent,var(--paper))}
.pgbot.alt{background:linear-gradient(transparent,var(--paper-2))}
@media(max-width:820px){.phero{padding:108px 0 44px;min-height:auto}}

/* ---------- SECTIONS BLANCHES ---------- */
.sec{position:relative;z-index:2;background:var(--paper);color:var(--ink-2);padding:clamp(66px,9vw,120px) 0}
.sec.alt{background:var(--paper-2)}
.kick{font-family:var(--mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--forest);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.kick::before{content:'';width:22px;height:1px;background:var(--forest)}
h2{font-family:var(--display);font-weight:700;font-size:clamp(1.9rem,4.6vw,3.4rem);letter-spacing:-.03em;line-height:1.05;max-width:20ch;text-wrap:balance}
h2.wide{max-width:24ch}
h2 em{font-style:normal;background:linear-gradient(transparent 62%,rgba(200,255,0,.55) 0);padding:0 .04em}
.sec-lead{color:var(--soft-2);font-size:1.1rem;line-height:1.6;max-width:54ch;margin-top:16px;text-wrap:pretty}
.eyebrow-dk{font-family:var(--mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--forest)}

/* ---------- BENTO / TUILES ---------- */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-top:44px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:44px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:44px}
.tile{border:1px solid var(--line);border-radius:20px;padding:26px;display:flex;flex-direction:column;justify-content:space-between;min-height:190px;background:#fff;transition:transform .35s var(--ease),box-shadow .35s,border-color .35s,background .35s,color .35s}
.tile.span3{grid-column:span 3}.tile.span2{grid-column:span 2}
.ic{width:48px;height:48px;border-radius:13px;background:var(--ink-2);display:flex;align-items:center;justify-content:center;position:relative;margin-bottom:auto;transition:background .35s}
.ic svg{width:22px;height:22px;fill:none;stroke:#fff;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.ic::after{content:'';position:absolute;top:-4px;right:-4px;width:13px;height:13px;border-radius:50%;background:var(--acid);border:2.5px solid #fff;transition:border-color .35s}
.tile h3{font-family:var(--display);font-size:1.2rem;font-weight:600;margin-top:20px;letter-spacing:-.01em;transition:color .35s}
.tile p{font-size:.9rem;color:var(--soft-2);line-height:1.55;margin-top:8px;text-wrap:pretty;transition:color .35s}
.tile .more{margin-top:16px;font-size:.84rem;font-weight:700;color:var(--forest);display:inline-flex;gap:6px;transition:color .35s}
.tile:hover{transform:translateY(-6px);background:var(--ink-2);border-color:transparent;box-shadow:0 30px 60px -30px rgba(6,6,10,.55)}
.tile:hover h3{color:#fff}
.tile:hover p{color:rgba(255,255,255,.72)}
.tile:hover .more{color:var(--acid)}
.tile:hover .ic{background:rgba(255,255,255,.1)}
.tile:hover .ic::after{border-color:var(--ink-2)}
@media(max-width:900px){.bento{grid-template-columns:1fr 1fr}.tile.span3,.tile.span2{grid-column:span 1}.grid3{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.bento,.grid3,.grid2{grid-template-columns:1fr}}

/* ---------- CUBES QUI SE BALANCENT ---------- */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:48px}
.flow.three{grid-template-columns:repeat(3,1fr)}
.fcard{position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;min-height:236px;display:flex;flex-direction:column;box-shadow:0 18px 40px -28px rgba(19,19,26,.22);animation:sway 6.5s var(--ease) infinite;transition:transform .4s var(--ease),box-shadow .4s,background .4s,color .4s}
.fcard:nth-child(2){animation-delay:-1.6s}
.fcard:nth-child(3){animation-delay:-3.2s}
.fcard:nth-child(4){animation-delay:-4.8s}
@keyframes sway{0%,100%{transform:translateY(0) rotate(-.7deg)}50%{transform:translateY(-12px) rotate(.7deg)}}
.fcard:hover{animation-play-state:paused;transform:translateY(-14px) rotate(0);background:var(--ink-2);border-color:transparent;box-shadow:0 36px 70px -30px rgba(6,6,10,.5);color:#fff}
.fcard .n{width:42px;height:42px;border-radius:12px;background:var(--ink-2);color:var(--acid);font-family:var(--display);font-weight:700;display:flex;align-items:center;justify-content:center;margin-bottom:auto;transition:background .4s}
.fcard:hover .n{background:rgba(255,255,255,.1)}
.fcard h3{font-family:var(--display);font-size:1.16rem;font-weight:600;margin-top:22px;letter-spacing:-.01em}
.fcard p{font-size:.88rem;color:var(--soft-2);line-height:1.5;margin-top:8px;text-wrap:pretty;transition:color .4s}
.fcard:hover p{color:rgba(255,255,255,.74)}
.fcard .tag{margin-top:14px;font-family:var(--mono);font-size:.7rem;color:var(--forest);transition:color .4s}
.fcard:hover .tag{color:var(--acid)}
@media(max-width:900px){.flow,.flow.three{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.flow,.flow.three{grid-template-columns:1fr}.fcard{animation:none;min-height:auto}}

/* ---------- AVANT / APRÈS ---------- */
.ba{display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:stretch;margin-top:44px}
.ba-col{border-radius:22px;padding:32px}
.ba-before{background:#faf9f7;border:1px solid var(--line);border-left:4px solid var(--acid)}
.ba-after{background:var(--ink-2);color:#fff;position:relative;overflow:hidden;box-shadow:0 30px 70px -30px rgba(6,6,10,.6)}
.ba-after::after{content:'';position:absolute;width:200px;height:200px;border-radius:50%;background:rgba(200,255,0,.14);filter:blur(70px);top:-60px;right:-50px}
.ba-lbl{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px;color:var(--soft)}
.ba-after .ba-lbl{color:var(--acid)}
.ba-li{display:flex;gap:12px;font-size:.95rem;line-height:1.5;margin-bottom:13px;color:var(--soft-2)}
.ba-after .ba-li{color:rgba(255,255,255,.9)}
.ba-li::before{content:'';width:8px;height:8px;border-radius:2px;background:#c2bdb4;flex-shrink:0;margin-top:7px}
.ba-after .ba-li::before{content:'✓';background:none;color:var(--acid);font-weight:800;width:auto;height:auto;margin-top:0}
.ba-arrow{align-self:center;width:52px;height:52px;border-radius:50%;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--forest);font-size:1.4rem;box-shadow:0 12px 30px -10px rgba(21,128,61,.25)}
@media(max-width:760px){.ba{grid-template-columns:1fr;gap:14px}.ba-arrow{transform:rotate(90deg);margin:0 auto}}

/* ---------- TARIFS / PACKS ---------- */
.packs{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:44px}
.pack{border:1px solid var(--line);border-radius:20px;padding:28px;background:#fff;transition:transform .3s var(--ease),box-shadow .3s;display:flex;flex-direction:column}
.pack:hover{transform:translateY(-5px);box-shadow:0 26px 50px -28px rgba(19,19,26,.2)}
.pack.feat{background:var(--ink-2);color:#fff;border-color:transparent;position:relative}
.pack.feat::before{content:'Le plus choisi';position:absolute;top:-11px;left:22px;background:var(--acid);color:var(--ink-2);font-family:var(--mono);font-size:.62rem;letter-spacing:.06em;text-transform:uppercase;padding:5px 12px;border-radius:20px;font-weight:600}
.pack .pn{font-family:var(--display);font-size:1.1rem;font-weight:600}
.pack .pp{font-family:var(--display);font-size:2.2rem;font-weight:700;letter-spacing:-.02em;margin-top:10px}
.pack .pp small{font-size:.85rem;font-weight:500;color:var(--soft-2)}
.pack.feat .pp small{color:rgba(255,255,255,.6)}
.pack .pfor{font-size:.86rem;color:var(--soft-2);margin-top:6px}
.pack.feat .pfor{color:rgba(255,255,255,.65)}
.pack .pcount{font-family:var(--display);font-weight:700;font-size:1.05rem;margin-top:8px;color:var(--ink-2)}
.pack.feat .pcount{color:var(--acid)}
.pack .plist{margin:18px 0 0;display:flex;flex-direction:column;gap:9px}
.pack .plist li{list-style:none;display:flex;gap:9px;font-size:.84rem;color:var(--soft-2);line-height:1.4}
.pack.feat .plist li{color:rgba(255,255,255,.8)}
.pack .plist li::before{content:'✓';color:var(--forest);font-weight:800;flex-shrink:0}
.pack.feat .plist li::before{color:var(--acid)}
.pack .pbtn{display:block;text-align:center;margin-top:auto;padding:12px;border-radius:100px;font-weight:700;font-size:.9rem;background:var(--paper-2);color:var(--ink-2);transition:background .2s,color .2s;border:none;cursor:pointer;font-family:inherit;width:100%}
.pack .plist+.pbtn{margin-top:22px}
.pack .pbtn:hover{background:var(--ink-2);color:#fff}
.pack.feat .pbtn{background:var(--acid);color:var(--ink-2)}
@media(max-width:980px){.packs{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.packs{grid-template-columns:1fr}}
.oneshot{display:flex;align-items:center;justify-content:space-between;gap:28px;margin-top:22px;padding:26px 30px;border:1px solid var(--line);border-radius:20px;background:#fff;flex-wrap:wrap}
.oneshot h3{font-family:var(--display);font-size:1.2rem;font-weight:600;letter-spacing:-.01em;margin-bottom:8px}
.oneshot p{font-size:.92rem;color:var(--soft-2);line-height:1.55;max-width:62ch;text-wrap:pretty}
.oneshot p b{color:var(--ink-2);font-weight:700}
.oneshot .btn-dark{flex-shrink:0}
@media(max-width:760px){.oneshot{flex-direction:column;align-items:flex-start}}

/* ---------- TABLEAU COMPARATIF ---------- */
.compare{margin-top:48px;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff}
.compare table{width:100%;border-collapse:collapse;font-size:.92rem}
.compare th,.compare td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line)}
.compare tr:last-child td{border-bottom:none}
.compare thead th{font-family:var(--display);font-size:.92rem;font-weight:600;letter-spacing:-.01em;color:rgba(255,255,255,.62);background:var(--ink-2);padding:18px}
.compare thead th:first-child{font-family:var(--mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.5);font-weight:500}
.compare thead th:nth-child(4){color:var(--acid)}
.compare tbody td:nth-child(4){background:rgba(200,255,0,.05)}
.compare tbody tr:hover td{background:rgba(21,128,61,.04)}
.compare td:first-child,.compare th:first-child{color:var(--ink-2);font-weight:500}
.compare .yes{color:var(--forest);font-weight:800}
.compare .no{color:var(--soft)}
@media(max-width:760px){.compare{overflow-x:auto}.compare table{min-width:560px}}

/* ---------- STATS ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:44px}
.stat{border:1px solid var(--line);border-radius:18px;padding:26px;background:#fff;transition:transform .35s var(--ease),box-shadow .35s}
.stat:hover{transform:translateY(-5px);box-shadow:0 26px 50px -30px rgba(19,19,26,.2)}
.stat .v{font-family:var(--display);font-size:2.5rem;font-weight:700;letter-spacing:-.02em;color:var(--ink-2)}
.stat .v em{font-style:normal;color:var(--forest)}
.stat .k{font-size:.88rem;color:var(--soft-2);margin-top:6px;text-wrap:pretty}
@media(max-width:860px){.stats{grid-template-columns:1fr 1fr}}

/* ---------- SPLIT 2 COLONNES ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;margin-top:46px}
.split.rev .split-media{order:-1}
.checks{margin-top:24px;display:flex;flex-direction:column;gap:13px}
.checks li{list-style:none;position:relative;padding-left:28px;font-size:1.02rem;color:var(--soft-2);line-height:1.55}
.checks li::before{content:'✓';position:absolute;left:0;top:0;color:var(--forest);font-weight:800}
.checks li b{color:var(--ink-2);font-weight:600}
.split-media{border-radius:22px;background:var(--ink-2);color:#fff;padding:34px;position:relative;overflow:hidden;min-height:300px;box-shadow:0 30px 70px -34px rgba(6,6,10,.6)}
.split-media::after{content:'';position:absolute;width:220px;height:220px;border-radius:50%;background:rgba(200,255,0,.14);filter:blur(74px);bottom:-70px;left:-50px}
.split-media .smk{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--acid);position:relative;z-index:1}
.split-media .srow{position:relative;z-index:1;display:flex;align-items:center;gap:13px;padding:15px 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:.95rem;color:rgba(255,255,255,.9)}
.split-media .srow:last-child{border-bottom:none}
.split-media .srow .dot{width:9px;height:9px;border-radius:50%;background:var(--acid);flex-shrink:0;box-shadow:0 0 10px rgba(200,255,0,.6)}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:30px}.split.rev .split-media{order:0}}

/* ---------- CHIPS ---------- */
.chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:24px}
.chip{font-family:var(--mono);font-size:.74rem;color:var(--soft-2);border:1px solid var(--line);border-radius:100px;padding:7px 14px;background:#fff;transition:border-color .25s,color .25s}
.chip:hover{border-color:var(--forest);color:var(--ink-2)}
.chip b{color:var(--forest);font-weight:500}

/* ---------- FAQ ---------- */
.faq{margin-top:44px;max-width:840px;display:flex;flex-direction:column;gap:12px}
.faq details{border:1px solid var(--line);border-radius:16px;background:#fff;padding:2px 24px;transition:border-color .3s var(--ease),box-shadow .3s var(--ease),background .3s}
.faq details:hover{border-color:#dadae1;box-shadow:0 18px 40px -30px rgba(19,19,26,.28)}
.faq details[open]{border-color:var(--ink-2);background:#fbfbfa;box-shadow:0 26px 54px -34px rgba(19,19,26,.32)}
.faq summary{font-family:var(--display);font-weight:600;font-size:1.08rem;cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:22px;color:var(--ink-2);padding:20px 0;transition:color .25s}
.faq summary:hover{color:#000}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'';flex-shrink:0;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line);background:linear-gradient(var(--ink-2),var(--ink-2)) center/12px 1.7px no-repeat,linear-gradient(var(--ink-2),var(--ink-2)) center/1.7px 12px no-repeat;transition:transform .35s var(--ease),background-color .3s,border-color .3s}
.faq details[open] summary::after{transform:rotate(135deg);background-color:var(--acid);border-color:var(--acid)}
.faq p{margin:0 0 22px;color:var(--soft-2);line-height:1.65;text-wrap:pretty;max-width:68ch;animation:faqIn .4s var(--ease)}
@keyframes faqIn{from{opacity:0;transform:translateY(-7px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.faq p{animation:none}}

/* ---------- BANDES TRANSPARENTES (le courant réapparaît) ---------- */
.band{position:relative;z-index:2;background:transparent;min-height:300px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.band .bw{position:relative;z-index:2;max-width:760px;padding:0 24px}
.band .bk{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--acid);margin-bottom:14px}
.band h2{color:#fff;margin:0 auto;text-wrap:balance}
.band h2 em{background:none;color:var(--acid)}
.gtop,.gbot{position:absolute;left:0;right:0;height:28px;z-index:1;pointer-events:none}
.gtop{top:0;background:linear-gradient(var(--paper),transparent)}
.gtop.alt{background:linear-gradient(var(--paper-2),transparent)}
.gbot{bottom:0;background:linear-gradient(transparent,var(--paper))}
.gbot.alt{background:linear-gradient(transparent,var(--paper-2))}

/* ---------- CTA FINALE ---------- */
.cta{position:relative;z-index:2;background:transparent;padding:clamp(80px,12vw,150px) 0;text-align:center}
.cta .in{position:relative;z-index:2;max-width:720px;margin:0 auto;padding:0 24px}
.cta h2{color:#fff;margin:0 auto;text-wrap:balance}
.cta h2 em{background:none;color:var(--acid)}
.cta p{color:#cbcad5;max-width:62ch;margin:16px auto 28px;text-wrap:balance}
.cta .sub{margin-top:16px;font-family:var(--mono);font-size:.74rem;color:rgba(255,255,255,.55)}

/* ---------- FOOTER ---------- */
footer{position:relative;z-index:2;background:var(--ink-2);color:#fff;border-top:1px solid rgba(255,255,255,.08);padding:54px 44px 36px}
.fgrid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.fcol h4{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--soft);margin-bottom:14px}
.fcol a{display:block;font-size:.9rem;color:#b9b8c4;margin-bottom:9px}.fcol a:hover{color:#fff}
footer .logo .mk{background:#fff}
.ftag{font-size:.9rem;color:#b9b8c4;line-height:1.6;margin-top:14px;max-width:260px;text-wrap:pretty}
.fbot{max-width:1200px;margin:34px auto 0;padding-top:22px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;font-family:var(--mono);font-size:.76rem;color:var(--soft);flex-wrap:wrap;gap:10px}
@media(max-width:760px){footer{padding:44px 22px 30px}.fgrid{grid-template-columns:1fr 1fr;gap:26px}}

/* ---------- PAGES DÉTAIL OFFRE ---------- */
.breadcrumb{font-family:var(--mono);font-size:.74rem;color:rgba(255,255,255,.55);margin-bottom:8px}
.breadcrumb a{color:rgba(255,255,255,.75)}.breadcrumb a:hover{color:var(--acid)}
.qgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:40px}
.qcard{background:#fff;border:1px solid var(--line);border-left:3px solid var(--acid);border-radius:18px;padding:26px;font-size:.98rem;line-height:1.6;color:var(--soft-2);font-style:italic;transition:transform .35s var(--ease),box-shadow .35s}
.qcard:hover{transform:translateY(-5px);box-shadow:0 26px 50px -30px rgba(19,19,26,.2)}
@media(max-width:860px){.qgrid{grid-template-columns:1fr}}
.analogy{margin-top:26px;background:rgba(21,128,61,.08);border:1px solid rgba(21,128,61,.18);border-radius:18px;padding:26px 30px;font-size:1.12rem;line-height:1.6;color:var(--forest);font-weight:500;text-wrap:pretty;max-width:760px}
.center{text-align:center}.center h2,.center .sec-lead{margin-left:auto;margin-right:auto}
.darkcard{position:relative;overflow:hidden;background:var(--ink-2);color:#fff;border-radius:22px;padding:42px;margin-top:40px;box-shadow:0 30px 70px -34px rgba(6,6,10,.6)}
.darkcard::after{content:'';position:absolute;width:280px;height:280px;border-radius:50%;background:rgba(200,255,0,.13);filter:blur(80px);top:-90px;right:-60px}
.darkcard .xt{position:relative;font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--acid);margin-bottom:14px}
.darkcard h3{position:relative;font-family:var(--display);font-size:1.5rem;font-weight:600;margin-bottom:14px;max-width:640px;letter-spacing:-.01em}
.darkcard p{position:relative;color:rgba(255,255,255,.85);max-width:640px;line-height:1.7;text-wrap:pretty}
.pricebox{background:#fff;border:1px solid var(--line);border-radius:24px;padding:44px;text-align:center;max-width:560px;margin:40px auto 0;box-shadow:0 30px 60px -36px rgba(19,19,26,.25)}
.pricebox .pb{font-family:var(--display);font-size:3rem;font-weight:700;letter-spacing:-.02em}
.pricebox .pb small{font-size:1rem;font-weight:500;color:var(--soft-2)}
.pricebox .setup{font-size:.85rem;color:var(--soft);margin-top:8px}
.pricebox .incl{list-style:none;display:inline-flex;flex-direction:column;gap:11px;margin:24px 0;text-align:left}
.pricebox .incl li{display:flex;gap:10px;font-size:.92rem;color:var(--soft-2);line-height:1.4}
.pricebox .incl li::before{content:'✓';color:var(--forest);font-weight:800;flex-shrink:0}
.pricebox .inpack{font-size:.85rem;color:var(--soft-2);margin-bottom:20px}
.pricebox .pbtn{display:block;text-align:center;padding:14px;border-radius:100px;font-weight:700;background:var(--acid);color:var(--ink-2);transition:transform .3s var(--ease),box-shadow .3s}
.pricebox .pbtn:hover{transform:translateY(-3px);box-shadow:0 16px 40px -12px rgba(200,255,0,.5)}

/* ---------- PAGES LÉGALES (prose) ---------- */
.doc{max-width:760px;margin-top:8px}
.doc h2{font-family:var(--display);font-size:1.35rem;font-weight:600;letter-spacing:-.01em;margin:34px 0 10px;color:var(--ink-2)}
.doc h2:first-child{margin-top:0}
.doc p{color:var(--soft-2);line-height:1.7;margin-bottom:12px;text-wrap:pretty}
.doc a{color:var(--forest);text-decoration:underline;text-underline-offset:2px}
.doc ul{margin:0 0 12px 20px;color:var(--soft-2);line-height:1.7}
.doc li{margin-bottom:6px}
.doc strong{color:var(--ink-2);font-weight:600}

/* ---------- REVEAL ---------- */
.rv{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rv.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none}.hero h1 .l span,.rc,.fcard{animation:none!important;opacity:1!important;transform:none!important}}
