*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body, 'Inter', sans-serif);background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.55;font-weight:var(--body-weight, 400)}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}

/* ===== TOKENS — palettes ===== */
[data-palette="lime"]{--bg:#0a0a08;--surface:#111110;--surface-2:#16161a;--border:#222220;--border-2:#2a2a26;--text:#e8e6df;--muted:#888070;--muted2:#5a5950;--accent:#c8f060;--accent-soft:rgba(200,240,96,.12);--accent-2:#f0e060;--ink:#0a0a08}
[data-palette="cream"]{--bg:#f5f2ea;--surface:#fffcf3;--surface-2:#ece8dc;--border:#d6d1be;--border-2:#bdb8a4;--text:#1a1814;--muted:#6a6658;--muted2:#403d33;--accent:#d65a1f;--accent-soft:rgba(214,90,31,.12);--accent-2:#1a1814;--ink:#fffcf3}
[data-palette="midnight"]{--bg:#0b0e1a;--surface:#11142a;--surface-2:#161a35;--border:#1f243f;--border-2:#2a2f4d;--text:#e6e8f5;--muted:#7a80a3;--muted2:#52567a;--accent:#7c9eff;--accent-soft:rgba(124,158,255,.12);--accent-2:#b8d0ff;--ink:#0b0e1a}
[data-palette="sepia"]{--bg:#1a1612;--surface:#231e18;--surface-2:#2a241c;--border:#352d23;--border-2:#3f372c;--text:#ede4d3;--muted:#8a7e6b;--muted2:#5a4f3f;--accent:#d4a373;--accent-soft:rgba(212,163,115,.14);--accent-2:#e9c79b;--ink:#1a1612}
[data-palette="mono"]{--bg:#fafaf7;--surface:#ffffff;--surface-2:#f0eee8;--border:#d8d4c8;--border-2:#bab5a4;--text:#0a0a08;--muted:#6a6658;--muted2:#3a3830;--accent:#0a0a08;--accent-soft:rgba(10,10,8,.06);--accent-2:#3a3830;--ink:#fafaf7}

/* ===== TOKENS — densité ===== */
[data-density="compact"]{--gap-section:64px;--gap-block:32px;--pad-card:24px}
[data-density="comfy"]{--gap-section:104px;--gap-block:48px;--pad-card:36px}
[data-density="airy"]{--gap-section:160px;--gap-block:72px;--pad-card:56px}

/* ===== TOKENS — typo ===== */
[data-tone="editorial"]{--font-display:'Fraunces',serif;--font-body:'Inter',sans-serif;--font-mono:'JetBrains Mono',monospace;--display-weight:300;--display-italic:italic;--body-weight:400}
[data-tone="techbrut"]{--font-display:'Space Grotesk',sans-serif;--font-body:'Space Grotesk',sans-serif;--font-mono:'Geist Mono',monospace;--display-weight:500;--display-italic:normal;--body-weight:400}
[data-tone="institutional"]{--font-display:'Inter',sans-serif;--font-body:'Inter',sans-serif;--font-mono:'JetBrains Mono',monospace;--display-weight:600;--display-italic:normal;--body-weight:400}
[data-tone="warm"]{--font-display:'Instrument Serif',serif;--font-body:'Inter',sans-serif;--font-mono:'JetBrains Mono',monospace;--display-weight:400;--display-italic:italic;--body-weight:400}

/* ===== Background patterns ===== */
.bg-pattern{position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.6}
[data-bg="grid"] .bg-pattern{background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse at 50% 0%,#000 0%,transparent 70%)}
[data-bg="dots"] .bg-pattern{background-image:radial-gradient(var(--border-2) 1px,transparent 1.4px);background-size:28px 28px;opacity:.45}
[data-bg="lines"] .bg-pattern{background-image:linear-gradient(180deg,var(--border) 1px,transparent 1px);background-size:100% 80px;opacity:.4}
[data-bg="gradient"] .bg-pattern{background:radial-gradient(ellipse at 80% -10%,var(--accent-soft) 0%,transparent 55%),radial-gradient(ellipse at 20% 110%,var(--accent-soft) 0%,transparent 55%);opacity:1}
[data-bg="ascii"] .bg-pattern{background:none}
[data-bg="ascii"] .ascii-bg{position:fixed;inset:0;pointer-events:none;z-index:0;font-family:var(--font-mono);font-size:11px;line-height:14px;color:var(--border-2);white-space:pre;overflow:hidden;opacity:.35;padding:32px}
[data-bg="solid"] .bg-pattern,[data-bg="solid"] .ascii-bg{display:none}

/* ===== Card style variants ===== */
[data-cards="thin"] .card{background:transparent;border:1px solid var(--border)}
[data-cards="solid"] .card{background:var(--surface);border:1px solid var(--border)}
[data-cards="raised"] .card{background:var(--surface);border:1px solid var(--border);box-shadow:0 1px 0 var(--border-2),0 12px 32px -16px rgba(0,0,0,.4)}
[data-cards="naked"] .card{background:transparent;border:none;padding-left:0;padding-right:0}
[data-cards="naked"] .card + .card{border-top:1px solid var(--border);padding-top:var(--pad-card)}

/* ===== Layout primitives ===== */
.shell{position:relative;z-index:1;max-width:1240px;margin:0 auto;padding:0 40px}
@media(max-width:720px){.shell{padding:0 20px}}

/* ===== NAV ===== */
.nav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:24px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;font-weight:500;text-transform:uppercase}
.brand-mark{width:22px;height:22px;border-radius:50%;background:var(--accent);position:relative;overflow:hidden}
.brand-mark::after{content:"";position:absolute;inset:6px;border-radius:50%;background:var(--ink)}
.brand-name span{color:var(--accent)}
.nav-links{display:flex;gap:28px;font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.nav-links a:hover{color:var(--text)}
.nav-cta{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:10px 18px;background:var(--accent);color:var(--ink);border-radius:2px;font-weight:500;transition:transform .2s,background .2s}
.nav-cta:hover{transform:translateY(-1px)}
.nav-tail{display:flex;align-items:center;gap:14px}
.theme-toggle{display:inline-flex;align-items:center;gap:0;padding:3px;border:1px solid var(--border);border-radius:999px;background:var(--surface)}
.theme-toggle .tt-opt{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-radius:999px;cursor:pointer;background:transparent;border:none;transition:color .25s ease,background .3s ease,box-shadow .3s ease;white-space:nowrap}
.theme-toggle .tt-opt:hover{color:var(--text)}
.theme-toggle .tt-opt.active{background:var(--accent);color:var(--ink);box-shadow:0 1px 0 var(--border-2)}
.theme-toggle .tt-opt svg{display:block;flex-shrink:0}
@media(max-width:720px){.theme-toggle .tt-opt span{display:none}.theme-toggle .tt-opt{padding:7px 10px}}
@media(max-width:720px){.nav-links{display:none}}

/* ===== Section primitives ===== */
.section{padding:var(--gap-section) 0}
.section + .section{border-top:1px solid var(--border)}
.eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:10px;margin-bottom:24px}
.eyebrow::before{content:"";width:24px;height:1px;background:currentColor}
.h1,.h2,.h3{font-family:var(--font-display);font-weight:var(--display-weight);letter-spacing:-0.02em;line-height:1.04;color:var(--text)}
.h1{font-size:clamp(48px,8vw,104px)}
.h2{font-size:clamp(36px,5vw,64px);line-height:1.05;letter-spacing:-0.025em}
.h3{font-size:clamp(22px,2.4vw,30px);line-height:1.2;letter-spacing:-0.015em}
.h1 em,.h2 em,.h3 em{font-style:var(--display-italic);color:var(--accent);font-weight:var(--display-weight)}
.h1 .out,.h2 .out{color:var(--muted);font-style:normal}
.lead{font-size:clamp(17px,1.6vw,20px);color:var(--muted2);max-width:60ch;line-height:1.6}
.kicker{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.tabular{font-variant-numeric:tabular-nums}

/* ===== HERO ===== */
.hero{padding:96px 0 var(--gap-section)}
[data-hero="split"] .hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:center}
[data-hero="centered"] .hero-grid{display:flex;flex-direction:column;align-items:center;text-align:center;gap:32px}
[data-hero="centered"] .hero-aside{display:none}
[data-hero="centered"] .lead{margin-left:auto;margin-right:auto}
[data-hero="centered"] .hero-actions{justify-content:center}
[data-hero="asymmetric"] .hero-grid{display:grid;grid-template-columns:1fr;gap:32px}
[data-hero="asymmetric"] .h1{font-size:clamp(56px,11vw,160px)}
[data-hero="asymmetric"] .hero-aside{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;border-top:1px solid var(--border);padding-top:32px;margin-top:24px}
[data-hero="fullbleed"] .hero{padding:0}
[data-hero="fullbleed"] .hero-grid{display:flex;flex-direction:column;justify-content:center;min-height:88vh;padding:120px 0 96px}
[data-hero="fullbleed"] .h1{font-size:clamp(64px,12vw,180px);max-width:14ch}
[data-hero="fullbleed"] .hero-aside{display:none}
@media(max-width:900px){[data-hero="split"] .hero-grid{grid-template-columns:1fr;gap:48px}}

.hero-actions{display:flex;gap:24px;align-items:center;margin-top:36px;flex-wrap:wrap}
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--accent);color:var(--ink);font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:18px 32px;border-radius:2px;transition:transform .2s}
.btn-primary:hover{transform:translateY(-2px)}
.btn-ghost{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--muted);border-bottom:1px solid var(--border);padding-bottom:4px;transition:color .2s,border-color .2s}
.btn-ghost:hover{color:var(--text);border-color:var(--text)}

/* Hero aside — mini KPIs */
.hero-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.hero-meta > div{background:var(--bg);padding:36px 28px;display:flex;flex-direction:column;justify-content:flex-end;min-height:140px}
.hero-meta-num{font-family:var(--font-display);font-size:clamp(48px,5vw,72px);font-weight:var(--display-weight);color:var(--accent);line-height:1;margin-bottom:10px;font-style:var(--display-italic);letter-spacing:-.02em}
.hero-meta-lbl{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

/* Hero portrait card */
.hero-portrait{aspect-ratio:4/5;background:var(--surface);border:1px solid var(--border);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:24px}
.hero-portrait::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,var(--surface-2) 0 12px,transparent 12px 24px);opacity:.5}
.hero-portrait-tag{position:absolute;top:16px;left:16px;font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);background:var(--bg);padding:6px 10px;border:1px solid var(--border)}
.hero-portrait-meta{position:relative;z-index:1}
.hero-portrait-meta div:first-child{font-family:var(--font-display);font-style:var(--display-italic);font-size:24px;color:var(--text);margin-bottom:6px}
.hero-portrait-meta div:last-child{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase}

