*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden;}

.wrap{max-width:var(--container);margin:0 auto;padding-inline:var(--pad);}
section{position:relative;}

/* ── Typography primitives ── */
.display{font-family:var(--serif);font-weight:400;letter-spacing:-.025em;line-height:.98;font-variation-settings:"opsz" 144;}
.display em{font-style:italic;font-weight:300;color:var(--violet);}
.eyebrow{font-family:var(--sans);font-size:.75rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);}
.lead{font-family:var(--sans);font-size:clamp(1.05rem,1.4vw,1.25rem);font-weight:400;color:var(--ink-soft);line-height:1.55;}
a{color:inherit;text-decoration:none;transition:color .2s var(--ease);}
button{font-family:inherit;cursor:pointer;}
ul{list-style:none;}

.kicker{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap;}
.kicker-line{width:34px;height:1px;background:var(--violet);flex-shrink:0;}
.kicker.on-dark .eyebrow{color:rgba(250,249,246,.65);}

/* private-section pill */
.private-tag{display:inline-flex;align-items:center;gap:.4rem;padding:.32rem .7rem .32rem .55rem;border-radius:999px;background:rgba(255,46,136,.09);border:1px solid rgba(255,46,136,.32);color:var(--magenta);font-family:var(--sans);font-size:.66rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;line-height:1;white-space:nowrap;}
.private-tag .pt-lock{width:11px;height:11px;flex-shrink:0;}
.kicker.on-dark .private-tag{background:rgba(255,46,136,.14);border-color:rgba(255,46,136,.45);color:var(--magenta-soft);}

/* ── Section frame (impeccable: roomy, hairline-led) ── */
.sec{padding:7rem 0;}
.sec-head{display:grid;grid-template-columns:1fr 2fr;gap:3rem;margin-bottom:4rem;align-items:end;}
.sec-head h2{font-family:var(--serif);font-size:clamp(2.25rem,4.5vw,3.5rem);font-weight:400;line-height:1.02;letter-spacing:-.02em;}
.sec-head h2 em{font-style:italic;color:var(--violet);}
.sec-head .lead{margin-top:1.25rem;max-width:46ch;}
@media(max-width:920px){.sec-head{grid-template-columns:1fr;gap:1.25rem;margin-bottom:3rem;}}

.soft{background:var(--cream-soft);}