/* ===== Marquee ===== */
.marquee{padding:32px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden}
.marquee-track{display:flex;gap:64px;white-space:nowrap;animation:marquee 38s linear infinite;font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
[data-anim="off"] .marquee-track{animation:none}
[data-anim="theatrical"] .marquee-track{animation-duration:24s}
.marquee-item{display:flex;align-items:center;gap:14px}
.marquee-item::before{content:"●";color:var(--accent);font-size:8px}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== Method (3 steps editorial) ===== */
.method-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-top:var(--gap-block)}
.method-grid > .reveal{display:flex;height:100%}
.method-grid > .reveal > .method-step{flex:1}
.method-step{background:var(--bg);padding:var(--pad-card);position:relative;display:flex;flex-direction:column;gap:16px;min-height:280px;height:100%;overflow:hidden;transition:background .35s ease,transform .35s cubic-bezier(.2,.7,.2,1)}
.method-step::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);transform:scaleX(0);transform-origin:50% 50%;transition:transform .5s ease}
.method-step::after{content:"";position:absolute;inset:auto auto -40% -20%;width:140%;height:80%;background:radial-gradient(ellipse at 30% 60%,var(--accent-soft) 0%,transparent 60%);opacity:0;transition:opacity .45s ease;pointer-events:none}
.method-step:hover{background:var(--surface);transform:translateY(-4px)}
.method-step:hover::before{transform:scaleX(1)}
.method-step:hover::after{opacity:1}
.method-step:hover .method-step-num{transform:translateX(6px);opacity:1;color:var(--accent)}
.method-step:hover .method-step-tag{color:var(--accent);border-top-color:var(--accent)}
.method-step:hover .method-step-tag .arrow{transform:translateX(4px);opacity:1}
.method-step > *{position:relative;z-index:1}
.method-step-num{font-family:var(--font-display);font-style:var(--display-italic);font-size:80px;font-weight:var(--display-weight);line-height:.9;color:var(--accent);opacity:.9;transition:transform .4s cubic-bezier(.2,.7,.2,1),color .35s ease,opacity .35s ease}
.method-step h3{font-family:var(--font-display);font-style:var(--display-italic);font-size:24px;font-weight:var(--display-weight);line-height:1.2}
.method-step p{font-size:15px;color:var(--muted2);line-height:1.65}
.method-step-tag{margin-top:auto;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding-top:16px;border-top:1px dashed var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;transition:color .3s ease,border-top-color .3s ease}
.method-step-tag .arrow{opacity:0;transition:transform .35s ease,opacity .3s ease;color:var(--accent)}
[data-anim="off"] .method-step,[data-anim="off"] .method-step *{transition:none!important}
[data-anim="off"] .method-step:hover{transform:none}
[data-anim="theatrical"] .method-step{transition-duration:.55s}
[data-anim="theatrical"] .method-step:hover{transform:translateY(-8px)}
@media(max-width:760px){.method-grid{grid-template-columns:1fr}}