/* ── Buttons ── */
.btn-primary{display:inline-flex;align-items:center;gap:.6rem;padding:1rem 1.5rem;background:var(--ink);color:var(--cream);border-radius:999px;font-weight:500;font-size:.95rem;transition:all .2s var(--ease);border:0;}
.btn-primary:hover{background:var(--violet);color:#fff;transform:translateY(-2px);box-shadow:0 12px 30px -10px rgba(110,17,240,.5);}
.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;border:1px solid var(--line-strong);background:transparent;color:var(--ink);border-radius:999px;font-weight:500;font-size:.95rem;transition:all .2s var(--ease);}
.btn-secondary:hover{border-color:var(--ink);}
.btn-light{display:inline-flex;align-items:center;gap:.6rem;padding:1rem 1.6rem;background:var(--cream);color:var(--ink);border-radius:999px;font-weight:500;font-size:.95rem;transition:all .2s var(--ease);border:0;}
.btn-light:hover{background:#fff;transform:translateY(-2px);}

/* ── Meta badge ── */
.meta-badge{position:fixed;bottom:24px;right:24px;z-index:300;background:var(--ink);border:1px solid rgba(110,17,240,.4);border-radius:14px;padding:16px 18px;max-width:250px;box-shadow:0 20px 50px -20px rgba(10,10,15,.5);transition:opacity .3s;}
.meta-top{display:flex;align-items:center;gap:8px;margin-bottom:9px;}
.meta-dot{width:7px;height:7px;border-radius:50%;background:var(--violet);animation:pulse 2s infinite;flex-shrink:0;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.meta-top span{font-family:var(--sans);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--violet-soft);font-weight:500;}
.meta-badge p{font-size:.78rem;line-height:1.6;color:rgba(250,249,246,.7);}
.meta-badge strong{color:#fff;font-weight:500;}
.meta-close{position:absolute;top:9px;right:11px;background:none;border:none;color:rgba(250,249,246,.4);cursor:pointer;font-size:15px;line-height:1;}
.meta-close:hover{color:#fff;}

/* ── NAV ── */
#nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:1.15rem var(--pad);display:flex;justify-content:space-between;align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:rgba(250,249,246,.82);border-bottom:1px solid var(--line);transition:padding .3s var(--ease);}
#nav.scrolled{padding-top:.8rem;padding-bottom:.8rem;}
.nav-brand{display:flex;align-items:center;gap:.85rem;margin-right:auto;}
.nav-logo{height:26px;width:auto;display:block;}
.nav-div{width:1px;height:20px;background:var(--line-strong);}
.nav-offer{display:inline-flex;align-items:center;gap:.5rem;}
.nav-mark{flex-shrink:0;display:block;}
.cr-dot{width:18px;height:18px;border-radius:50%;flex-shrink:0;display:block;}
.foot-offer .cr-dot{width:16px;height:16px;}
.nav-offer-name{font-family:var(--serif);font-size:1.05rem;color:var(--ink);line-height:1;white-space:nowrap;}
.nav-offer-name em{font-style:italic;color:var(--violet);}
.nav-links{display:flex;gap:1.9rem;font-size:.8rem;font-weight:500;letter-spacing:.04em;color:var(--muted);}
.nav-links a:hover{color:var(--ink);}
.nav-cta{padding:.6rem 1.15rem;background:var(--ink);color:var(--cream);border-radius:999px;font-size:.8rem;font-weight:500;line-height:1;transition:all .2s var(--ease);border:0;}
/* Focus clavier visible sur les contrôles du header (A11y) */
.nav-cta:focus-visible,.nav-login:focus-visible,.nav-user-btn:focus-visible,.nav-lang a:focus-visible,.nav-user-logout:focus-visible,.mobile-user-logout:focus-visible,.mobile-menu-login:focus-visible{outline:2px solid var(--violet);outline-offset:2px;}
.nav-cta:hover{background:var(--violet);transform:translateY(-1px);}
@media(max-width:860px){.nav-links{display:none;}}

/* ── FLOATING BREADCRUMB (TOC) — collapsed rail, expands on hover ── */
.toc{position:fixed;top:50%;right:.9rem;left:auto;transform:translateY(-50%);z-index:150;width:max-content;align-items:flex-end;display:flex;flex-direction:column;gap:.18rem;padding:.55rem .5rem;border:1px solid transparent;border-radius:14px;transition:background .3s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease),padding .3s var(--ease);}
.toc:hover{background:rgba(250,249,246,.82);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-color:var(--line);box-shadow:0 20px 50px -28px rgba(10,10,15,.35);padding:.85rem .95rem;}
.toc a{display:flex;align-items:center;justify-content:flex-end;gap:.7rem;padding:.26rem 0;font-size:.74rem;font-weight:500;letter-spacing:.01em;color:var(--muted);white-space:nowrap;transition:color .2s var(--ease);}
.toc-label{max-width:0;opacity:0;overflow:hidden;transition:max-width .32s var(--ease),opacity .25s var(--ease);}
.toc:hover .toc-label{max-width:230px;opacity:1;}
.toc a:hover{color:var(--ink);}
.toc a.active{color:var(--violet);}
.toc-tick{width:18px;height:2px;border-radius:2px;background:var(--line-strong);flex-shrink:0;transition:width .25s var(--ease),background .2s var(--ease);}
.toc a.active .toc-tick{width:28px;background:var(--violet);}
.toc:hover a:hover .toc-tick{background:var(--ink);}
.toc:hover a.active .toc-tick{background:var(--violet);}
/* La section active garde sa couleur (violet) même quand on la survole directement */
.toc a.active:hover{color:var(--violet);}
.toc:hover a.active:hover .toc-tick{background:var(--violet);}
/* Sur fond foncé : ticks clairs pour rester visibles */
.toc.on-dark a{color:rgba(255,255,255,.62);}
.toc.on-dark .toc-tick{background:rgba(255,255,255,.6);}
.toc.on-dark a.active{color:#fff;}
.toc.on-dark a.active .toc-tick{background:#fff;}
.toc.on-dark:hover{background:rgba(20,12,38,.8);border-color:rgba(255,255,255,.16);}
.toc.on-dark:hover a:hover{color:#fff;}
.toc.on-dark:hover a:hover .toc-tick{background:#fff;}
@media(max-width:1080px){.toc{display:none;}}
@media(prefers-reduced-motion:reduce){.toc,.toc-label,.toc-tick{transition:none;}}

/* ── BACK TO TOP ── */
.totop{position:fixed;bottom:24px;right:24px;left:auto;z-index:300;width:46px;height:46px;border-radius:50%;background:var(--ink);color:var(--cream);border:1px solid var(--line-dark-strong);display:flex;align-items:center;justify-content:center;box-shadow:0 14px 34px -16px rgba(10,10,15,.5);opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .3s var(--ease),transform .3s var(--ease),background .2s var(--ease),visibility .3s;}
.totop.show{opacity:1;visibility:visible;transform:translateY(0);}
.totop:hover{background:var(--violet);transform:translateY(-2px);box-shadow:0 16px 36px -14px rgba(110,17,240,.55);}
.totop-arrow{font-family:var(--serif);font-size:1.25rem;line-height:1;}

/* ── HERO ── */
.hero{min-height:100vh;padding:9rem 0 5rem;display:flex;align-items:center;overflow:hidden;}
.hero-bg{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at 82% 26%,rgba(110,17,240,.13),transparent 50%),radial-gradient(ellipse at 8% 86%,rgba(255,46,136,.08),transparent 45%);}
.hero-bg::before{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.45'/%3E%3C/svg%3E");opacity:.4;mix-blend-mode:multiply;}
.hero-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:3.5rem;align-items:end;position:relative;z-index:2;}
@media(max-width:920px){.hero-grid{grid-template-columns:1fr;gap:2.5rem;align-items:start;}}
.hero h1{font-size:clamp(3.2rem,8.5vw,7rem);margin:1.5rem 0 1.75rem;}
.hero h1 .line{display:block;opacity:0;transform:translateY(28px);animation:rise 1s var(--ease) forwards;}
.hero h1 .line:nth-child(1){animation-delay:.1s;}
.hero h1 .line:nth-child(2){animation-delay:.25s;}
@keyframes rise{to{opacity:1;transform:translateY(0);}}
.hero-sub{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(1.4rem,2.4vw,2.1rem);color:var(--ink-soft);line-height:1.2;margin-bottom:1.75rem;opacity:0;animation:fade 1s .45s forwards;}
.hero-desc{font-size:1rem;color:var(--ink-soft);line-height:1.7;max-width:46ch;opacity:0;animation:fade 1s .6s forwards;}
.hero-desc strong{font-weight:500;color:var(--ink);}
.hero-desc em{font-style:italic;font-family:var(--serif);color:var(--violet);}
@keyframes fade{to{opacity:1;}}
.hero-cta-row{margin-top:2.5rem;display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:fade 1s .75s forwards;}
.hero-meta{border-left:1px solid var(--line-strong);padding-left:2.25rem;opacity:0;animation:fade 1s .85s forwards;}
@media(max-width:920px){.hero-meta{border-left:none;padding-left:0;padding-top:2rem;border-top:1px solid var(--line-strong);}}
.hero-meta .eyebrow{margin-bottom:1.5rem;}
.hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:1.75rem 1.5rem;}
.hstat .num{font-family:var(--serif);font-size:2.6rem;font-weight:400;line-height:.9;letter-spacing:-.02em;color:var(--ink);}
.hstat .num span{color:var(--magenta);}
.hstat .lbl{font-size:.78rem;color:var(--muted);margin-top:.5rem;line-height:1.45;}
.hero-clients{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--line);}
.hero-clients .eyebrow{font-size:.65rem;margin-bottom:.85rem;}
.badges{display:flex;flex-wrap:wrap;gap:.4rem;}
.badge{padding:.3rem .65rem;border:1px solid var(--line-strong);border-radius:999px;font-size:.72rem;color:var(--ink-soft);letter-spacing:.02em;}
.hero-note{margin-top:1.5rem;font-size:.78rem;line-height:1.6;color:var(--muted);}

/* ── CONVICTION ── */
.conv-grid{display:grid;grid-template-columns:1fr 1fr;gap:4.5rem;align-items:start;}
@media(max-width:920px){.conv-grid{grid-template-columns:1fr;gap:3rem;}}
.conv-left p{font-size:1rem;line-height:1.8;color:var(--ink-soft);margin-bottom:1.25rem;}
.conv-lead{font-size:1.12rem !important;line-height:1.7 !important;color:var(--ink) !important;}
.conv-pains{list-style:none;margin:0 0 1.5rem;padding:0;display:flex;flex-direction:column;gap:.7rem;}
.conv-pains li{display:flex;align-items:flex-start;gap:.7rem;font-size:.95rem;line-height:1.5;color:var(--ink-soft);}
.conv-pains .cp-x{flex-shrink:0;width:1.25rem;height:1.25rem;border-radius:50%;background:var(--cream);border:1px solid var(--line-strong);color:var(--muted);display:flex;align-items:center;justify-content:center;font-size:.6rem;margin-top:.12rem;}
.conv-left p strong{color:var(--ink);font-weight:500;}
.conv-left p em{color:var(--violet);font-style:italic;font-family:var(--serif);}
.proof{margin-top:1.75rem;padding:1.5rem 1.6rem;background:var(--cream);border:1px solid var(--line);border-left:3px solid var(--violet);border-radius:0 12px 12px 0;}
.proof p{font-size:.92rem;line-height:1.7;color:var(--ink-soft);}
.proof strong{color:var(--violet);font-weight:500;}
.conv-right .eyebrow{margin-bottom:0;}
.doc-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap;}
.doc-toggle{display:inline-flex;background:var(--cream);border:1px solid var(--line-strong);border-radius:999px;padding:.2rem;gap:.15rem;}
.doc-toggle button{border:0;background:transparent;border-radius:999px;padding:.4rem .95rem;font-family:var(--sans);font-size:.72rem;font-weight:500;letter-spacing:.04em;color:var(--muted);transition:color .2s var(--ease),background .2s var(--ease);}
.doc-toggle button.on{background:var(--ink);color:var(--cream);}
.doc-toggle button.apres.on{background:var(--violet);color:#fff;}
.doc-compare{display:flex;flex-direction:column;gap:.55rem;}
.flip{height:82px;perspective:1100px;border-radius:10px;cursor:pointer;outline:none;transition:transform .2s var(--ease);}
.flip:hover{transform:translateX(-3px);}
.flip-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .55s var(--ease);}
.flip.flipped .flip-inner{transform:rotateY(180deg);}
.flip-face{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;padding:.8rem 1.05rem;border-radius:10px;backface-visibility:hidden;-webkit-backface-visibility:hidden;}
.flip:focus-visible .flip-face{box-shadow:0 0 0 2px var(--violet);}
.doc-old{background:var(--cream);border:1px solid var(--line);}
.flip:hover .doc-old{border-color:var(--line-strong);}
.doc-new{background:rgba(110,17,240,.05);border:1px solid rgba(110,17,240,.2);transform:rotateY(180deg);}
.doc-tag{font-family:var(--sans);font-size:.56rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:.26rem;}
.doc-old .doc-tag{color:var(--muted);}
.doc-new .doc-tag{color:var(--violet);}
.doc-label{font-size:.9rem;font-weight:500;line-height:1.2;}
.doc-old .doc-label{color:var(--muted);}
.doc-new .doc-label{color:var(--ink);}
.doc-sub{font-size:.72rem;margin-top:.22rem;line-height:1.3;}
.doc-old .doc-sub{color:var(--muted);}
.doc-new .doc-sub{color:#8a5fd6;}
.flip-badge{position:absolute;top:.6rem;right:.7rem;display:inline-flex;align-items:center;gap:.28rem;font-family:var(--sans);font-size:.54rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:.2rem .42rem;border-radius:999px;line-height:1;}
.doc-old .flip-badge{background:var(--paper,#fff);border:1px solid var(--line-strong);color:var(--muted);}
.doc-new .flip-badge{background:rgba(110,17,240,.12);color:var(--violet);}
.flip-badge .fb-ic{font-size:.78rem;line-height:1;}
.flip:hover .doc-old .flip-badge{color:var(--violet);border-color:var(--violet);}
.flip-hint{display:flex;align-items:center;gap:.45rem;margin-top:1rem;font-size:.72rem;color:var(--muted);}
.flip-hint .gl{color:var(--violet);font-size:.9rem;}
@media(prefers-reduced-motion:reduce){.flip-inner,.flip{transition:none;}}

/* ── BEYOND (ink) ── */
.ink-sec{background:var(--ink);color:var(--cream);padding:7rem 0;overflow:hidden;}
.ink-sec::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(110,17,240,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(110,17,240,.06) 1px,transparent 1px);background-size:64px 64px;pointer-events:none;}
.ink-sec .wrap{position:relative;z-index:2;}
.ink-sec .sec-head h2{color:#fff;}
.ink-sec .sec-head h2 em{color:var(--violet-soft);}
.ink-sec .lead{color:rgba(250,249,246,.72);}
.horizons{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:3.5rem;}
@media(max-width:920px){.horizons{grid-template-columns:1fr;}}
.horizon{padding:2.25rem 1.75rem;border:1px solid var(--line-dark);border-radius:16px;background:rgba(250,249,246,.02);transition:all .35s var(--ease);position:relative;overflow:hidden;}
.horizon::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--violet),var(--magenta));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);}
.horizon:hover{border-color:var(--violet);background:rgba(110,17,240,.07);transform:translateY(-4px);}
.horizon:hover::after{transform:scaleX(1);}
.horizon-num{font-family:var(--serif);font-size:.95rem;font-style:italic;color:var(--magenta);}
.horizon-title{font-family:var(--serif);font-size:1.35rem;font-weight:500;color:#fff;margin:.6rem 0 .9rem;line-height:1.15;}
.horizon-desc{font-size:.85rem;color:rgba(250,249,246,.65);line-height:1.6;margin-bottom:1.25rem;}
.horizon-ex{display:flex;flex-direction:column;gap:.55rem;}
.horizon-ex li{font-size:.8rem;color:rgba(250,249,246,.82);line-height:1.45;display:flex;gap:.55rem;}
.horizon-ex li::before{content:'→';color:var(--violet-soft);flex-shrink:0;}

.spectrum{background:rgba(250,249,246,.03);border:1px solid var(--line-dark);border-radius:18px;padding:2.5rem;}
.spectrum-title{font-family:var(--serif);font-size:1.25rem;font-weight:500;color:#fff;margin-bottom:1.75rem;}
.spectrum-bar{height:5px;border-radius:3px;background:linear-gradient(90deg,rgba(110,17,240,.45),var(--violet) 55%,var(--magenta));}
.spectrum-labels{display:flex;justify-content:space-between;margin-top:.75rem;flex-wrap:wrap;gap:.5rem;}
.spectrum-labels span{font-size:.68rem;color:rgba(250,249,246,.5);letter-spacing:.06em;text-transform:uppercase;}
.spectrum-nodes{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem;margin-top:1.75rem;}
@media(max-width:720px){.spectrum-nodes{grid-template-columns:repeat(2,1fr);}}
.snode{padding:1.1rem .85rem;background:rgba(250,249,246,.03);border:1px solid var(--line-dark);border-radius:10px;transition:border-color .2s;}
.snode:hover{border-color:rgba(110,17,240,.4);}
.snode-i{font-family:var(--serif);font-style:italic;font-size:.85rem;color:var(--magenta);}
.snode-label{font-size:.82rem;color:#fff;font-weight:500;margin:.35rem 0 .3rem;}
.snode-sub{font-size:.72rem;color:rgba(250,249,246,.55);line-height:1.4;}

/* ── BRIDGE ── */
.bridge{display:flex;flex-direction:column;align-items:center;gap:.9rem;padding:3.5rem 0 0;}
.bridge-label{font-family:var(--sans);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);padding:.5rem 1.1rem;border:1px solid var(--line-strong);border-radius:999px;}
.bridge-line{width:1px;height:48px;background:linear-gradient(180deg,var(--violet),transparent);}

/* ── PAIN ── */
.pain-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:start;}
@media(max-width:920px){.pain-grid{grid-template-columns:1fr;gap:2.5rem;}}
/* Les enfants de grille doivent pouvoir rétrécir (sinon le carrousel impose une largeur hors-écran) */
.pain-grid>*{min-width:0;}
.vb-carousel,.vb-track,.vb-track-inner,.vb-slide{min-width:0;max-width:100%;}
.pain-list{display:flex;flex-direction:column;gap:.85rem;}
.pain-card{display:flex;gap:1.25rem;padding:1.4rem 1.5rem;border:1px solid var(--line);border-radius:14px;background:var(--cream);transition:border-color .25s,transform .25s var(--ease);}
.soft .pain-card{background:var(--cream-soft);}
.pain-card:hover{border-color:var(--violet);transform:translateY(-2px);}
.pain-n{font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--violet);flex-shrink:0;width:1.6rem;line-height:1.4;}
.pain-card h4{font-family:var(--serif);font-size:1.1rem;font-weight:500;color:var(--ink);margin-bottom:.35rem;}
.pain-card p{font-size:.88rem;line-height:1.6;color:var(--ink-soft);}
.verbatim{padding:1.75rem;border-left:2px solid var(--magenta);background:var(--cream-soft);border-radius:0 12px 12px 0;margin-bottom:1.25rem;}
.verbatim-q{font-family:var(--serif);font-style:italic;font-size:1.2rem;line-height:1.5;color:var(--ink);margin-bottom:1rem;}
.verbatim-src{font-size:.78rem;color:var(--muted);letter-spacing:.04em;}
/* verbatim carousel */
.vb-head{margin-bottom:.9rem;}
.vb-eyebrow{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--ink);}
.vb-carousel{margin-bottom:1.25rem;}
.vb-track{display:flex;overflow:hidden;}
.vb-track-inner{display:flex;transition:transform .5s var(--ease);width:100%;}
.vb-slide{flex:0 0 100%;margin-bottom:0;border-radius:0 12px 12px 0;display:flex;flex-direction:column;justify-content:center;min-height:230px;}
.vb-slide .verbatim-q{margin-bottom:1.1rem;}
.vb-controls{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:1rem;}
.vb-dots{display:flex;gap:.5rem;}
.vb-dot{width:8px;height:8px;padding:0;border:0;border-radius:50%;background:var(--line-strong);cursor:pointer;transition:background .25s,width .25s var(--ease);}
.vb-dot.on{background:var(--magenta);width:22px;border-radius:4px;}
.vb-arrows{display:flex;gap:.5rem;}
.vb-arrow{width:38px;height:38px;border-radius:50%;border:1px solid var(--line-strong);background:transparent;color:var(--ink);font-family:var(--serif);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s,border-color .2s;}
.vb-arrow:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}
@media(prefers-reduced-motion:reduce){.vb-track{transition:none;}}
.insight{padding:1.5rem 1.6rem;background:rgba(110,17,240,.05);border:1px solid rgba(110,17,240,.18);border-radius:12px;font-size:.95rem;line-height:1.7;color:var(--ink-soft);}
.insight strong{color:var(--violet);font-weight:500;}

/* ── NAME REVEAL (violet gradient) ── */
.name{padding:8rem 0;text-align:center;background:linear-gradient(160deg,#1B0A2E 0%,#2A0568 60%,#4A0BB0 100%);color:var(--cream);overflow:hidden;}
.name::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 15%,rgba(255,46,136,.22),transparent 50%),radial-gradient(ellipse at 15% 90%,rgba(110,17,240,.4),transparent 50%);pointer-events:none;}
.name .wrap{position:relative;z-index:2;}
.name .eyebrow{color:var(--magenta-soft);justify-content:center;display:block;margin-bottom:1.5rem;}
.name-big{font-family:var(--serif);font-weight:400;font-size:clamp(3.5rem,11vw,9rem);line-height:.9;letter-spacing:-.03em;color:#fff;}
.name-big em{font-style:italic;font-weight:300;color:var(--magenta-soft);}
.name-tag{margin-top:1.5rem;font-size:.85rem;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:var(--magenta-soft);}
.name-row{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:920px;margin:3.5rem auto 0;text-align:left;}
@media(max-width:760px){.name-row{grid-template-columns:1fr;gap:1.5rem;}}
.name-item{padding-top:1.25rem;border-top:1px solid var(--line-dark-strong);}
.name-item-i{font-family:var(--serif);font-style:italic;font-size:1.4rem;color:var(--magenta-soft);}
.name-item p{font-size:.9rem;line-height:1.6;color:rgba(255,255,255,.82);margin-top:.6rem;}

/* ── OFFER · STARS METHOD ── */
.stars-legend{display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem 1.4rem;margin-bottom:1.6rem;}
.stars-legend .sl-lead{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.stars-legend .sl{display:inline-flex;align-items:baseline;gap:.16rem;font-size:.92rem;color:var(--ink-soft);font-family:var(--sans);}
.stars-legend .sl b{font-family:var(--serif);font-weight:500;font-size:1.25rem;color:var(--violet);line-height:1;}

.stars-stage{position:relative;display:grid;grid-template-columns:minmax(118px,1.05fr) 4.3fr minmax(150px,1.35fr);grid-template-rows:minmax(340px,auto);border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--cream);}
@media(max-width:820px){.stars-stage{grid-template-columns:1fr;grid-template-rows:auto;}}

.stars-zone{position:relative;z-index:4;padding:1.6rem 1.3rem;display:flex;flex-direction:column;justify-content:space-between;gap:1rem;}
.stars-zone .zword{font-family:var(--serif);font-weight:400;line-height:.92;letter-spacing:-.01em;display:flex;align-items:baseline;}
.stars-zone .zword .cap{font-size:2.7rem;}
.stars-zone .zword .rest{font-size:1.45rem;}
.stars-zone .zsub{font-size:.74rem;line-height:1.5;}
.stars-scoping{background:var(--ink);color:#fff;}
.stars-scoping .zsub{color:rgba(255,255,255,.62);}
.stars-spread{background:var(--violet);color:#fff;text-align:right;}
.stars-spread .zword{justify-content:flex-end;}
.stars-spread .zsub{color:rgba(255,255,255,.82);}

.stars-pilots{position:relative;display:flex;flex-direction:column;background:linear-gradient(180deg,#fff 0%,var(--cream-soft) 100%);padding:1.1rem 1.6rem 0;}
.pilots-top{text-align:center;font-family:var(--serif);font-size:1.15rem;color:var(--ink);line-height:1;padding:.3rem 0 .2rem;}
.pilots-top .pt-lead{color:var(--muted);font-size:.95rem;}
.pilots-top .pt-cap{font-size:1.6rem;}
.pilots-track{position:relative;flex:1;padding:2.7rem 0 1.1rem;min-height:170px;}

.stars-wedge{position:absolute;left:0;right:0;bottom:.6rem;height:74%;clip-path:polygon(0 100%,100% 0,100% 100%);background:linear-gradient(90deg,rgba(255,46,136,0),rgba(255,46,136,.16) 50%,rgba(110,17,240,.4));transform:scaleX(0);transform-origin:left;transition:transform 1s var(--ease) .2s;z-index:1;}
.wedge-label{position:absolute;right:8%;bottom:.35rem;font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--violet);z-index:3;opacity:0;transition:opacity .6s var(--ease) .7s;}

.ck{position:absolute;top:-.2rem;bottom:.4rem;z-index:3;opacity:0;transition:opacity .55s var(--ease);}
.ck-1{left:31%;transition-delay:.55s;}
.ck-2{left:62%;transition-delay:.8s;}
.ck-head{display:flex;align-items:center;gap:.4rem;white-space:nowrap;}
.ck-star{color:var(--magenta);font-size:1.15rem;line-height:1;}
.ck-label{font-family:var(--serif);font-size:.92rem;color:var(--ink);}
.ck-label b{color:var(--violet);font-weight:500;}
.ck-line{position:absolute;left:.42rem;top:1.7rem;bottom:0;border-left:1px dashed var(--violet);opacity:.45;}

.lanes{position:relative;z-index:2;display:flex;flex-direction:column;gap:.75rem;}
.lane{position:relative;height:36px;}
.lane-bar{position:absolute;inset:0;background:#fff;clip-path:polygon(0 0,calc(100% - 17px) 0,100% 50%,calc(100% - 17px) 100%,0 100%);box-shadow:0 1px 4px rgba(10,10,15,.1),inset 0 0 0 1px rgba(10,10,15,.06);transform:scaleX(0);transform-origin:left;transition:transform .8s var(--ease);}
.lanes .lane:nth-child(1) .lane-bar{transition-delay:.15s;}
.lanes .lane:nth-child(2) .lane-bar{transition-delay:.28s;}
.lanes .lane:nth-child(3) .lane-bar{transition-delay:.41s;}
.lane span{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:.76rem;font-weight:600;letter-spacing:.04em;color:var(--ink);z-index:2;opacity:0;transition:opacity .5s var(--ease) .5s;}

.stars-stage.visible .lane-bar{transform:scaleX(1);}
.stars-stage.visible .stars-wedge{transform:scaleX(1);}
.stars-stage.visible .ck,.stars-stage.visible .wedge-label,.stars-stage.visible .lane span{opacity:1;}

.pilots-base{display:flex;align-items:center;justify-content:center;gap:.45rem;text-align:center;font-family:var(--sans);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;font-weight:600;padding:.8rem 1.6rem;margin:.5rem -1.6rem 0;background:linear-gradient(90deg,var(--ink) 0%,var(--violet-deep) 55%,var(--violet) 100%);}
.pilots-base .pb-i{color:rgba(255,255,255,.85);font-size:.85rem;}

@media(prefers-reduced-motion:reduce){.stars-stage .lane-bar,.stars-stage .stars-wedge{transform:none!important;transition:none!important;}.stars-stage .ck,.stars-stage .wedge-label,.stars-stage .lane span{opacity:1!important;}}

@media(max-width:820px){
  .stars-zone{flex-direction:row;align-items:center;justify-content:space-between;padding:1.1rem 1.3rem;gap:1.25rem;}
  .stars-zone .zword .cap{font-size:2.1rem;}.stars-zone .zword .rest{font-size:1.2rem;}
  .stars-zone .zsub{max-width:55%;text-align:right;}
  .stars-spread{text-align:left;}.stars-spread .zword{justify-content:flex-start;}.stars-spread .zsub{text-align:left;}
  .stars-pilots{padding:1rem 1.1rem 0;}
  .pilots-base{margin:.5rem -1.1rem 0;padding:.8rem 1.1rem;}
  .pilots-track{padding-top:3rem;}
}

/* Petit mobile : légende sur une ligne sous le label + jalons sans chevauchement */
@media(max-width:620px){
  .stars-legend{justify-content:center;gap:.35rem .7rem;}
  .stars-legend .sl-lead{flex-basis:100%;text-align:center;margin-bottom:.15rem;}
  .stars-legend .sl{font-size:.78rem;}
  .stars-legend .sl b{font-size:1.02rem;}
  .pilots-top{font-size:1rem;}
  .pilots-top .pt-cap{font-size:1.35rem;}
  .pilots-track{padding-top:4rem;}
  .ck-label{font-size:.7rem;}
  .ck-star{font-size:.95rem;}
  .ck-1{left:24%;}
  .ck-2{left:58%;}
  .wedge-label{right:4%;font-size:.88rem;}
}

/* priorities */
.stars-prio{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.5rem;}
@media(max-width:760px){.stars-prio{grid-template-columns:1fr;}}
.pri{padding:1.5rem 1.6rem;border:1px solid var(--line);border-radius:14px;background:var(--cream);transition:border-color .25s,transform .25s var(--ease);}
.pri:hover{border-color:var(--violet);transform:translateY(-3px);}
.pri .pri-i{font-family:var(--serif);font-style:italic;font-size:1.4rem;color:var(--magenta);line-height:1;}
.pri h4{font-family:var(--serif);font-size:1.2rem;font-weight:500;color:var(--ink);margin:.4rem 0 .45rem;line-height:1.1;}
.pri p{font-size:.86rem;line-height:1.6;color:var(--ink-soft);}

/* ── PRODUCTS ── */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;}
@media(max-width:920px){.prod-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:600px){.prod-grid{grid-template-columns:1fr;}}
.prod{padding:1.75rem 1.5rem;border:1px solid var(--line);border-radius:14px;background:var(--cream);transition:all .25s var(--ease);position:relative;}
.prod:hover{border-color:var(--violet);transform:translateY(-3px);}
.prod.feat{border-color:rgba(110,17,240,.28);background:rgba(110,17,240,.04);}
.prod-badge{position:absolute;top:1rem;right:1rem;background:var(--violet);color:#fff;font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;padding:.28rem .55rem;border-radius:999px;font-weight:500;}
.prod-name{font-family:var(--serif);font-size:1.25rem;font-weight:500;color:var(--ink);margin-bottom:.15rem;line-height:1.1;}
.prod-sub{font-size:.7rem;color:var(--violet);letter-spacing:.06em;text-transform:uppercase;font-weight:500;display:block;margin-bottom:1rem;}
.prod-desc{font-size:.85rem;line-height:1.6;color:var(--ink-soft);margin-bottom:1.25rem;}
.tags{display:flex;flex-wrap:wrap;gap:.4rem;}
.tag{padding:.25rem .6rem;border:1px solid var(--line);border-radius:999px;font-size:.68rem;color:var(--muted);}

/* ── SKILLS / COMPÉTENCES ── */
.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;}
@media(max-width:920px){.skills-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:600px){.skills-grid{grid-template-columns:1fr;}}
.skill{padding:1.75rem 1.5rem;border:1px solid var(--line);border-radius:14px;background:var(--cream);transition:all .25s var(--ease);}
.skill:hover{border-color:var(--violet);transform:translateY(-3px);}
.skill-num{font-family:var(--serif);font-style:italic;font-size:1.4rem;color:var(--magenta);line-height:1;}
.skill-title{font-family:var(--serif);font-size:1.2rem;font-weight:500;color:var(--ink);margin:.5rem 0 .6rem;line-height:1.15;}
.skill-desc{font-size:.85rem;line-height:1.6;color:var(--ink-soft);margin-bottom:1.1rem;}

/* ── FLOW (ink) ── */
.flow-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;}
@media(max-width:920px){.flow-grid{grid-template-columns:1fr;gap:2.5rem;}}
.flow-grid h2{font-family:var(--serif);font-size:clamp(1.9rem,3.2vw,2.6rem);font-weight:400;line-height:1.08;letter-spacing:-.02em;color:#fff;margin-bottom:1.25rem;}
.flow-grid h2 em{font-style:italic;color:var(--violet-soft);}
.flow-grid .flow-text{font-size:.95rem;line-height:1.75;color:rgba(250,249,246,.7);}
.flow-steps{border:1px solid var(--line-dark);border-radius:16px;overflow:hidden;background:rgba(250,249,246,.02);}
.flow-step{padding:1.15rem 1.4rem;display:flex;align-items:center;gap:1.1rem;border-bottom:1px solid var(--line-dark);transition:background .2s;}
.flow-step:last-child{border-bottom:none;}
.flow-step:hover{background:rgba(110,17,240,.06);}
.flow-dot{width:30px;height:30px;border-radius:50%;background:var(--ink);border:1px solid var(--line-dark-strong);color:var(--violet-soft);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:.85rem;flex-shrink:0;transition:all .25s;}
.flow-step:hover .flow-dot{background:var(--violet);color:#fff;border-color:var(--violet);}
.flow-dot.arr{background:transparent;border:none;color:var(--violet-soft);font-family:var(--serif);}
.flow-cnt h5{font-family:var(--serif);font-size:1rem;font-weight:500;color:#fff;margin-bottom:.15rem;}
.flow-cnt p{font-size:.8rem;color:rgba(250,249,246,.6);}

/* ── MODEL · ORG BLUEPRINT ── */
.ob{margin-top:.25rem;}
.ob-toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.25rem;}
.ob-legend{display:flex;gap:1.1rem;flex-wrap:wrap;font-size:.7rem;color:var(--muted);align-items:center;}
.ob-legend span{display:inline-flex;align-items:center;gap:.45rem;}
.ob-dot{width:11px;height:11px;border-radius:3px;flex-shrink:0;}
.ob-dot.group{background:rgba(110,17,240,.85);}
.ob-dot.local{background:var(--magenta);}
.ob-dot.infra{background:var(--ink);}
.ob-hint{font-size:.74rem;color:var(--muted);font-style:italic;font-family:var(--serif);}

.ob-stage{display:flex;gap:.6rem;align-items:stretch;}
@media(max-width:820px){.ob-stage{flex-direction:column;}}

/* Backlog */
.ob-backlog{width:152px;flex-shrink:0;border-radius:14px;background:linear-gradient(165deg,#2A0568,#4A0BB0);color:#fff;padding:.9rem .9rem 1rem;display:flex;flex-direction:column;}
@media(max-width:820px){.ob-backlog{width:auto;}}
.ob-bk-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;}
.ob-bk-title{font-family:var(--serif);font-size:.98rem;font-weight:500;line-height:1.05;}
.ob-bk-title .ob-band-sub{display:block;margin:.25rem 0 0;color:rgba(255,255,255,.6);}
.ob-bk-items{display:flex;flex-direction:column;gap:.4rem;margin-top:.7rem;}
@media(max-width:820px){.ob-bk-items{flex-direction:row;flex-wrap:wrap;}}
.ob-bk-item{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:7px;padding:.45rem .55rem;font-size:.64rem;letter-spacing:.06em;text-transform:uppercase;color:#fff;font-weight:500;}
.ob-bk-detail{margin-top:.7rem;border-top:1px solid rgba(255,255,255,.2);padding-top:.65rem;display:none;}
.ob-backlog.open .ob-bk-detail{display:block;}
.ob-bk-detail li{font-size:.69rem;line-height:1.45;color:rgba(255,255,255,.82);display:flex;gap:.4rem;margin-bottom:.35rem;}
.ob-bk-detail li::before{content:'→';color:var(--magenta-soft);flex-shrink:0;}
.ob-bk-detail li b{color:#fff;font-weight:600;}

/* Flux connector — un label par rangée, centré en face de sa brique */
.ob-row{display:flex;align-items:center;gap:.45rem;}
@media(max-width:820px){.ob-row{flex-direction:column;align-items:stretch;gap:.4rem;}}
.ob-row>.ob-band,.ob-row>.ob-mgmt-row{flex:1;min-width:0;}
.ob-flux-item{width:30px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:.25rem;}
@media(max-width:820px){.ob-flux-item{width:auto;flex-direction:row;justify-content:center;padding:.1rem 0;}}
.ob-flux-item .gl{font-size:.95rem;line-height:1;color:var(--violet);}
.ob-flux-item .lb{font-size:.5rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap;}
@media(max-width:820px){.ob-flux-item .lb{writing-mode:horizontal-tb;transform:none;}}

/* Bands */
.ob-bands{flex:1;display:flex;flex-direction:column;gap:.6rem;min-width:0;}
.ob-band{border-radius:14px;border:1px solid var(--line-strong);overflow:hidden;background:var(--cream);}
.ob-band-head{display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:.6rem .9rem;}
.ob-band-title{font-family:var(--serif);font-size:1.02rem;font-weight:500;color:var(--ink);}
.ob-band-sub{font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-left:.5rem;}
.ob-plus{width:24px;height:24px;flex-shrink:0;border-radius:50%;border:1px solid currentColor;background:transparent;color:var(--violet);font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-family:var(--sans);}
.ob-plus:hover{background:var(--violet);color:#fff;border-color:var(--violet);}

.ob-vision{background:rgba(110,17,240,.06);border-color:rgba(110,17,240,.22);}
.ob-vision .ob-band-head{background:rgba(110,17,240,.12);}
.ob-infra{background:var(--ink);border-color:var(--ink);}
.ob-infra .ob-band-title{color:#fff;}
.ob-infra .ob-band-sub{color:rgba(255,255,255,.55);}
.ob-infra .ob-plus{color:#fff;}
.ob-infra .ob-plus:hover{background:#fff;color:var(--ink);border-color:#fff;}

.ob-cells{display:grid;grid-template-columns:repeat(3,1fr);gap:.45rem;padding:0 .6rem .6rem;}
@media(max-width:540px){.ob-cells{grid-template-columns:1fr;}}
.ob-cell{background:var(--cream);border:1px solid var(--line);border-radius:8px;padding:.55rem .65rem;}
.ob-infra .ob-cell{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.16);}
.ob-cell-t{font-size:.78rem;font-weight:600;color:var(--ink);}
.ob-infra .ob-cell-t{color:#fff;}
.ob-cell-s{font-size:.65rem;color:var(--muted);margin-top:.1rem;line-height:1.35;}
.ob-infra .ob-cell-s{color:rgba(255,255,255,.6);}

/* Detail (expand) */
.ob-detail{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:.5rem;max-height:0;overflow:hidden;opacity:0;padding:0 .6rem;transition:max-height .45s var(--ease),opacity .35s,padding .45s var(--ease);}
.ob-band.open .ob-detail{max-height:1600px;opacity:1;padding:.1rem .6rem .7rem;}
.ob-role{background:rgba(250,249,246,.65);border:1px dashed var(--line-strong);border-radius:8px;padding:.65rem .75rem;}
.ob-infra .ob-role{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.2);}
.ob-role-h{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;margin-bottom:.35rem;}
.ob-role h6{font-family:var(--serif);font-size:.86rem;font-weight:600;color:var(--ink);}
.ob-infra .ob-role h6{color:#fff;}
.ob-role .fte{font-size:.55rem;letter-spacing:.08em;text-transform:uppercase;color:var(--violet);font-weight:600;white-space:nowrap;}
.ob-infra .ob-role .fte{color:var(--violet-soft);}
.ob-role>p{font-size:.72rem;line-height:1.5;color:var(--ink-soft);margin-bottom:.4rem;}
.ob-infra .ob-role>p{color:rgba(255,255,255,.78);}
.ob-role ul{display:flex;flex-direction:column;gap:.25rem;}
.ob-role li{font-size:.69rem;line-height:1.4;color:var(--ink-soft);display:flex;gap:.4rem;}
.ob-role li::before{content:'→';color:var(--violet);flex-shrink:0;}
.ob-infra .ob-role li{color:rgba(255,255,255,.75);}
.ob-infra .ob-role li::before{color:var(--violet-soft);}

/* Management row + BUs */
.ob-mgmt-row{display:flex;gap:.6rem;align-items:stretch;}
@media(max-width:820px){.ob-mgmt-row{flex-direction:column;}}
.ob-mgmt{flex:1;min-width:0;}
.ob-bus{display:none;flex:2;gap:.6rem;min-width:0;}
@media(max-width:820px){.ob-bus{flex-direction:column;}}
#orgBlueprint.bu-on .ob-bus{display:flex;animation:obIn .45s var(--ease);}
#orgBlueprint.bu-on .ob-bu-add{display:none;}
.ob-bu-add{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;border:1.5px dashed var(--magenta);border-radius:14px;background:rgba(255,46,136,.04);color:var(--magenta);cursor:pointer;padding:1rem;text-align:center;transition:background .2s,transform .2s;min-width:0;font-family:inherit;}
.ob-bu-add:hover{background:rgba(255,46,136,.09);transform:translateY(-2px);}
.ob-bu-add .ob-bu-plus{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--magenta);display:flex;align-items:center;justify-content:center;font-size:1.2rem;}
.ob-bu-add .t{font-family:var(--serif);font-size:.95rem;font-weight:500;}
.ob-bu-add .s{font-size:.68rem;color:var(--muted);max-width:190px;line-height:1.4;}
@keyframes obIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.ob-bu{flex:1;min-width:0;border-radius:14px;border:1px solid var(--magenta);background:rgba(255,46,136,.05);overflow:hidden;}
.ob-bu .ob-band-head{background:rgba(255,46,136,.12);}
.ob-bu .ob-band-title{color:var(--ink);}
.ob-bu.dim{opacity:.6;border-style:dashed;}
.ob-bu .ob-band-sub{color:var(--magenta);}
.ob-bu .ob-cells{grid-template-columns:1fr 1fr;}
@media(max-width:540px){.ob-bu .ob-cells{grid-template-columns:1fr;}}

.ob-busbar{display:none;margin-top:.7rem;padding:.75rem .95rem;border:1px solid rgba(255,46,136,.25);background:rgba(255,46,136,.05);border-radius:10px;align-items:center;gap:.7rem;font-size:.78rem;color:var(--ink-soft);line-height:1.5;}
#orgBlueprint.bu-on .ob-busbar{display:flex;}
.ob-busbar .mk{color:var(--magenta);font-weight:700;font-family:var(--serif);flex-shrink:0;}
.ob-busbar strong{color:var(--magenta);font-weight:600;}
.ob-busbar .ob-hide{margin-left:auto;flex-shrink:0;border:1px solid var(--line-strong);background:transparent;border-radius:999px;padding:.35rem .85rem;font-size:.68rem;cursor:pointer;color:var(--muted);font-family:inherit;}
.ob-busbar .ob-hide:hover{border-color:var(--ink);color:var(--ink);}

/* Mobile : on conserve la disposition desktop du schéma et on le rend défilable horizontalement
   (au lieu de l'empiler) — préserve les imbrications + interactions (+/toggle BU). */
@media(max-width:820px){
  .ob-scroll{overflow-x:auto;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch;border-radius:14px;padding-bottom:.4rem;}
  .ob-stage{flex-direction:row;min-width:900px;}
  .ob-backlog{width:152px;}
  .ob-bk-items{flex-direction:column;}
  .ob-row{flex-direction:row;align-items:center;gap:.45rem;}
  .ob-flux-item{width:30px;flex-direction:column;}
  .ob-flux-item .lb{writing-mode:vertical-rl;transform:rotate(180deg);}
  .ob-mgmt-row{flex-direction:row;}
  .ob-bus{flex-direction:row;}
  .ob-cells{grid-template-columns:repeat(3,1fr);}
  .ob-bu .ob-cells{grid-template-columns:1fr 1fr;}
  .ob-hint::after{content:' · glissez le schéma horizontalement →';color:var(--violet);}
}

.model-note{margin-top:1.75rem;padding:1.5rem 1.75rem;background:rgba(110,17,240,.05);border:1px solid rgba(110,17,240,.18);border-radius:12px;display:flex;gap:1rem;align-items:flex-start;}
.model-note::before{content:'◆';color:var(--magenta);font-size:.7rem;line-height:1.6;flex-shrink:0;}
.model-note p{font-size:.95rem;line-height:1.7;color:var(--ink-soft);}
.model-note strong{color:var(--violet);font-weight:500;}

/* ── REFS ── */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:16px;overflow:hidden;margin-bottom:2.5rem;background:var(--cream);}
@media(max-width:760px){.kpis{grid-template-columns:1fr 1fr;}}
.kpi{padding:2rem 1.5rem;text-align:center;border-right:1px solid var(--line);border-bottom:1px solid transparent;}
.kpi:last-child{border-right:none;}
@media(max-width:760px){.kpi:nth-child(2){border-right:none;}.kpi:nth-child(-n+2){border-bottom:1px solid var(--line);}}
.kpi-n{font-family:var(--serif);font-size:clamp(2.4rem,4vw,3rem);font-weight:400;color:var(--ink);line-height:1;letter-spacing:-.02em;}
.kpi-n span{color:var(--magenta);}
.kpi-l{font-size:.78rem;color:var(--muted);margin-top:.6rem;line-height:1.4;}
.refs-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;}
@media(max-width:760px){.refs-grid{grid-template-columns:1fr;}}
.ref{padding:2rem;border:1px solid var(--line);border-radius:16px;background:var(--cream);transition:border-color .25s;}
.ref:hover{border-color:var(--violet);}
.ref-client{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--violet);font-weight:500;margin-bottom:.6rem;}
.ref-title{font-family:var(--serif);font-size:1.3rem;font-weight:500;color:var(--ink);margin-bottom:.85rem;line-height:1.2;}
.ref-desc{font-size:.88rem;line-height:1.7;color:var(--ink-soft);margin-bottom:1.25rem;}

/* ── DIFF ── */
.diff-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;}
@media(max-width:920px){.diff-grid{grid-template-columns:1fr;gap:3rem;}}
.diff-points{display:flex;flex-direction:column;gap:2rem;}
.diff-point{display:flex;gap:1.5rem;}
.diff-n{font-family:var(--serif);font-size:2.4rem;font-weight:300;color:var(--violet-soft);line-height:1;flex-shrink:0;width:2.5rem;}
.diff-point h4{font-family:var(--serif);font-size:1.2rem;font-weight:500;color:var(--ink);margin-bottom:.4rem;}
.diff-point p{font-size:.9rem;line-height:1.65;color:var(--ink-soft);}
.diff-vs{background:var(--cream);border:1px solid var(--line);border-radius:18px;padding:2.25rem;}
.soft .diff-vs{background:var(--cream-soft);}
.dvs-title{font-family:var(--serif);font-size:1.35rem;font-weight:500;color:var(--ink);margin-bottom:1.5rem;}
.dvs-row{display:grid;grid-template-columns:1fr auto 1fr;gap:.6rem;align-items:center;margin-bottom:.6rem;}
.dvs-item{padding:.7rem .9rem;border-radius:8px;font-size:.8rem;line-height:1.35;}
.dvs-item.them{background:rgba(10,10,15,.03);color:var(--muted);border:1px solid var(--line);}
.dvs-item.us{background:rgba(110,17,240,.06);color:var(--ink);border:1px solid rgba(110,17,240,.18);}
.dvs-sep{font-family:var(--serif);font-style:italic;font-size:.78rem;color:var(--muted);}
.dvs-head{display:grid;grid-template-columns:1fr auto 1fr;gap:.6rem;margin-bottom:.75rem;}
.dvs-hl{font-size:.62rem;letter-spacing:.13em;text-transform:uppercase;font-weight:500;padding:0 .5rem;}
.dvs-hl.them{color:var(--muted);}
.dvs-hl.us{color:var(--violet);}

/* ── CTA FINAL (violet) ── */
.cta{padding:8rem 0;background:linear-gradient(160deg,var(--violet) 0%,var(--violet-deep) 60%,#2A0568 100%);color:var(--cream);overflow:hidden;text-align:center;}
.cta::before{content:'';position:absolute;top:-40%;left:50%;transform:translateX(-50%);width:800px;height:600px;background:radial-gradient(circle,var(--magenta) 0%,transparent 70%);opacity:.35;pointer-events:none;}
.cta .wrap{position:relative;z-index:2;}
.cta .eyebrow{color:var(--magenta-soft);display:block;margin-bottom:1.5rem;}
.cta h2{font-family:var(--serif);font-size:clamp(2.5rem,5.5vw,4.25rem);font-weight:400;line-height:1.02;letter-spacing:-.02em;color:#fff;}
.cta h2 em{font-style:italic;color:var(--magenta-soft);}
.cta-sub{font-size:1.1rem;color:rgba(255,255,255,.85);max-width:50ch;margin:1.5rem auto 2.5rem;line-height:1.6;}
.cta-contacts{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--line-dark-strong);display:flex;justify-content:center;gap:3rem;flex-wrap:wrap;}
.cc-lbl{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--magenta-soft);margin-bottom:.35rem;}
.cc-val{font-size:.95rem;color:#fff;font-weight:500;}
.cc-val a{color:#fff;text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--magenta-soft);transition:color .2s var(--ease),text-decoration-color .2s var(--ease);}
.cc-val a:hover{color:var(--magenta-soft);text-decoration-color:var(--magenta-soft);}

/* ── FOOTER ── */
footer{padding:2.75rem 0;border-top:1px solid var(--line);background:var(--cream);}
.foot{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap;}
.foot-brand{display:flex;align-items:center;gap:.85rem;}
.foot-logo{height:24px;width:auto;}
.foot-offer{font-family:var(--serif);font-size:1rem;color:var(--ink);display:inline-flex;align-items:center;gap:.45rem;}
.foot-offer em{font-style:italic;color:var(--violet);}
.foot-tag{font-size:.8rem;color:var(--muted);}
.foot-awards{display:flex;gap:.5rem;flex-wrap:wrap;}
.foot-award{padding:.3rem .7rem;border:1px solid var(--line-strong);border-radius:999px;font-size:.65rem;letter-spacing:.06em;color:var(--muted);text-transform:uppercase;}
.foot-legal{font-size:.72rem;color:var(--muted);width:100%;padding-top:1.25rem;border-top:1px solid var(--line);}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(28px);filter:blur(6px);transition:opacity .9s var(--ease),transform .9s var(--ease),filter .9s var(--ease);}
.reveal.visible{opacity:1;transform:translateY(0);filter:blur(0);}
/* Hover des cartes reveal prioritaire sur l'état .reveal.visible (même spécificité → on remonte la priorité avec une règle plus spécifique) */
.prod.reveal.visible:hover,.skill.reveal.visible:hover,.pri.reveal.visible:hover{transform:translateY(-3px);}
.ref.reveal.visible:hover{transform:translateY(-4px);}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;filter:none;transition:none;}.hero h1 .line,.hero-sub,.hero-desc,.hero-cta-row,.hero-meta{opacity:1;animation:none;}}

/* Flou de sortie des sections (anim 2) — transition courte pour lisser le rAF, neutralisée si reduced-motion */
.sec{transition:filter .12s linear,opacity .12s linear;}
@media(prefers-reduced-motion:reduce){.sec{transition:none;filter:none!important;opacity:1!important;}}

/* Utility class (extracted from former inline style) */
.lead-beyond{max-width:780px;margin-bottom:3.5rem;}

/* ════════════════════════════════════════════════
   MICRO-ANIMATIONS (validées client)
   ════════════════════════════════════════════════ */

/* (1) Filet de titre qui se trace — sous chaque <h2> de .sec-head */
.sec-head h2{position:relative;padding-bottom:1.1rem;}
.sec-head h2::after{content:'';position:absolute;left:0;bottom:0;width:56px;height:3px;border-radius:3px;background:linear-gradient(90deg,var(--violet),var(--magenta));transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease);}
.sec-head h2.visible::after{transform:scaleX(1);}
.ink-sec .sec-head h2::after{background:linear-gradient(90deg,var(--violet-soft),var(--magenta));}

/* (2) Count-up — le span animé hérite de la couleur d'encre (le span suffixe magenta existant n'est pas touché) */
.hstat .num .cu,.kpi .kpi-n .cu{color:var(--ink);}

/* (4) CTA flèche + lift — boutons d'action portant une flèche */
.cta-arrow{display:inline-block;transition:transform .25s var(--ease);}
.btn-primary:hover .cta-arrow,.btn-light:hover .cta-arrow{transform:translateX(4px);}
.btn-light:hover{box-shadow:0 12px 30px -12px rgba(10,10,15,.45);}

/* (5) Cartes : lift + bordure accent + ombre douce (renforce les hovers existants) */
.prod:hover,.skill:hover,.pri:hover,.ref:hover,.pain-card:hover{box-shadow:0 14px 34px -18px rgba(110,17,240,.4);}
.ref{transition:border-color .25s var(--ease),transform .25s var(--ease),box-shadow .25s var(--ease);}
.ref:hover{transform:translateY(-4px);border-color:var(--violet-soft);}

/* (6) Liens nav / TOC : soulignement animé gauche→droite */
.mobile-menu-nav a{position:relative;}
.mobile-menu-nav a::after{content:'';position:absolute;left:0;bottom:.05em;height:2px;width:100%;background:var(--violet);transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease);}
.mobile-menu-nav a:hover::after,.mobile-menu-nav a:focus-visible::after{transform:scaleX(1);}
.toc a::after{content:'';position:absolute;left:0;right:auto;bottom:.05rem;height:1px;width:0;background:var(--violet);transition:width .28s var(--ease);}
.toc:hover a:hover::after,.toc a:focus-visible::after{width:100%;}

/* prefers-reduced-motion : tout figé sur l'état final, sans mouvement */
@media(prefers-reduced-motion:reduce){
  .sec-head h2::after{transform:scaleX(1);transition:none;}
  .cta-arrow{transition:none;}
  .btn-primary:hover .cta-arrow,.btn-light:hover .cta-arrow{transform:none;}
  .prod,.skill,.pri,.ref,.pain-card{transition:border-color .25s var(--ease);}
  .prod:hover,.skill:hover,.pri:hover,.ref:hover,.pain-card:hover{transform:none;box-shadow:none;}
  .prod.reveal.visible:hover,.skill.reveal.visible:hover,.pri.reveal.visible:hover,.ref.reveal.visible:hover{transform:none;}
  .mobile-menu-nav a::after,.toc a::after{transition:none;}
}

/* ── LANGUAGE SWITCH (FR / EN pill) ── */
.nav-lang{display:inline-flex;align-items:stretch;margin-right:.6rem;border:1px solid var(--line-strong);border-radius:999px;overflow:hidden;font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;line-height:1;background:transparent;}
.nav-lang>*{padding:.62rem .85rem;display:inline-flex;align-items:center;transition:background .2s ease,color .2s ease;color:var(--muted);cursor:pointer;text-decoration:none;}
.nav-lang>a:hover{color:var(--ink);background:rgba(10,10,15,.05);}
.nav-lang .is-active{background:var(--ink);color:var(--cream);cursor:default;}
@media(max-width:560px){nav .nav-offer,nav .nav-div{display:none;}}

/* ── MOBILE BURGER ── */
.nav-burger{display:none;width:38px;height:38px;align-items:center;justify-content:center;padding:0;background:transparent;color:var(--ink);border:1px solid var(--line-strong);border-radius:.55rem;cursor:pointer;transition:all .2s var(--ease);margin-left:.4rem;}
.nav-burger:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}
.nav-burger svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;pointer-events:none;}
.nav-burger svg .line{transform-origin:center;transition:transform .3s cubic-bezier(.5,.85,.25,1.1);}
.nav-burger svg .line.top{transform:translateY(-7px);}
.nav-burger svg .line.bot{transform:translateY(7px);}
.nav-burger[aria-expanded="true"] svg .line.top{transform:translateY(0) rotate(315deg);}
.nav-burger[aria-expanded="true"] svg .line.mid{transform:rotate(45deg);}
.nav-burger[aria-expanded="true"] svg .line.bot{transform:translateY(0) rotate(135deg);}
@media(max-width:860px),(max-height:500px) and (orientation:landscape){nav .nav-burger{display:inline-flex;}nav .nav-cta{display:none;}}

/* ── MOBILE MENU OVERLAY ── */
.mobile-menu{position:fixed;inset:0;z-index:250;background:var(--cream);display:grid;grid-template-columns:1fr;grid-template-rows:auto minmax(0,1fr) auto;grid-template-areas:"header" "nav" "foot";overflow:hidden;transform:translateX(100%);visibility:hidden;pointer-events:none;transition:transform .35s var(--ease),visibility 0s linear .35s;}
.mobile-menu.is-open{transform:translateX(0);visibility:visible;pointer-events:auto;transition:transform .35s var(--ease),visibility 0s linear 0s;}
.mobile-menu-header{grid-area:header;position:relative;z-index:2;background:var(--cream);display:flex;justify-content:space-between;align-items:center;padding:1.15rem var(--pad);border-bottom:1px solid var(--line);}
.mobile-menu-brand{display:flex;align-items:center;gap:.7rem;}
.mobile-menu-logo{height:24px;width:auto;display:block;}
.mobile-menu-offer{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--serif);font-size:1rem;color:var(--ink);line-height:1;}
.mobile-menu-offer em{font-style:italic;color:var(--violet);}
.mobile-menu-close{width:38px;height:38px;display:flex;align-items:center;justify-content:center;padding:0;background:transparent;border:1px solid var(--line-strong);border-radius:.55rem;color:var(--ink);cursor:pointer;transition:all .2s var(--ease);}
.mobile-menu-close:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}
.mobile-menu-close svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.mobile-menu-nav{grid-area:nav;display:flex;flex-direction:column;align-items:flex-start;justify-content:space-evenly;padding:1.25rem var(--pad);gap:.4rem;overflow-y:auto;min-height:0;}
.mobile-menu-nav a{font-family:var(--serif);font-weight:400;font-size:clamp(1.45rem,5.5vw,2rem);line-height:1.12;color:var(--ink);transition:color .2s var(--ease);min-height:44px;display:inline-flex;align-items:center;}
.mobile-menu-nav a:hover,.mobile-menu-nav a:active{color:var(--violet);}
.mobile-menu-foot{grid-area:foot;display:flex;flex-direction:column;gap:1.1rem;padding:1.25rem var(--pad) calc(2rem + env(safe-area-inset-bottom,0px));}
.mobile-menu-cta{display:inline-flex;align-items:center;justify-content:center;padding:1rem 1.5rem;background:var(--ink);color:var(--cream);border-radius:999px;font-family:var(--sans);font-weight:500;font-size:.95rem;min-height:44px;transition:all .2s var(--ease);}
.mobile-menu-cta:hover{background:var(--violet);color:#fff;}
.mobile-menu-lang{align-self:flex-start;}
.mobile-menu-lang>*{padding:.6rem 1rem;min-height:44px;align-items:center;}
@media(prefers-reduced-motion:reduce){.mobile-menu{transition:visibility 0s;}.mobile-menu.is-open{transition:visibility 0s;}.nav-burger svg .line{transition:none;}}
/* Masquer le bouton "remonter en haut" quand le menu mobile est ouvert (évite le doublon avec le toggle FR/EN) */
.mobile-menu.is-open ~ .totop{opacity:0;visibility:hidden;pointer-events:none;}
/* ── Paysage mobile : menu structuré (header réancré + 2 colonnes), pattern pitch.saegus.ai ── */
@media (orientation:landscape) and (max-height:500px){
  .mobile-menu-header{padding:.5rem var(--pad);}
  .mobile-menu-logo{height:22px;}
  .mobile-menu-nav{display:grid;grid-template-columns:1fr 1fr;align-content:space-evenly;column-gap:2.5rem;row-gap:.4rem;padding:1rem var(--pad);overflow-y:auto;min-height:0;}
  .mobile-menu-nav a{font-size:1.02rem;line-height:1.1;min-height:0;}
  .mobile-menu-foot{border-left:none;padding:.75rem var(--pad) calc(.75rem + env(safe-area-inset-bottom,0px));}
  .mobile-menu-cta{padding:.7rem 1.25rem;font-size:.9rem;}
}

/* ── NAV LOGIN (pill secondaire on-brand) ── */
.nav-login{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.05rem;margin-left:2.5rem;background:transparent;color:var(--ink);border:1px solid var(--line-strong);border-radius:999px;font-family:var(--sans);font-size:.8rem;font-weight:500;letter-spacing:.02em;line-height:1;cursor:pointer;transition:all .2s var(--ease);}
.nav-login:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}
.nav-login .ms-logo{width:15px;height:15px;flex-shrink:0;display:block;}
.nav-login .login-mark{width:17px;height:17px;border-radius:50%;flex-shrink:0;display:block;}
/* Mode burger : login reste visible à côté du burger (le CTA, lui, passe dans le menu) */
@media(max-width:860px),(max-height:500px) and (orientation:landscape){nav .nav-login{margin-left:.6rem;}body[data-auth="in"] .nav-user{margin-left:.6rem;}}
@media(max-width:560px){.nav-login{padding:.55rem .65rem;}.nav-login span{display:none;}}

/* ── MOBILE MENU LOGIN ── */
.mobile-menu-login{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;padding:1rem 1.5rem;background:transparent;color:var(--ink);border:1px solid var(--line-strong);border-radius:999px;font-family:var(--sans);font-weight:500;font-size:.95rem;min-height:44px;cursor:pointer;transition:all .2s var(--ease);}
.mobile-menu-login:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}
.mobile-menu-login .ms-logo{width:16px;height:16px;flex-shrink:0;display:block;}
.mobile-menu-login .login-mark{width:18px;height:18px;border-radius:50%;flex-shrink:0;display:block;}