/* ===== Use cases (avant/après) ===== */
.uc-wrap .reveal{transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1)}
/* Apparition : avant glisse depuis la gauche, après depuis la droite */
.usecase .uc-side.before{transform:translateX(-24px);opacity:0;transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1), background .35s ease, padding-left .45s cubic-bezier(.2,.7,.2,1)}
.usecase .uc-side.after{transform:translateX(24px);opacity:0;transition:opacity .7s ease .12s, transform .7s cubic-bezier(.2,.7,.2,1) .12s, background .35s ease}
.uc-wrap .reveal.in .uc-side.before,
.uc-wrap .reveal.in .uc-side.after{transform:translateX(0);opacity:1}
[data-anim="off"] .usecase .uc-side.before,
[data-anim="off"] .usecase .uc-side.after{transform:none;opacity:1;transition:background .35s ease}
.usecase{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:1px;transition:border-color .35s ease, box-shadow .35s ease, transform .35s ease;position:relative}
.usecase:hover{border-color:var(--accent);box-shadow:0 18px 50px -28px rgba(0,0,0,.55);transform:translateY(-2px);z-index:2}
.uc-side{background:var(--bg);padding:var(--pad-card);transition:background .35s ease, padding-left .45s cubic-bezier(.2,.7,.2,1)}
.uc-side.before{background:var(--bg)}
.uc-side.after{background:var(--surface);position:relative;overflow:hidden}
.uc-side.after::after{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg, color-mix(in oklab, var(--accent) 14%, transparent), transparent);transition:width .55s cubic-bezier(.2,.7,.2,1);pointer-events:none}
.usecase:hover .uc-side.after::after{width:100%}
.usecase:hover .uc-side.before{background:color-mix(in oklab, var(--bg) 92%, var(--muted) 8%)}
.usecase:hover .uc-title{transform:translateX(2px)}
.uc-title{transition:transform .35s ease}
.usecase:hover .uc-side li{transform:translateX(2px)}
.uc-side li{transition:transform .35s ease}
.uc-tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;margin-bottom:14px}
.uc-tag.before{color:var(--muted)}
.uc-tag.after{color:var(--accent)}
.uc-tag::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.uc-title{font-family:var(--font-display);font-style:var(--display-italic);font-size:22px;font-weight:var(--display-weight);margin-bottom:10px;line-height:1.25}
.uc-side ul{list-style:none;display:flex;flex-direction:column;gap:6px;margin-top:14px}
.uc-side li{font-size:14px;color:var(--muted2);padding-left:18px;position:relative;line-height:1.55}
.uc-side.before li::before{content:"–";position:absolute;left:0;color:var(--muted)}
.uc-side.after li::before{content:"+";position:absolute;left:0;color:var(--accent);font-weight:600}
.uc-metric{margin-top:18px;padding-top:14px;border-top:1px solid var(--border);display:flex;align-items:baseline;gap:10px}
.uc-metric-num{font-family:var(--font-display);font-style:var(--display-italic);font-size:36px;font-weight:var(--display-weight);color:var(--accent);line-height:1}
.uc-metric-lbl{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.uc-header{display:flex;align-items:baseline;justify-content:space-between;gap:20px;margin-bottom:14px;padding:24px var(--pad-card) 0}
.uc-sector{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
.uc-name{font-family:var(--font-display);font-style:var(--display-italic);font-size:18px;color:var(--text)}
.uc-wrap{margin-top:var(--gap-block)}
@media(max-width:760px){.usecase{grid-template-columns:1fr}}

/* ===== Metrics ===== */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:var(--gap-block);border-top:1px solid var(--border);border-bottom:1px solid var(--border);transition:gap .35s ease;align-items:stretch}
.metrics > .reveal{display:flex;height:100%}
.metric{padding:36px 28px;border-right:1px solid var(--border);transition:background .3s ease, transform .3s ease;position:relative;display:flex;flex-direction:column;width:100%}
.metric:last-child{border-right:none}
.metric:hover{background:var(--surface)}
.metric-num{font-family:var(--font-display);font-style:var(--display-italic);font-size:clamp(42px,5vw,64px);font-weight:var(--display-weight);color:var(--accent);line-height:1;margin-bottom:8px;letter-spacing:-.02em}
.metric-lbl{display:inline-flex;align-self:flex-start;align-items:center;font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text);margin-bottom:14px;padding:5px 9px 5px 10px;border:1px solid var(--border);border-radius:2px;background:var(--surface);position:relative}
.metric-lbl::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);margin-right:8px;flex-shrink:0}
.metric-note{font-size:13px;color:var(--muted2);line-height:1.5}
@media(max-width:900px){.metrics{grid-template-columns:repeat(2,1fr)}.metric:nth-child(2){border-right:none}.metric:nth-child(1),.metric:nth-child(2){border-bottom:1px solid var(--border)}}
@media(max-width:520px){.metrics{grid-template-columns:1fr}.metric{border-right:none;border-bottom:1px solid var(--border)}.metric:last-child{border-bottom:none}}