/* ── NAV USER (avatar + menu, visible une fois connecté) ── */
.nav-user{display:none;}
body[data-auth="in"] .nav-user{display:inline-flex;position:relative;margin-left:2.5rem;}
body[data-auth="in"] .nav-login{display:none;}
/* Mobile (≤860 / paysage court) : auth gérée dans le menu burger → masquer avatar + login du header */
@media(max-width:860px),(max-height:500px) and (orientation:landscape){nav .nav-login{display:none;}body[data-auth="in"] .nav-user{display:none;}}
.nav-user-btn{display:inline-flex;align-items:center;gap:.35rem;padding:0;background:transparent;border:0;cursor:pointer;line-height:0;}
.nav-user-avatar{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:var(--ink);color:var(--cream);font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.02em;line-height:1;flex-shrink:0;text-transform:uppercase;}
.nav-user-chev{width:16px;height:16px;color:var(--ink-soft);flex-shrink:0;transition:transform .2s var(--ease);}
.nav-user.open .nav-user-chev{transform:rotate(180deg);}
.nav-user-menu{display:none;position:absolute;top:calc(100% + 10px);right:0;min-width:240px;background:var(--cream);border:1px solid var(--line);border-radius:1rem;box-shadow:0 18px 50px -20px rgba(10,10,15,.4);padding:1rem 1.1rem;z-index:60;}
.nav-user.open .nav-user-menu{display:block;}
@media(prefers-reduced-motion:no-preference){.nav-user.open .nav-user-menu{animation:loginPop .2s var(--ease);}}
.nav-user-name{font-family:var(--sans);font-size:.9rem;font-weight:600;color:var(--ink);line-height:1.3;}
.nav-user-email{margin-top:.15rem;font-family:var(--sans);font-size:.8rem;color:var(--muted);line-height:1.3;overflow-wrap:anywhere;}
.nav-user-sep{height:1px;background:var(--line);margin:.85rem 0;}
.nav-user-logout{display:flex;align-items:center;gap:.55rem;width:100%;padding:0;background:transparent;border:0;cursor:pointer;font-family:var(--sans);font-size:.88rem;font-weight:500;color:var(--violet);line-height:1;transition:color .2s var(--ease);}
.nav-user-logout svg{width:18px;height:18px;flex-shrink:0;}
.nav-user-logout:hover{color:var(--violet-deep);}