/* --- Metrics variant: tiles (cards w/ gap + hover lift + accent line) --- */
[data-metrics="tiles"] .metrics{gap:1px;background:var(--border)}
[data-metrics="tiles"] .metric{background:var(--bg);border-right:none;padding:clamp(28px,3vw,40px)}
[data-metrics="tiles"] .metric:hover{background:var(--surface);transform:translateY(-3px);z-index:2;box-shadow:0 18px 40px -22px rgba(0,0,0,.5)}
[data-metrics="tiles"] .metric::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:0 0;transition:transform .4s cubic-bezier(.2,.7,.2,1)}
[data-metrics="tiles"] .metric:hover::before{transform:scaleX(1)}

/* --- Metrics variant: numbered (counter prefix, smaller display num) --- */
[data-metrics="numbered"] .metrics{counter-reset:metric-counter}
[data-metrics="numbered"] .metric{padding:clamp(32px,3.5vw,52px) clamp(24px,2.5vw,36px)}
[data-metrics="numbered"] .metric .metric-num{font-size:clamp(22px,2.2vw,30px);color:var(--text);display:flex;align-items:baseline;gap:14px}
[data-metrics="numbered"] .metric .metric-num::before{content:counter(metric-counter, decimal-leading-zero);counter-increment:metric-counter;font-family:var(--font-mono);font-style:normal;font-size:11px;letter-spacing:.16em;color:var(--accent);font-weight:500}
[data-metrics="numbered"] .metric-lbl{font-size:11px;letter-spacing:.14em;color:var(--accent);margin-top:18px;margin-bottom:10px;background:transparent;border-color:var(--accent);color:var(--accent)}
[data-metrics="numbered"] .metric-lbl::before{background:var(--accent)}
[data-metrics="numbered"] .metric-note{font-size:13.5px;line-height:1.6}