/* ── MOBILE USER (bloc utilisateur dans le menu mobile) ── */
.mobile-user{display:none;}
body[data-auth="in"] .mobile-user{display:flex;align-items:center;gap:.75rem;}
body[data-auth="in"] .mobile-menu-login{display:none;}
.mobile-user-avatar{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--ink);color:var(--cream);font-family:var(--sans);font-size:.9rem;font-weight:600;line-height:1;flex-shrink:0;text-transform:uppercase;}
.mobile-user-id{flex:1;min-width:0;}
.mobile-user-name{font-family:var(--sans);font-size:.95rem;font-weight:600;color:var(--ink);line-height:1.3;}
.mobile-user-email{margin-top:.1rem;font-family:var(--sans);font-size:.8rem;color:var(--muted);line-height:1.3;overflow-wrap:anywhere;}
.mobile-user-logout{flex-shrink:0;padding:.55rem .9rem;background:transparent;border:1px solid var(--line-strong);border-radius:999px;cursor:pointer;font-family:var(--sans);font-size:.82rem;font-weight:500;color:var(--violet);line-height:1;transition:all .2s var(--ease);}
.mobile-user-logout:hover{color:var(--violet-deep);border-color:var(--violet);}
@media(prefers-reduced-motion:reduce){.nav-user-chev{transition:none;}.nav-user.open .nav-user-menu{animation:none;}}