/* --- Metrics variant: stacked (vertical, editorial long-form rows) --- */
[data-metrics="stacked"] .metrics{display:flex;flex-direction:column;border:none;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
[data-metrics="stacked"] .metrics > .reveal{display:block;height:auto}
[data-metrics="stacked"] .metric{display:grid;grid-template-columns:minmax(120px,160px) minmax(180px,220px) 1fr;gap:clamp(20px,3vw,48px);align-items:baseline;border-right:none;border-bottom:1px solid var(--border);padding:clamp(28px,3vw,40px) clamp(8px,2vw,24px)}
[data-metrics="stacked"] .metric:last-child{border-bottom:none}
[data-metrics="stacked"] .metric:hover{background:transparent}
[data-metrics="stacked"] .metric .metric-num{font-size:clamp(48px,5vw,72px);margin-bottom:0}
[data-metrics="stacked"] .metric .metric-lbl{margin-bottom:0;font-size:12px;letter-spacing:.16em;color:var(--text)}
[data-metrics="stacked"] .metric .metric-note{font-size:15px;line-height:1.6;color:var(--muted2);max-width:55ch}
@media(max-width:760px){[data-metrics="stacked"] .metric{grid-template-columns:1fr;gap:8px}}

/* --- Metrics variant: minimal (no borders, oversized type, editorial) --- */
[data-metrics="minimal"] .metrics{border:none;display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(28px,4vw,56px)}
[data-metrics="minimal"] .metric{border:none;padding:0;background:transparent}
[data-metrics="minimal"] .metric:hover{background:transparent;transform:translateY(-2px)}
[data-metrics="minimal"] .metric .metric-num{font-size:clamp(56px,6.5vw,96px);color:var(--accent);margin-bottom:14px}
[data-metrics="minimal"] .metric .metric-lbl{font-size:12px;letter-spacing:.16em;color:var(--text);margin-bottom:8px}
[data-metrics="minimal"] .metric .metric-note{font-size:13px;line-height:1.55;color:var(--muted)}
@media(max-width:900px){[data-metrics="minimal"] .metrics{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){[data-metrics="minimal"] .metrics{grid-template-columns:1fr}}

/* ===== Pricing / Packages ===== */
.pricing{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-top:var(--gap-block);align-items:stretch}
.pricing > *{display:flex;height:100%}
.price{padding:var(--pad-card);background:var(--bg);display:flex;flex-direction:column;gap:18px;position:relative;width:100%;height:100%;transition:background .25s ease, transform .25s ease, box-shadow .25s ease;cursor:default}
.price:hover{background:var(--surface);transform:translateY(-3px);box-shadow:0 12px 40px -16px rgba(0,0,0,.5);z-index:2}
.price:hover .price-cta{border-color:var(--accent);color:var(--accent)}
.price.featured{background:var(--surface)}
.price.featured:hover{background:var(--surface)}
.price.featured::before{content:"Recommandé";position:absolute;top:-1px;right:-1px;background:var(--accent);color:var(--ink);font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;padding:5px 12px;font-weight:500;z-index:3}
.price-name{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.price.featured .price-name{color:var(--accent)}
.price-amount{font-family:var(--font-display);font-style:var(--display-italic);font-size:42px;font-weight:var(--display-weight);line-height:1;color:var(--text);letter-spacing:-0.02em}
.price-amount span{font-family:var(--font-mono);font-style:normal;font-size:14px;color:var(--muted);letter-spacing:.06em;display:block;margin-top:8px}
.price-pitch{font-size:14px;color:var(--muted2);line-height:1.6;padding-bottom:16px;border-bottom:1px solid var(--border)}
.price ul{list-style:none;display:flex;flex-direction:column;gap:10px;flex:1}
.price li{font-size:13.5px;color:var(--text);padding-left:22px;position:relative;line-height:1.5}
.price li::before{content:"→";position:absolute;left:0;color:var(--accent);font-family:var(--font-mono)}
.price-cta{margin-top:16px;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:14px 20px;border:1px solid var(--border);text-align:center;transition:all .2s}
.price-cta:hover{border-color:var(--accent);color:var(--accent)}
.price.featured .price-cta{background:var(--accent);color:var(--ink);border-color:var(--accent)}
@media(max-width:1100px){.pricing{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.pricing{grid-template-columns:1fr}}

/* ===== Differentiation table ===== */
.diff-table{margin-top:var(--gap-block);border:1px solid var(--border)}
.diff-row{display:grid;grid-template-columns:1.1fr 1fr 1fr;border-bottom:1px solid var(--border)}
.diff-row:last-child{border-bottom:none}
.diff-row.head{background:var(--surface)}
.diff-cell{padding:18px 22px;font-size:14.5px;line-height:1.55;border-right:1px solid var(--border)}
.diff-cell:last-child{border-right:none}
.diff-row.head .diff-cell{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:14px 22px}
.diff-row.head .diff-cell.us{color:var(--accent)}
.diff-cell.us{background:var(--accent-soft)}
.diff-cell.label{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}
.diff-cell .neg{color:var(--muted);text-decoration:line-through;text-decoration-color:var(--border-2);text-decoration-thickness:1px}
@media(max-width:760px){.diff-row{grid-template-columns:1fr}.diff-cell{border-right:none;border-bottom:1px solid var(--border)}.diff-cell:last-child{border-bottom:none}}

/* ===== Quote ===== */
.quote{padding:var(--gap-block) 0}
.quote blockquote{font-family:var(--font-display);font-style:var(--display-italic);font-weight:var(--display-weight);font-size:clamp(28px,3.6vw,46px);line-height:1.2;letter-spacing:-.015em;max-width:24ch;color:var(--text)}
.quote blockquote::before{content:"« ";color:var(--accent)}
.quote blockquote::after{content:" »";color:var(--accent)}
.quote cite{display:block;margin-top:24px;font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-style:normal}
.quote cite span{color:var(--accent)}

/* ===== FAQ ===== */
.faq-list{margin-top:var(--gap-block);border-top:1px solid var(--border)}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;text-align:left;display:flex;justify-content:space-between;align-items:center;padding:24px 0;font-family:var(--font-display);font-style:var(--display-italic);font-weight:var(--display-weight);font-size:clamp(18px,2vw,24px);color:var(--text);transition:color .2s}
.faq-q:hover{color:var(--accent)}
.faq-toggle{font-family:var(--font-mono);font-size:14px;color:var(--accent);transition:transform .3s}
.faq-item.open .faq-toggle{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-item.open .faq-a{max-height:300px}
.faq-a-inner{padding:0 0 24px;font-size:15px;color:var(--muted2);line-height:1.7;max-width:60ch}

/* ===== CTA bottom ===== */
.cta-band{padding:var(--gap-section) 0;border-top:1px solid var(--border);position:relative;overflow:hidden}
.cta-inner{display:grid;grid-template-columns:1.4fr auto;gap:40px;align-items:center}
@media(max-width:760px){.cta-inner{grid-template-columns:1fr}}
.cta-h{font-family:var(--font-display);font-weight:var(--display-weight);font-size:clamp(32px,4vw,52px);line-height:1.1;letter-spacing:-.02em}
.cta-h em{font-style:var(--display-italic);color:var(--accent)}
.cta-sub{font-size:15px;color:var(--muted2);margin-top:12px;max-width:48ch}
.cta-meta{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:14px;text-align:center}

/* ===== Footer ===== */
footer{border-top:1px solid var(--border);padding:32px 0;font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;color:var(--muted)}
.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.footer-inner a:hover{color:var(--accent)}

/* ===== Reveal anim ===== */
[data-anim="off"] .reveal{opacity:1;transform:none}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:translateY(0)}
[data-anim="theatrical"] .reveal{transform:translateY(48px) scale(.97)}
[data-anim="theatrical"] .reveal.in{transform:translateY(0) scale(1)}

/* ===== Promise Band (résultat de l'accompagnement) ===== */
.promise-band{padding:clamp(80px,9vw,140px) 0;background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.promise-band::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 80% at 50% 0%, color-mix(in oklab, var(--accent) 8%, transparent), transparent 70%);pointer-events:none}
.promise-tag{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:24px;display:inline-flex;align-items:center;gap:10px}
.promise-tag::before{content:"";width:32px;height:1px;background:var(--accent)}
.promise-title{font-family:var(--font-display);font-style:var(--display-italic);font-weight:var(--display-weight);font-size:clamp(36px,4.4vw,64px);line-height:1.05;letter-spacing:-0.02em;color:var(--text);margin-bottom:clamp(48px,5vw,72px);max-width:18ch}
.promise-title em{color:var(--accent);font-style:var(--display-italic)}
.promise-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.promise-grid > .reveal{display:flex;height:100%}
.promise-card{background:var(--bg);padding:clamp(28px,3vw,44px);display:flex;flex-direction:column;gap:18px;width:100%;height:100%;position:relative;transition:background .35s ease, transform .35s ease}
.promise-card:hover{background:var(--surface);transform:translateY(-3px)}
.promise-sign{font-family:var(--font-mono);font-size:14px;letter-spacing:.06em;color:var(--accent);width:44px;height:44px;border:1px solid var(--accent);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:600}
.promise-headline{display:flex;flex-direction:column;gap:4px;font-family:var(--font-display);font-style:var(--display-italic);font-weight:var(--display-weight);line-height:1.05;letter-spacing:-0.015em}
.promise-verb{font-size:clamp(32px,3.4vw,48px);color:var(--text)}
.promise-object{font-size:clamp(24px,2.4vw,34px);color:var(--accent)}
.promise-sub{font-size:15px;line-height:1.6;color:var(--muted2);margin-top:8px}
@media(max-width:900px){.promise-grid{grid-template-columns:1fr}}

/* --- Variant: slim band --- */
.promise-slim{padding:clamp(40px,4.5vw,64px) 0;background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.promise-slim-grid{display:grid;grid-template-columns:auto repeat(3,1fr);gap:clamp(20px,3vw,48px);align-items:center}
.promise-slim-tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);max-width:11ch;line-height:1.5;padding-right:clamp(12px,2vw,24px);border-right:1px solid var(--border)}
.promise-slim-item{display:flex;align-items:center;gap:14px}
.promise-slim-sign{font-family:var(--font-mono);font-size:12px;color:var(--accent);width:36px;height:36px;border:1px solid var(--accent);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}
.promise-slim-headline{display:flex;flex-direction:column;gap:2px;font-family:var(--font-display);font-style:var(--display-italic);font-weight:var(--display-weight);line-height:1.05}
.promise-slim-verb{font-size:clamp(20px,2vw,28px);color:var(--text)}
.promise-slim-obj{font-size:clamp(14px,1.3vw,17px);color:var(--accent)}
@media(max-width:900px){.promise-slim-grid{grid-template-columns:1fr;gap:18px}.promise-slim-tag{border-right:none;border-bottom:1px solid var(--border);padding-right:0;padding-bottom:14px;max-width:none}}

/* --- Variant: top bar (above nav) --- */
.promise-topbar{background:var(--accent);color:var(--ink);border-bottom:1px solid var(--border);overflow:hidden}
.promise-topbar-inner{display:flex;align-items:center;gap:clamp(20px,3vw,40px);padding:14px 0;flex-wrap:wrap}
.promise-topbar-tag{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;flex-shrink:0;padding-right:clamp(16px,2.5vw,28px);border-right:1px solid color-mix(in oklab, var(--ink) 25%, transparent)}
.promise-topbar-items{display:flex;align-items:center;gap:clamp(20px,3vw,40px);flex:1;flex-wrap:wrap}
.promise-topbar-item{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-style:var(--display-italic);font-weight:var(--display-weight);font-size:clamp(16px,1.5vw,20px);line-height:1}
.promise-topbar-sign{font-family:var(--font-mono);font-size:11px;font-style:normal;width:24px;height:24px;border:1px solid color-mix(in oklab, var(--ink) 60%, transparent);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:600}
.promise-topbar-verb{}
.promise-topbar-obj{opacity:.75;font-size:.85em}
@media(max-width:760px){.promise-topbar-tag{border-right:none;width:100%;padding-right:0}.promise-topbar-items{gap:14px}}

/* --- Variant: hero aside replaces stats --- */
.hero-promise-aside{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);background:var(--surface);position:relative;overflow:hidden}
.hero-promise-aside::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 60% at 100% 0%, color-mix(in oklab, var(--accent) 14%, transparent), transparent 65%);pointer-events:none}
.hero-promise-tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);padding:18px 22px 6px;position:relative;z-index:1}
.hero-promise-item{display:flex;align-items:center;gap:16px;padding:20px 22px;border-top:1px solid var(--border);position:relative;z-index:1;transition:background .25s ease}
.hero-promise-item:hover{background:color-mix(in oklab, var(--accent) 6%, var(--surface))}
.hero-promise-item:first-of-type{border-top:1px solid var(--border)}
.hero-promise-sign{font-family:var(--font-mono);font-size:13px;color:var(--accent);width:38px;height:38px;border:1px solid var(--accent);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}
.hero-promise-text{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}
.hero-promise-headline{display:flex;flex-direction:column;gap:2px;font-family:var(--font-display);font-style:var(--display-italic);font-weight:var(--display-weight);line-height:1.05;letter-spacing:-0.015em}
.hero-promise-verb{font-size:24px;color:var(--text)}
.hero-promise-obj{font-size:15px;color:var(--accent)}
.hero-promise-desc{font-size:12.5px;line-height:1.5;color:var(--muted2);margin-top:4px;text-wrap:pretty}

/* ===== Inline meta strip on hero (replaces emoji pills) ===== */
.hero-strip{display:flex;flex-wrap:wrap;gap:8px 20px;margin-bottom:32px;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);align-items:center}
.hero-strip span{display:inline-flex;align-items:center;gap:8px}
.hero-strip span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);display:inline-block}
.hero-strip .sep{width:1px;height:11px;background:var(--border-2)}
.hero-strip .sep::before{display:none}

/* ===== Process visual (replaces neural SVG) — minimal trace ===== */
.trace{position:relative;height:280px;border:1px solid var(--border);background:var(--surface);overflow:hidden}
.trace-grid{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:24px 24px;opacity:.5}
.trace-node{position:absolute;width:14px;height:14px;border-radius:50%;background:var(--accent);transform:translate(-50%,-50%);box-shadow:0 0 0 4px var(--accent-soft)}
.trace-line{position:absolute;height:1px;background:var(--accent);transform-origin:0 50%;opacity:.7}
.trace-label{position:absolute;font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);transform:translate(-50%,12px);white-space:nowrap}
.trace-label.top{transform:translate(-50%,-22px)}

/* tweak panel root z-index high */
#tweaks-root{position:fixed;z-index:99}

/* ===== Vision teaser (landing) ===== */
.vision-teaser{position:relative}
.vision-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(40px,5vw,80px);align-items:center}
@media(max-width:980px){.vision-grid{grid-template-columns:1fr;gap:48px}}
.vision-compare{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:stretch}
@media(max-width:680px){.vision-compare{grid-template-columns:1fr;gap:14px}.vision-compare .vc-arrow{transform:rotate(90deg);justify-self:center}}
.vc-card{padding:22px 22px 20px;border:1px solid var(--border);border-radius:6px;background:var(--surface);display:flex;flex-direction:column;gap:14px;position:relative;overflow:hidden}
.vc-after{border-color:color-mix(in srgb,var(--accent) 45%,var(--border));box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 20%,transparent),0 18px 40px -22px rgba(0,0,0,.35)}
.vc-tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:8px}
.vc-after .vc-tag{color:var(--accent)}
.vc-tag::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.vc-arrow{display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:24px;color:var(--muted);padding:0 4px}
.vc-diagram{display:flex;flex-direction:column;gap:6px;flex:1;justify-content:center}
.vc-diagram.pyramid .lvl{display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--text);height:28px;border:1px solid var(--border);border-radius:2px;background:var(--bg)}
.vc-diagram.pyramid .lvl.l1{width:38%;align-self:center}
.vc-diagram.pyramid .lvl.l2{width:58%;align-self:center}
.vc-diagram.pyramid .lvl.l3{width:78%;align-self:center}
.vc-diagram.pyramid .lvl.l4{width:100%}
.vc-diagram.flow .flow-row{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:9.5px;letter-spacing:.04em;text-transform:uppercase}
.vc-diagram.flow .flow-row .ev{padding:5px 8px;border:1px solid var(--border);border-radius:2px;background:var(--bg);color:var(--muted);white-space:nowrap}
.vc-diagram.flow .flow-row .ag{padding:5px 8px;border:1px solid var(--accent);border-radius:2px;background:color-mix(in srgb,var(--accent) 12%,var(--bg));color:var(--text);white-space:nowrap;flex:1;text-align:center}
.vc-diagram.flow .flow-row .line{flex-shrink:0;width:14px;height:1px;background:var(--accent);opacity:.5}
.vc-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;border-top:1px solid var(--border);padding-top:14px;margin-top:auto}
.vc-stats > div{display:flex;flex-direction:column;gap:2px}
.vc-stats strong{font-family:var(--font-display);font-style:var(--display-italic);font-size:22px;font-weight:var(--display-weight);color:var(--accent);line-height:1;letter-spacing:-.01em}
.vc-stats span{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}