/* ── LOGIN MODAL ── */
.login-modal{position:fixed;inset:0;z-index:400;display:none;align-items:center;justify-content:center;padding:var(--pad);}
.login-modal.is-open{display:flex;}
.login-overlay{position:absolute;inset:0;background:rgba(10,10,15,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);}
.login-card{position:relative;z-index:1;width:100%;max-width:460px;background:var(--cream);border:1px solid var(--line);border-radius:18px;box-shadow:0 24px 60px -12px rgba(10,10,15,.30),0 8px 24px -8px rgba(10,10,15,.18);padding:clamp(2rem,5vw,3rem) clamp(1.5rem,5vw,2.75rem) clamp(1.75rem,4vw,2.25rem);text-align:center;}
.login-close{position:absolute;top:1rem;right:1rem;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;padding:0;background:transparent;border:1px solid var(--line-strong);border-radius:.55rem;color:var(--ink);cursor:pointer;transition:all .2s var(--ease);}
.login-close:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}
.login-close svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.login-logo{height:26px;width:auto;display:block;margin:0 auto 1.6rem;}
.login-eyebrow{display:block;font-family:var(--sans);font-size:.72rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--violet);}
.login-title{font-family:var(--serif);font-weight:300;font-style:italic;font-size:clamp(1.9rem,4vw,2.4rem);line-height:1.05;letter-spacing:-.02em;color:var(--violet);margin-top:.6rem;}
.login-sub{max-width:34ch;margin:.75rem auto 0;font-size:.95rem;line-height:1.55;color:var(--muted);}
.login-ms{display:inline-flex;width:100%;align-items:center;justify-content:center;gap:.75rem;min-height:48px;margin-top:1.75rem;padding:1rem 1.5rem;background:var(--violet);color:var(--cream);border:0;border-radius:999px;font-family:var(--sans);font-size:.95rem;font-weight:600;line-height:1;cursor:pointer;transition:background .2s var(--ease),transform .2s var(--ease);}
.login-ms:hover{background:var(--violet-deep);transform:translateY(-1px);}
.login-ms .ms-logo{width:18px;height:18px;flex-shrink:0;display:block;}
.login-foot{margin-top:1.6rem;font-size:.75rem;color:var(--muted);}
.login-error{margin-top:.9rem;font-family:var(--sans);font-size:.82rem;line-height:1.4;color:var(--magenta);text-align:center;}
@media(prefers-reduced-motion:no-preference){
  .login-card{animation:loginPop .28s var(--ease);}
}
@keyframes loginPop{from{opacity:0;transform:translateY(8px) scale(.98);}to{opacity:1;transform:none;}}
@media(prefers-reduced-motion:reduce){.login-ms{transition:background .2s var(--ease);}.login-ms:hover{transform:none;}}