/* ===== Vision page ===== */
.section-alt{background:var(--surface);position:relative}
.section-alt::before,.section-alt::after{content:"";position:absolute;left:0;right:0;height:1px;background:var(--border)}
.section-alt::before{top:0}
.section-alt::after{bottom:0}

.paradigme-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,40px)}
@media(max-width:980px){.paradigme-grid{grid-template-columns:1fr}}
.paradigme-card{padding:clamp(28px,3vw,40px);border:1px solid var(--border);border-radius:6px;background:var(--bg);display:flex;flex-direction:column;gap:24px;position:relative;overflow:hidden}
.paradigme-card.pc-after{border-color:color-mix(in srgb,var(--accent) 50%,var(--border));box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 20%,transparent),0 24px 60px -28px rgba(0,0,0,.4)}
.paradigme-card .pc-tag{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:8px}
.paradigme-card .pc-tag::before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor}
.paradigme-card.pc-after .pc-tag{color:var(--accent)}
.pc-note{font-size:14px;line-height:1.65;color:var(--muted2)}
.pc-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;border-top:1px solid var(--border);padding-top:20px;margin-top:auto}
.pc-stats > div{display:flex;flex-direction:column;gap:4px}
.pc-stats strong{font-family:var(--font-display);font-style:var(--display-italic);font-size:clamp(24px,2.4vw,32px);font-weight:var(--display-weight);color:var(--accent);line-height:1;letter-spacing:-.01em}
.pc-stats span{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

.pyramid-stack{display:flex;flex-direction:column;gap:8px;align-items:center;padding:14px 0}
.pyramid-stack .pl{display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--text);height:36px;border:1px solid var(--border);border-radius:2px;background:var(--surface)}
.pyramid-stack .pl-1{width:30%}
.pyramid-stack .pl-2{width:50%}
.pyramid-stack .pl-3{width:75%}
.pyramid-stack .pl-4{width:100%}

.flow-stack{display:flex;flex-direction:column;gap:12px}
.fr{display:grid;grid-template-columns:auto auto 1fr 1fr auto;align-items:center;gap:8px;font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;padding:10px 12px;border:1px solid var(--border);border-radius:3px;background:var(--surface)}
@media(max-width:680px){.fr{grid-template-columns:1fr;gap:6px}}
.fr-ev{padding:5px 9px;border:1px solid var(--border);border-radius:2px;background:var(--bg);color:var(--muted);white-space:nowrap;justify-self:start}
.fr-arr{color:var(--accent);font-size:14px;justify-self:center;font-weight:bold}
.fr-ag{padding:5px 9px;border:1px solid var(--accent);border-radius:2px;background:color-mix(in srgb,var(--accent) 14%,var(--bg));color:var(--text);white-space:nowrap;text-align:center}
.fr-out{padding:5px 9px;color:var(--accent);font-style:italic;text-transform:none;letter-spacing:.02em;font-size:11px;justify-self:end;white-space:nowrap}

.vision-pull{margin-top:80px;padding:36px 40px;border-left:3px solid var(--accent);background:transparent;font-family:var(--font-display);font-style:var(--display-italic);font-size:clamp(20px,2.2vw,28px);font-weight:var(--display-weight);line-height:1.4;color:var(--text);max-width:880px}
.vision-pull cite{display:block;margin-top:18px;font-family:var(--font-mono);font-style:normal;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:500}