/* ── GATING (sections réservées) ── */
body:not([data-auth="in"]) [data-gated]{display:none;}
body:not([data-auth="in"]) .gated-link{display:none;}
@media(prefers-reduced-motion:no-preference){
  body[data-auth="in"] [data-gated]{animation:gatedReveal .5s var(--ease);}
}
@keyframes gatedReveal{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}

/* ── MISE EN AVANT des liens TOC / menu réservés (débloqués) ── */
/* Marqueur pastille magenta AVANT le label — usage ::before (le ::after porte l'underline) */
.toc a.gated-link{color:var(--violet);font-weight:600;}
.toc a.gated-link .toc-label{position:relative;}
.toc a.gated-link .toc-label::before{content:'';display:inline-block;width:7px;height:7px;margin-right:.45rem;border-radius:50%;background:var(--magenta);vertical-align:middle;box-shadow:0 0 0 3px rgba(255,46,136,.18);}
.toc a.gated-link:hover{color:var(--magenta);}
/* ticks des liens réservés alignés sur les ticks standards (pas de magenta au repos) */
/* l'état actif reste lisible : on garde le violet d'accent + tick large */
.toc a.gated-link.active{color:var(--violet);}
.toc a.gated-link.active .toc-tick{width:28px;background:var(--violet);}
.toc:hover a.gated-link.active .toc-tick{background:var(--violet);}

/* Menu mobile : même signalétique débloqué */
.mobile-menu-nav a.gated-link{color:var(--violet);}
.mobile-menu-nav a.gated-link::before{content:'';display:inline-block;width:8px;height:8px;margin-right:.5rem;border-radius:50%;background:var(--magenta);vertical-align:middle;box-shadow:0 0 0 3px rgba(255,46,136,.18);}
.mobile-menu-nav a.gated-link:hover,.mobile-menu-nav a.gated-link:active{color:var(--magenta);}

/* Animation d'entrée quand les liens réservés apparaissent (connexion) */
@media(prefers-reduced-motion:no-preference){
  body[data-auth="in"] .toc a.gated-link{animation:gatedLinkIn .55s var(--ease) both;}
  body[data-auth="in"] .toc a.gated-link .toc-label::before,
  body[data-auth="in"] .mobile-menu-nav a.gated-link::before{animation:gatedDotPulse 1.1s var(--ease) .45s 2;}
}
@keyframes gatedLinkIn{from{opacity:0;transform:translateX(10px);}to{opacity:1;transform:none;}}
@keyframes gatedDotPulse{0%,100%{box-shadow:0 0 0 3px rgba(255,46,136,.18);}50%{box-shadow:0 0 0 6px rgba(255,46,136,.32);}}
@media(prefers-reduced-motion:reduce){
  body[data-auth="in"] .toc a.gated-link{animation:none;}
  body[data-auth="in"] .toc a.gated-link .toc-label::before,
  body[data-auth="in"] .mobile-menu-nav a.gated-link::before{animation:none;}
}