.change-list{display:flex;flex-direction:column;gap:0}
.change-row{display:grid;grid-template-columns:1fr auto 1fr;gap:clamp(20px,3vw,48px);align-items:start;padding:clamp(28px,3vw,40px) 0;border-bottom:1px solid var(--border)}
.change-list .reveal:last-child .change-row{border-bottom:none}
@media(max-width:760px){.change-row{grid-template-columns:1fr;gap:18px}.change-arrow{transform:rotate(90deg);justify-self:start}}
.change-side{display:flex;flex-direction:column;gap:10px}
.change-tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:6px;align-self:flex-start;padding:4px 9px;border:1px solid var(--border);border-radius:2px;background:var(--surface)}
.change-after .change-tag{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 50%,var(--border))}
.change-title{font-family:var(--font-display);font-style:var(--display-italic);font-size:clamp(20px,2vw,26px);font-weight:var(--display-weight);line-height:1.25;color:var(--text);letter-spacing:-.01em}
.change-after .change-title{color:var(--accent)}
.change-body{font-size:14px;line-height:1.65;color:var(--muted2)}
.change-arrow{font-family:var(--font-mono);font-size:24px;color:var(--accent);align-self:center;font-weight:bold}

.sector-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-top:40px;border-bottom:1px solid var(--border);padding-bottom:0}
.sector-tab{padding:14px 22px;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .25s,border-color .25s;margin-bottom:-1px}
.sector-tab:hover{color:var(--text)}
.sector-tab.active{color:var(--text);border-bottom-color:var(--accent)}
.sector-panels{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,32px);margin-top:40px}
@media(max-width:880px){.sector-panels{grid-template-columns:1fr}}
.sector-card{padding:28px 28px 24px;border:1px solid var(--border);border-radius:6px;background:var(--bg);display:flex;flex-direction:column;gap:20px;height:100%}
.sector-card-title{font-family:var(--font-display);font-style:var(--display-italic);font-size:22px;font-weight:var(--display-weight);line-height:1.2;color:var(--text);letter-spacing:-.01em}
.sector-flow{display:flex;flex-direction:column;gap:14px;list-style:none;padding:0;margin:0}
.sf-line{display:grid;grid-template-columns:28px 1fr;gap:14px;align-items:start}
.sf-icon{font-size:14px;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);flex-shrink:0}
.sf-auto .sf-icon{background:color-mix(in srgb,var(--accent) 14%,var(--surface));border-color:color-mix(in srgb,var(--accent) 40%,var(--border));color:var(--accent)}
.sf-text{display:flex;flex-direction:column;gap:3px}
.sf-main{font-size:13.5px;font-weight:500;color:var(--text);line-height:1.45}
.sf-sub{font-size:12.5px;color:var(--muted2);line-height:1.55}
.sector-gain{margin-top:auto;padding-top:18px;border-top:1px solid var(--border);font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);font-weight:500}

.byoa-layout{display:grid;grid-template-columns:auto 1fr;gap:clamp(28px,4vw,56px);align-items:center}
@media(max-width:880px){.byoa-layout{grid-template-columns:1fr}}
.byoa-human{display:flex;flex-direction:column;align-items:center;gap:10px;padding:28px;border:1px solid var(--border);border-radius:6px;background:var(--bg);min-width:200px}
.byoa-head{font-size:48px;line-height:1}
.byoa-label{font-family:var(--font-display);font-style:var(--display-italic);font-size:20px;font-weight:var(--display-weight);color:var(--text)}
.byoa-sub{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-align:center}
.byoa-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media(max-width:760px){.byoa-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.byoa-grid{grid-template-columns:1fr}}
.byoa-card{padding:18px 18px 16px;border:1px solid var(--border);border-radius:4px;background:var(--bg);display:flex;flex-direction:column;gap:6px;transition:border-color .25s,transform .25s}
.byoa-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.byoa-card-name{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:500}
.byoa-card-role{font-size:13px;line-height:1.45;color:var(--text)}
.byoa-card-state{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;color:var(--muted);margin-top:4px;padding-top:8px;border-top:1px dashed var(--border)}

/* ===== RDV page ===== */
.rdv-meta{display:flex;flex-wrap:wrap;gap:clamp(18px,3vw,36px);margin-top:36px;padding:20px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);max-width:680px}
.rdv-meta-item{display:flex;align-items:center;gap:12px}
.rmi-num{font-family:var(--font-display);font-style:var(--display-italic);font-size:32px;font-weight:var(--display-weight);color:var(--accent);line-height:1;display:flex;align-items:center}
.rmi-lbl{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

.rdv-cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:clamp(20px,3vw,40px);align-items:start}
@media(max-width:980px){.rdv-cols{grid-template-columns:1fr}}
.rdv-col{padding:clamp(24px,2.5vw,32px);border:1px solid var(--border);border-radius:6px;background:var(--bg)}
.rdv-col-no{background:var(--surface);border-style:dashed}
.rdv-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.rdv-list li{display:grid;grid-template-columns:24px 1fr;gap:12px;align-items:start;font-size:14px;line-height:1.6;color:var(--text)}
.rdv-list li strong{color:var(--text);font-weight:600}
.rdv-list-yes .rl-mark{color:var(--accent);font-family:var(--font-mono);font-weight:bold;font-size:14px;line-height:1.6}
.rdv-list-no .rl-mark{color:var(--muted);font-family:var(--font-mono);font-size:13px;line-height:1.6}
.rdv-list-no li{color:var(--muted2)}
.h3{font-family:var(--font-display);font-style:var(--display-italic);font-size:clamp(22px,2.4vw,30px);font-weight:var(--display-weight);line-height:1.2;color:var(--text);letter-spacing:-.01em}
