/* === GROWTH CONSULT — DESIGN SYSTEM MANGA BRUT === */
:root{
  --paper:#F1ECDF; --panel:#FBF9F1; --ink:#15120B; --red:#E12C22;
  --navy:#1E3A5F; --ink-dim:#3A3220; --bw:3px; --accent:var(--red);
}

/* =========================================================
   === DARK MODE — REFACTOR PROPRE                       ===
   === Stratégie :                                       ===
   === - Le background "page" bascule clair → sombre     ===
   === - Les éléments "naturellement sombres" RESTENT     ===
   ===   sombres (footer, hero dark, dark cards)         ===
   === - Le texte par défaut bascule sombre → clair      ===
   === - Les gris bas-contraste sont rehaussés           ===
   ========================================================= */
html[data-theme="dark"]{
  --paper:#0E0C07;
  --panel:#1A1610;
  --ink:#F1ECDF;
  --red:#FF4A40;
  --navy:#6BA6D6;
  --ink-dim:#C9C2B0;
  color-scheme:dark;
}
html[data-theme="dark"] body{background:#0E0C07;color:#F1ECDF;}

/* --- 1) Texte par défaut : tout ce qui n'est pas dans une zone "dark" passe en clair --- */
html[data-theme="dark"] h1,
html[data-theme="dark"] h2,
html[data-theme="dark"] h3,
html[data-theme="dark"] h4,
html[data-theme="dark"] h5{color:#F8F4E8;}
html[data-theme="dark"] p,
html[data-theme="dark"] li,
html[data-theme="dark"] dd,
html[data-theme="dark"] dt,
html[data-theme="dark"] td,
html[data-theme="dark"] th,
html[data-theme="dark"] label{color:#E8E2D2;}
html[data-theme="dark"] body > p,
html[data-theme="dark"] section p,
html[data-theme="dark"] section li,
html[data-theme="dark"] .slead,
html[data-theme="dark"] .sub,
html[data-theme="dark"] .lead{color:#E8E2D2;}
html[data-theme="dark"] b,
html[data-theme="dark"] strong{color:#FFFFFF;}
html[data-theme="dark"] a{color:inherit;}
html[data-theme="dark"] a:hover{color:#FF4A40;}

/* --- 2) Sections / cartes claires en light → sombres en dark --- */
html[data-theme="dark"] section[style*="background:var(--panel)"],
html[data-theme="dark"] section[style*="background:var(--paper)"]{background:#0E0C07 !important;}
html[data-theme="dark"] [style*="background:var(--paper)"]:not(section){background:#0E0C07 !important;}
html[data-theme="dark"] [style*="background:#FBF9F1"]{background:#1A1610 !important;}
html[data-theme="dark"] [style*="background:#F1ECDF"]{background:#0E0C07 !important;}
html[data-theme="dark"] [style*="background:#EDE2C9"]{background:#241E15 !important;}
html[data-theme="dark"] [style*="background:#f3f0e8"],
html[data-theme="dark"] [style*="background:#F3F0E8"]{background:#1A1610 !important;}

/* --- 3) Sections / cartes naturellement SOMBRES : on les garde sombres --- */
/* Le pattern "background:var(--ink)" dans un attribut style est sensé être SOMBRE.
   En dark mode, var(--ink) bascule en clair, donc on force le sombre. */
html[data-theme="dark"] section[style*="background:var(--ink)"],
html[data-theme="dark"] [style*="background:var(--ink)"]:not(section){background:#1A1610 !important;color:#F1ECDF !important;}
html[data-theme="dark"] [style*="background:#15120B"]{background:#1A1610 !important;}
html[data-theme="dark"] [style*="background:#2A241A"]{background:#221C13 !important;}
html[data-theme="dark"] [style*="background:#262119"]{background:#221C13 !important;}
html[data-theme="dark"] [style*="background:var(--ink-dim)"]{background:#3D3829 !important;color:#F1ECDF !important;}
/* Dans ces zones sombres, le texte hardcodé en gris-beige clair RESTE valide → ne rien override */

/* === BUG MAJEUR : color:var(--paper) est utilisé comme TEXTE CLAIR sur fond sombre === */
/* En light: --paper = #F1ECDF (clair) → ok texte clair sur fond sombre */
/* En dark: --paper bascule en #0E0C07 (sombre) → texte invisible sur fond sombre ! */
/* Fix : forcer ces textes à rester clairs en dark mode */
html[data-theme="dark"] [style*="color:var(--paper)"]{color:#F1ECDF !important;}
html[data-theme="dark"] [style*="color: var(--paper)"]{color:#F1ECDF !important;}
html[data-theme="dark"] [style*="color:#F1ECDF"]{color:#F1ECDF !important;}
html[data-theme="dark"] [style*="color:#FBF9F1"]{color:#FBF9F1 !important;}
/* Idem pour les textes hardcodés en clair (style="color:#paper-like;") */
html[data-theme="dark"] [style*="color:#F8F4E8"]{color:#F8F4E8 !important;}
/* Et le color:#15120B (encre foncée) doit basculer en clair en dark */
html[data-theme="dark"] [style*="color:#15120B"]{color:#F1ECDF !important;}
html[data-theme="dark"] [style*="color:var(--ink)"]:not([style*="background:var(--ink)"]):not([style*="background:#1A"]):not([style*="background:#0E"]){color:#F1ECDF !important;}

/* --- 4) FOOTER : naturellement sombre, doit le rester en dark --- */
html[data-theme="dark"] .bigfoot,
html[data-theme="dark"] footer.bigfoot{background:#0A0805 !important;color:#F1ECDF !important;border-top-color:#241E15 !important;}
html[data-theme="dark"] .bigfoot .fcol h4{color:#F1ECDF !important;}
html[data-theme="dark"] .bigfoot .fcol a{color:#D4CFC0 !important;}
html[data-theme="dark"] .bigfoot .fcol a:hover{color:#FF4A40 !important;}
html[data-theme="dark"] .bigfoot .flogo{color:#F1ECDF !important;}
html[data-theme="dark"] .bigfoot .ftag{color:#C9C2B0 !important;}
html[data-theme="dark"] .bigfoot .fnews-note,
html[data-theme="dark"] .bigfoot .fnews-alt .fnews-or,
html[data-theme="dark"] .bigfoot .fbottom,
html[data-theme="dark"] .bigfoot .flinks a{color:#C9C2B0 !important;}
html[data-theme="dark"] .bigfoot .fbottom{border-top-color:#3A3625 !important;}
html[data-theme="dark"] .bigfoot .fbig{border-color:#5B5648 !important;}
html[data-theme="dark"] .bigfoot .fbig-msg p{color:#F1ECDF !important;}
html[data-theme="dark"] .bigfoot .fnews-form{border-color:#F1ECDF !important;}
html[data-theme="dark"] .bigfoot .fnews-form input{background:#241E15 !important;color:#F1ECDF !important;}
html[data-theme="dark"] .bigfoot .fnews-alt a{color:#F1ECDF !important;border-color:#F1ECDF !important;}

/* --- 5) Couleurs grises hardcodées (texte) qui sont sur fond CLAIR par défaut → bump contraste --- */
/* Attention : si la couleur est sur fond sombre (footer etc.), elle reste OK telle quelle.
   Ces selectors ciblent les usages hors zones explicitement sombres. */
html[data-theme="dark"] body > *:not(.bigfoot) [style*="color:#5B5648"],
html[data-theme="dark"] body > *:not(.bigfoot) [style*="color:#3A3625"]{color:#E8E2D2 !important;}
html[data-theme="dark"] [style*="color:var(--ink-dim)"]{color:#C9C2B0 !important;}

/* --- 6) NAV en dark --- */
html[data-theme="dark"] nav{background:#0E0C07;border-bottom-color:#241E15;}
html[data-theme="dark"] .navdrop-menu,
html[data-theme="dark"] .navdrop-menu-mini{background:#0E0C07;border-color:#F1ECDF;box-shadow:6px 6px 0 #241E15;}
html[data-theme="dark"] .navdrop-h{color:#FF4A40;border-bottom-color:#3A3625;}
html[data-theme="dark"] .navdrop-col a{color:#E8E2D2;}
html[data-theme="dark"] .navdrop-col a:hover{color:#FF4A40;}
html[data-theme="dark"] .navlinks > a:hover,
html[data-theme="dark"] .navlinks > a.cur{color:#FF4A40;}
html[data-theme="dark"] .navburger span{background:#F1ECDF;}
html[data-theme="dark"] .logo .htag{background:#FF4A40;color:#0E0C07;}

/* --- 7) BTN, CTA, kicker en dark --- */
html[data-theme="dark"] .kicker{background:#F1ECDF;color:#0E0C07;}
html[data-theme="dark"] .btn{border-color:#F1ECDF;box-shadow:6px 6px 0 #241E15;}
html[data-theme="dark"] .btn-primary{background:#FF4A40;color:#0E0C07;}
html[data-theme="dark"] .btn-primary:hover{box-shadow:9px 9px 0 #241E15;}
html[data-theme="dark"] .navcta{box-shadow:4px 4px 0 #241E15 !important;}

/* --- 8) Cards SIGMAGIA / Manga --- */
html[data-theme="dark"] .sg-stat{background:#1A1610 !important;border-color:#F1ECDF;box-shadow:5px 5px 0 #241E15;}
html[data-theme="dark"] .sg-stat .l{color:#E8E2D2;}
html[data-theme="dark"] .sg-stat .s{color:#C9C2B0;}
html[data-theme="dark"] .fnder{background:#1A1610;border-color:#F1ECDF;box-shadow:6px 6px 0 #6BA6D6;color:#E8E2D2;}
html[data-theme="dark"] .fnder p{color:#E8E2D2 !important;}
html[data-theme="dark"] .fnder h3{color:#F8F4E8 !important;}
html[data-theme="dark"] .fnder[style*="repeating-linear-gradient"]{background:repeating-linear-gradient(45deg,#1A1610 0,#1A1610 10px,#241E15 10px,#241E15 20px) !important;}
html[data-theme="dark"] .fnder h3[style*="color:var(--ink-dim)"]{color:#C9C2B0 !important;}
html[data-theme="dark"] .fnder .badge[style*="background:var(--ink-dim)"]{background:#3D3829 !important;color:#F1ECDF !important;}
html[data-theme="dark"] .mod-tile{background:#1A1610;border-color:#F1ECDF;box-shadow:6px 6px 0 #FF4A40;}
html[data-theme="dark"] .mod-tile p{color:#E8E2D2;}
html[data-theme="dark"] .mod-tile:nth-child(3n+2){box-shadow:6px 6px 0 #6BA6D6;}
html[data-theme="dark"] .tgt{background:#1A1610;border-color:#F1ECDF;color:#E8E2D2;}
html[data-theme="dark"] .tgt p{color:#E8E2D2;}
html[data-theme="dark"] .panel{background:#1A1610;border-color:#F1ECDF;box-shadow:6px 6px 0 #FF4A40;color:#E8E2D2;}
html[data-theme="dark"] .panel p{color:#E8E2D2;}
html[data-theme="dark"] .split-box{border-color:#F1ECDF;box-shadow:7px 7px 0 #FF4A40;}
html[data-theme="dark"] .split-bad{background:#1A1610;border-right-color:#F1ECDF;color:#E8E2D2;}
html[data-theme="dark"] .split-good{background:#F1ECDF;color:#0E0C07;}
html[data-theme="dark"] .split-good .shd,
html[data-theme="dark"] .split-good li,
html[data-theme="dark"] .split-good b{color:#0E0C07 !important;}
html[data-theme="dark"] .name-decomp span{background:#1A1610;border-color:#F1ECDF;box-shadow:4px 4px 0 #F1ECDF;color:#F1ECDF;}
html[data-theme="dark"] .name-decomp span.red{background:#FF4A40;color:#0E0C07;}
html[data-theme="dark"] .name-decomp span.navy{background:#6BA6D6;color:#0E0C07;}
html[data-theme="dark"] .sigma-form{background:#1A1610;border-color:#F1ECDF;}
html[data-theme="dark"] .sigma-form input{background:transparent;color:#F1ECDF;}
html[data-theme="dark"] .sigma-form button{background:#F1ECDF;color:#0E0C07;}
html[data-theme="dark"] .sigma-form button:hover{background:#FF4A40;color:#0E0C07;}
html[data-theme="dark"] .fnder .stealth-badge{background:#FF4A40;color:#0E0C07;border-color:#F1ECDF;box-shadow:3px 3px 0 #F1ECDF;}
html[data-theme="dark"] .fnder .reveal-line{color:#F1ECDF;border-top-color:#F1ECDF;}

/* --- 9) TLDR / aside / dashes borders --- */
html[data-theme="dark"] .tldr{background:#1A1610 !important;border-color:#F1ECDF !important;color:#E8E2D2;box-shadow:5px 5px 0 #6BA6D6 !important;}
html[data-theme="dark"] .tldr .tldr-k{background:#FF4A40 !important;color:#0E0C07 !important;}
html[data-theme="dark"] .tldr .tldr-v,html[data-theme="dark"] .tldr .tldr-v b{color:#F1ECDF !important;}
html[data-theme="dark"] .tldr .tldr-tag{color:#0E0C07 !important;background:#F1ECDF !important;}
html[data-theme="dark"] .tldr .tldr-sub{color:#C9C2B0 !important;}
html[data-theme="dark"] .tldr .tldr-row{border-bottom-color:#3A3625 !important;}
html[data-theme="dark"] [style*="border:2px dashed var(--ink)"],
html[data-theme="dark"] [style*="border:2px dashed #5B5648"]{border-color:#F1ECDF !important;}
html[data-theme="dark"] [style*="border:var(--bw) solid var(--ink)"]{border-color:#F1ECDF !important;}

/* ============================================================
   === EGGPOP — popups des easter eggs (RESTAURÉ)
   === Position : toast bas-centre, ne masque PAS Tanu en bas-droite
   ============================================================ */
.eggpop{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);z-index:9700;display:flex;align-items:flex-end;justify-content:center;pointer-events:none;}
.eggpop[hidden]{display:none;}
.eggpop-card{display:flex;align-items:flex-end;gap:8px;max-width:460px;pointer-events:auto;animation:eggin .25s cubic-bezier(.34,1.56,.64,1);}
@keyframes eggin{from{transform:translateY(30px) scale(.92);opacity:0;}to{transform:none;opacity:1;}}
.eggpop-mascot{flex-shrink:0;background:var(--paper);border:var(--bw) solid var(--ink);padding:6px;box-shadow:4px 4px 0 var(--ink);}
.eggpop-mascot svg{display:block;}
.eggpop-bubble{position:relative;background:var(--panel);border:var(--bw) solid var(--ink);border-radius:18px;padding:16px 40px 16px 20px;box-shadow:6px 6px 0 var(--ink);max-width:340px;}
.eggpop-bubble::after{content:"";position:absolute;left:-15px;bottom:18px;border:9px solid transparent;border-right-color:var(--ink);border-left:0;}
.eggpop-bubble::before{content:"";position:absolute;left:-11px;bottom:21px;border:7px solid transparent;border-right-color:var(--panel);border-left:0;z-index:2;}
.eggname{font-family:'Anton';font-size:17px;text-transform:uppercase;color:var(--red);letter-spacing:0.04em;line-height:1;}
.eggmsg{font-family:'Space Grotesk';font-size:13.5px;color:var(--ink);margin-top:8px;line-height:1.5;}
.eggpop-close{position:absolute;top:8px;right:8px;width:28px;height:28px;background:var(--ink);color:var(--paper);border:none;font-family:'Anton';font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;padding-bottom:3px;border-radius:50%;transition:background .15s ease,transform .15s ease;box-shadow:2px 2px 0 var(--red);}
.eggpop-close:hover{background:var(--red);transform:scale(1.08);}

/* Tanu : on lui baisse l'opacité quand un eggpop est visible (pas de chevauchement gênant) */
body:has(.eggpop:not([hidden])) .tanu-chat-bubble{opacity:.35;pointer-events:none;}

/* Mobile : eggpop pleine largeur avec marges, Tanu se cache temporairement */
@media (max-width:600px){
  .eggpop{left:12px;right:12px;bottom:14px;transform:none;}
  .eggpop-card{max-width:100%;}
  .eggpop-bubble{max-width:calc(100% - 80px);}
  body:has(.eggpop:not([hidden])) .tanu-chat-bubble{display:none;}
}

/* Dark mode eggpop */
html[data-theme="dark"] .eggpop-mascot{background:#1A1610;border-color:#F1ECDF;box-shadow:4px 4px 0 #F1ECDF;}
html[data-theme="dark"] .eggpop-bubble{background:#1A1610;border-color:#F1ECDF;box-shadow:6px 6px 0 #F1ECDF;color:#F1ECDF;}
html[data-theme="dark"] .eggpop-bubble::after{border-right-color:#F1ECDF;}
html[data-theme="dark"] .eggpop-bubble::before{border-right-color:#1A1610;}
html[data-theme="dark"] .eggname{color:#FF4A40;}
html[data-theme="dark"] .eggmsg{color:#E8E2D2;}
html[data-theme="dark"] .eggpop-close{background:#F1ECDF;color:#0E0C07;box-shadow:2px 2px 0 #FF4A40;}
html[data-theme="dark"] .eggpop-close:hover{background:#FF4A40;color:#F1ECDF;}

/* ============================================================
   === CHATBOT TANU (FAQ + boutons scripté, Manga Brut style)
   ============================================================ */
.tanu-chat-bubble{position:fixed;bottom:22px;right:22px;width:76px;height:76px;background:var(--paper);border:var(--bw) solid var(--ink);box-shadow:5px 5px 0 var(--red);cursor:pointer;z-index:9500;padding:4px 4px 0;display:flex;align-items:flex-end;justify-content:center;transition:transform .18s ease,box-shadow .18s ease;border-radius:0;overflow:visible;}
.tanu-chat-bubble:hover{transform:translate(-3px,-3px);box-shadow:8px 8px 0 var(--red);}
.tanu-chat-bubble svg{width:62px;height:auto;display:block;}
.tanu-chat-bubble.hidden{display:none;}
.tanu-chat-bubble .tcb-dot{position:absolute;top:-6px;right:-6px;width:14px;height:14px;background:var(--red);border:2px solid var(--paper);border-radius:50%;animation:tcbPulse 1.8s infinite;z-index:2;}
@keyframes tcbPulse{0%,100%{transform:scale(1);}50%{transform:scale(1.35);}}
.tanu-chat-bubble.pulse{animation:tcbBig 0.6s ease-out 0s 4;}
@keyframes tcbBig{0%,100%{transform:translate(0,0) rotate(0);}25%{transform:translate(-2px,-3px) rotate(-4deg);}75%{transform:translate(-2px,-3px) rotate(4deg);}}
/* Bulle "?" au-dessus de la tête de Tanu */
.tanu-chat-bubble .tcb-question{position:absolute;top:-22px;left:-16px;width:34px;height:34px;background:var(--paper);color:var(--red);border:2.5px solid var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Anton','Bangers',sans-serif;font-size:22px;font-weight:bold;box-shadow:3px 3px 0 var(--ink);animation:tcbBubble 2.4s ease-in-out infinite;line-height:1;padding-bottom:2px;}
.tanu-chat-bubble .tcb-question::after{content:"";position:absolute;bottom:-9px;right:6px;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:9px solid var(--ink);}
.tanu-chat-bubble .tcb-question::before{content:"";position:absolute;bottom:-6px;right:7px;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:7px solid var(--paper);z-index:2;}
@keyframes tcbBubble{0%,100%{transform:translateY(0) rotate(-6deg);}50%{transform:translateY(-4px) rotate(-2deg);}}

.tanu-chat-panel{position:fixed;bottom:22px;right:22px;width:380px;max-width:calc(100vw - 36px);max-height:min(620px,calc(100vh - 80px));background:var(--paper);border:var(--bw) solid var(--ink);box-shadow:7px 7px 0 var(--red);z-index:9600;display:none;flex-direction:column;overflow:hidden;font-family:'Inter',sans-serif;}
.tanu-chat-panel.open{display:flex;animation:tcpIn .22s ease-out;}
@keyframes tcpIn{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}

.tcp-head{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--ink);color:var(--paper);border-bottom:var(--bw) solid var(--ink);position:relative;}
.tcp-avatar{flex-shrink:0;width:50px;height:50px;background:var(--paper);border:2px solid var(--paper);display:flex;align-items:flex-end;justify-content:center;overflow:hidden;padding:3px 2px 0;}
.tcp-avatar svg{width:42px;height:auto;display:block;}
.tcp-meta{flex:1;min-width:0;}
.tcp-name{font-family:'Anton';font-size:20px;text-transform:uppercase;letter-spacing:0.04em;line-height:1;}
.tcp-role{font-family:'Space Mono';font-size:10.5px;font-weight:700;letter-spacing:0.08em;color:#C8C3B2;margin-top:4px;text-transform:uppercase;display:flex;align-items:center;gap:6px;}
.tcp-online{width:7px;height:7px;border-radius:50%;background:#3FCF8E;display:inline-block;}
.tcp-close{background:transparent;border:none;color:var(--paper);font-size:30px;cursor:pointer;line-height:1;padding:0 4px;}
.tcp-close:hover{color:var(--red);}

.tcp-body{flex:1;overflow-y:auto;padding:16px;background:var(--panel);display:flex;flex-direction:column;gap:10px;scrollbar-width:thin;scrollbar-color:var(--ink-dim) var(--panel);}
.tcp-body::-webkit-scrollbar{width:6px;}
.tcp-body::-webkit-scrollbar-thumb{background:var(--ink-dim);}

.tcp-msg{padding:10px 14px;border:1.5px solid var(--ink);max-width:88%;font-family:'Space Grotesk';font-size:14px;line-height:1.5;}
.tcp-msg.bot{align-self:flex-start;background:var(--paper);box-shadow:3px 3px 0 var(--ink);}
.tcp-msg.user{align-self:flex-end;background:var(--ink);color:var(--paper);box-shadow:3px 3px 0 var(--red);}
.tcp-msg.user b{color:var(--paper);}
.tcp-msg b{font-weight:700;color:var(--ink);}
.tcp-typing{display:flex;gap:5px;padding:14px 16px;}
.tcp-typing span{width:8px;height:8px;background:var(--ink);border-radius:50%;animation:tcpTyp 1.2s infinite;}
.tcp-typing span:nth-child(2){animation-delay:.2s;}
.tcp-typing span:nth-child(3){animation-delay:.4s;}
@keyframes tcpTyp{0%,60%,100%{opacity:.3;transform:translateY(0);}30%{opacity:1;transform:translateY(-4px);}}

.tcp-menu{align-self:stretch;display:flex;flex-direction:column;gap:6px;margin-top:6px;}
.tcp-menu-h{font-family:'Space Mono';font-size:10.5px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:4px;}
.tcp-q{text-align:left;background:var(--paper);border:1.5px solid var(--ink);padding:10px 12px;font-family:'Space Grotesk';font-size:13.5px;font-weight:500;color:var(--ink);cursor:pointer;line-height:1.4;transition:transform .12s ease,box-shadow .12s ease,background .15s ease;}
.tcp-q:hover{background:var(--red);color:var(--paper);transform:translateX(-2px);box-shadow:3px 0 0 var(--ink);}

.tcp-cta-wrap{margin-top:10px;display:flex;flex-direction:column;gap:6px;}
.tcp-cta-btn{display:block;background:var(--red);color:var(--paper);text-decoration:none;padding:8px 12px;font-family:'Space Grotesk';font-size:13px;font-weight:700;border:1.5px solid var(--ink);box-shadow:2px 2px 0 var(--ink);transition:transform .12s ease,box-shadow .12s ease;}
.tcp-cta-btn:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--ink);}

.tcp-more{align-self:center;margin-top:4px;}
.tcp-more-btn{background:transparent;border:1.5px dashed var(--ink-dim);font-family:'Space Mono';font-size:11px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink);padding:6px 12px;cursor:pointer;}
.tcp-more-btn:hover{background:var(--ink);color:var(--paper);border-color:var(--ink);}

.tcp-actions{display:flex;gap:6px;padding:10px 12px;border-top:var(--bw) solid var(--ink);background:var(--paper);}
.tcp-cta{flex:1;text-align:center;background:var(--paper);border:2px solid var(--ink);padding:9px 8px;font-family:'Space Grotesk';font-size:12px;font-weight:700;color:var(--ink);text-decoration:none;box-shadow:3px 3px 0 var(--ink);transition:transform .12s ease,box-shadow .12s ease;cursor:pointer;}
.tcp-cta:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink);}
.tcp-cta.primary{background:var(--red);color:var(--paper);box-shadow:3px 3px 0 var(--ink);}
.tcp-mail-btn{font-family:'Space Grotesk';font-weight:700;font-size:12px;}

/* Mini-formulaire contact dans le chatbot */
.tcp-contact-form{align-self:stretch;background:var(--paper);border:2px solid var(--ink);padding:14px;display:flex;flex-direction:column;gap:10px;box-shadow:4px 4px 0 var(--red);margin-top:4px;}
.tcp-contact-form label{display:flex;flex-direction:column;gap:4px;font-family:'Space Mono';font-size:10.5px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink);}
.tcp-contact-form input,
.tcp-contact-form textarea{font-family:'Space Grotesk';font-size:13.5px;font-weight:500;padding:8px 10px;border:1.5px solid var(--ink);background:var(--panel);color:var(--ink);outline:none;resize:vertical;}
.tcp-contact-form input:focus,
.tcp-contact-form textarea:focus{background:var(--paper);box-shadow:2px 2px 0 var(--red);}
.tcp-contact-form textarea{min-height:80px;font-family:'Inter',sans-serif;text-transform:none;letter-spacing:0;font-weight:400;}
.tcp-form-submit{background:var(--red);color:var(--paper);border:2px solid var(--ink);padding:10px;font-family:'Anton';font-size:16px;text-transform:uppercase;letter-spacing:0.04em;cursor:pointer;box-shadow:3px 3px 0 var(--ink);transition:transform .12s ease,box-shadow .12s ease;margin-top:4px;}
.tcp-form-submit:hover:not(:disabled){transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink);}
.tcp-form-submit:disabled{opacity:0.6;cursor:wait;}
.tcp-form-note{font-family:'Space Mono';font-size:10px;letter-spacing:0.06em;color:var(--ink-dim);text-align:center;text-transform:uppercase;}

/* Dark mode du form */
html[data-theme="dark"] .tcp-contact-form{background:#1A1610;border-color:#F1ECDF;box-shadow:4px 4px 0 #FF4A40;}
html[data-theme="dark"] .tcp-contact-form label{color:#F1ECDF;}
html[data-theme="dark"] .tcp-contact-form input,
html[data-theme="dark"] .tcp-contact-form textarea{background:#0E0C07;color:#F1ECDF;border-color:#F1ECDF;}
html[data-theme="dark"] .tcp-contact-form input:focus,
html[data-theme="dark"] .tcp-contact-form textarea:focus{background:#241E15;box-shadow:2px 2px 0 #FF4A40;}
html[data-theme="dark"] .tcp-form-submit{background:#FF4A40;color:#0E0C07;border-color:#F1ECDF;box-shadow:3px 3px 0 #F1ECDF;}
html[data-theme="dark"] .tcp-form-submit:hover:not(:disabled){box-shadow:5px 5px 0 #F1ECDF;}
html[data-theme="dark"] .tcp-form-note{color:#C9C2B0;}

/* Décale le toggle dark mode pour éviter conflit avec bulle Tanu (gauche pour le toggle, droite pour Tanu) */
.theme-toggle{left:18px;right:auto;}

/* Mobile */
@media (max-width:480px){
  .tanu-chat-bubble{width:58px;height:58px;bottom:14px;right:14px;}
  .tanu-chat-bubble svg{width:42px;height:42px;}
  .tanu-chat-panel{bottom:0;right:0;left:0;width:100%;max-width:100%;max-height:80vh;border-bottom:none;}
}

/* Dark mode chatbot */
html[data-theme="dark"] .tanu-chat-bubble{background:#F1ECDF;border-color:#F1ECDF;box-shadow:5px 5px 0 #FF4A40;}
html[data-theme="dark"] .tanu-chat-bubble:hover{box-shadow:8px 8px 0 #FF4A40;}
html[data-theme="dark"] .tanu-chat-panel{background:#0E0C07;border-color:#F1ECDF;box-shadow:7px 7px 0 #FF4A40;}
html[data-theme="dark"] .tcp-head{background:#1A1610;border-bottom-color:#F1ECDF;color:#F1ECDF;}
html[data-theme="dark"] .tcp-avatar{background:#F1ECDF;border-color:#F1ECDF;}
html[data-theme="dark"] .tcp-role{color:#C9C2B0;}
html[data-theme="dark"] .tcp-body{background:#0E0C07;scrollbar-color:#3A3625 #0E0C07;}
html[data-theme="dark"] .tcp-msg{border-color:#F1ECDF;}
html[data-theme="dark"] .tcp-msg.bot{background:#1A1610;color:#F1ECDF;box-shadow:3px 3px 0 #F1ECDF;}
html[data-theme="dark"] .tcp-msg.bot b{color:#F1ECDF;}
html[data-theme="dark"] .tcp-msg.user{background:#F1ECDF;color:#0E0C07;box-shadow:3px 3px 0 #FF4A40;}
html[data-theme="dark"] .tcp-msg.user b{color:#0E0C07;}
html[data-theme="dark"] .tcp-typing span{background:#F1ECDF;}
html[data-theme="dark"] .tcp-menu-h{color:#C9C2B0;}
html[data-theme="dark"] .tcp-q{background:#1A1610;border-color:#F1ECDF;color:#F1ECDF;}
html[data-theme="dark"] .tcp-q:hover{background:#FF4A40;color:#0E0C07;}
html[data-theme="dark"] .tcp-cta-btn{background:#FF4A40;color:#0E0C07;border-color:#F1ECDF;box-shadow:2px 2px 0 #F1ECDF;}
html[data-theme="dark"] .tcp-cta-btn:hover{box-shadow:4px 4px 0 #F1ECDF;}
html[data-theme="dark"] .tcp-more-btn{color:#F1ECDF;border-color:#3A3625;}
html[data-theme="dark"] .tcp-more-btn:hover{background:#F1ECDF;color:#0E0C07;border-color:#F1ECDF;}
html[data-theme="dark"] .tcp-actions{background:#1A1610;border-top-color:#F1ECDF;}
html[data-theme="dark"] .tcp-cta{background:#1A1610;color:#F1ECDF;border-color:#F1ECDF;box-shadow:3px 3px 0 #F1ECDF;}
html[data-theme="dark"] .tcp-cta:hover{box-shadow:5px 5px 0 #F1ECDF;}
html[data-theme="dark"] .tcp-cta.primary{background:#FF4A40;color:#0E0C07;}

/* === SECTION 100+ AGENTS IA === */
.agents-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;}
.agent-cat{background:#2A241A;border:2.5px solid var(--paper);padding:22px 22px 18px;position:relative;box-shadow:5px 5px 0 var(--red);transition:transform .16s ease,box-shadow .16s ease;}
.agent-cat:hover{transform:translate(-3px,-3px);box-shadow:8px 8px 0 var(--red);}
.agent-cat .ac-icon{font-size:30px;line-height:1;margin-bottom:8px;}
.agent-cat .ac-name{font-family:'Anton';font-size:24px;text-transform:uppercase;color:var(--paper);letter-spacing:0.02em;line-height:1.1;}
.agent-cat .ac-list{font-family:'Space Grotesk';font-size:13.5px;color:#D9D4C4;line-height:1.55;margin-top:10px;}
.agent-cat .ac-count{position:absolute;top:-12px;right:-10px;background:var(--red);color:var(--paper);font-family:'Space Mono';font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;padding:4px 9px;border:2px solid var(--paper);box-shadow:2px 2px 0 var(--paper);}
.agstat{background:#2A241A;border:2px solid var(--paper);padding:20px 22px;text-align:left;}
.agstat .agnum{font-family:'Anton';font-size:42px;color:var(--red);line-height:1;-webkit-text-stroke:1.5px var(--paper);}
.agstat .aglbl{font-family:'Space Grotesk';font-weight:600;font-size:13.5px;color:#D9D4C4;margin-top:8px;line-height:1.4;}
@media (max-width:880px){.agents-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.agents-grid{grid-template-columns:1fr;}}

/* Variante compacte pour pages offres/accompagnement/pilotage */
.agents-mini{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:center;background:var(--ink);color:var(--paper);padding:24px 26px;border:var(--bw) solid var(--ink);box-shadow:7px 7px 0 var(--red);margin-top:34px;}
.agents-mini .am-num{font-family:'Anton';font-size:clamp(54px,7vw,84px);color:var(--red);line-height:1;-webkit-text-stroke:2px var(--paper);}
.agents-mini .am-body{display:flex;flex-direction:column;gap:8px;}
.agents-mini .am-tag{font-family:'Space Mono';font-size:11px;font-weight:700;letter-spacing:0.13em;text-transform:uppercase;color:var(--red);}
.agents-mini .am-head{font-family:'Anton';font-size:24px;text-transform:uppercase;color:var(--paper);line-height:1.05;}
.agents-mini .am-desc{font-family:'Space Grotesk';font-size:14.5px;line-height:1.5;color:#D9D4C4;}
.agents-mini .am-desc b{color:var(--paper);}
@media (max-width:640px){.agents-mini{grid-template-columns:1fr;gap:8px;padding:22px;}.agents-mini .am-num{font-size:48px;}}

/* Dark mode agents */
html[data-theme="dark"] .agent-cat,html[data-theme="dark"] .agstat{background:#221C13;border-color:#F1ECDF;}
html[data-theme="dark"] .agent-cat{box-shadow:5px 5px 0 #FF4A40;}
html[data-theme="dark"] .agent-cat:hover{box-shadow:8px 8px 0 #FF4A40;}
html[data-theme="dark"] .agent-cat .ac-name{color:#F1ECDF;}
html[data-theme="dark"] .agent-cat .ac-count{background:#FF4A40;color:#0E0C07;border-color:#F1ECDF;}
html[data-theme="dark"] .agstat .agnum{color:#FF4A40;-webkit-text-stroke:1.5px #F1ECDF;}
html[data-theme="dark"] .agents-mini{background:#1A1610;box-shadow:7px 7px 0 #FF4A40;}
html[data-theme="dark"] .agents-mini .am-num{color:#FF4A40;}

/* === L'ESSENTIEL · ENCART ÉDITORIAL MANGA BRUT === */
/* Design : encart léger, bordure latérale rouge épaisse, sans bandeau lourd.
   S'intègre comme une fiche d'info entre les sections, sans casser le flow. */
.essentiel{position:relative;background:transparent;border:none;padding:18px 0 18px 26px;margin:36px 0;max-width:760px;}
.essentiel::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--red);}
.essentiel-head{display:flex;align-items:baseline;gap:10px;margin-bottom:14px;flex-wrap:wrap;}
.essentiel-star{font-family:'Anton';font-size:20px;color:var(--red);line-height:1;transform:translateY(2px);}
.essentiel-title{font-family:'Anton';font-size:22px;letter-spacing:0.02em;color:var(--ink);text-transform:uppercase;line-height:1;}
.essentiel-meta{font-family:'Space Mono';font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-dim);}
.essentiel-grid{display:flex;flex-direction:column;gap:0;}
.essentiel-row{display:grid;grid-template-columns:120px 1fr;gap:18px;align-items:baseline;padding:11px 0;border-top:1px dotted var(--ink-dim);}
.essentiel-row:first-child{border-top:none;padding-top:4px;}
.essentiel-k{font-family:'Space Mono';font-size:10.5px;font-weight:700;letter-spacing:0.13em;text-transform:uppercase;color:var(--red);align-self:start;padding-top:2px;}
.essentiel-v{font-family:'Space Grotesk';font-size:15px;line-height:1.55;color:var(--ink);font-weight:500;}
.essentiel-v b{color:var(--ink);font-weight:700;}
@media (max-width:640px){
  .essentiel{padding:14px 0 14px 18px;margin:28px 0;}
  .essentiel::before{width:4px;}
  .essentiel-title{font-size:18px;}
  .essentiel-row{grid-template-columns:1fr;gap:4px;padding:10px 0;}
  .essentiel-k{padding-top:0;}
}

/* Dark mode pour le nouveau .essentiel */
html[data-theme="dark"] .essentiel::before{background:#FF4A40;}
html[data-theme="dark"] .essentiel-star{color:#FF4A40;}
html[data-theme="dark"] .essentiel-title{color:#F8F4E8;}
html[data-theme="dark"] .essentiel-meta{color:#C9C2B0;}
html[data-theme="dark"] .essentiel-row{border-top-color:#3A3625;}
html[data-theme="dark"] .essentiel-k{color:#FF4A40;}
html[data-theme="dark"] .essentiel-v,
html[data-theme="dark"] .essentiel-v b{color:#E8E2D2;}

/* --- 10) Logos clients / marquee / autres --- */
html[data-theme="dark"] .logos-count{color:#C9C2B0 !important;}
html[data-theme="dark"] .logochip{background:#1A1610;border-color:#F1ECDF;color:#E8E2D2;}
html[data-theme="dark"] .mode.feat .mbody p{color:#D4CFC0 !important;}
html[data-theme="dark"] .gmcard{background:#1A1610;color:#E8E2D2;}
html[data-theme="dark"] .gmcard .gmstats{color:#C9C2B0 !important;}

/* --- 11) Liens hover : rouge vif --- */
html[data-theme="dark"] a:hover{color:#FF4A40;}

/* --- 12) Couleurs "C8C3B2 / 9B968A / D9D4C4" : selon contexte --- */
/* Sur fond clair (body principal) → texte clair impossible : ces couleurs sont
   utilisées exclusivement sur fond sombre (footer, dark sections). Donc on
   les laisse, mais en s'assurant qu'elles ne traînent pas sur fond clair. */
html[data-theme="dark"] body > *:not(.bigfoot):not([style*="background:var(--ink)"]) [style*="color:#C8C3B2"]{color:#E0DAC8 !important;}
html[data-theme="dark"] body > *:not(.bigfoot):not([style*="background:var(--ink)"]) [style*="color:#9B968A"]{color:#D4CFC0 !important;}

/* --- 13) Images : légèrement adoucies pour ne pas brûler les yeux --- */
html[data-theme="dark"] img:not([src*=".svg"]){filter:brightness(.94) contrast(1.04);}

/* --- 14) Fix derniers fails contraste --- */
/* #B0A188 (gris-beige pâle utilisé sur 404, polaroïd cap) → bascule en sombre */
html[data-theme="dark"] [style*="background:#B0A188"]{background:#3D3829 !important;color:#F1ECDF !important;}
/* Boutons rouges : texte plus foncé pour mieux ressortir */
html[data-theme="dark"] .btn-primary,
html[data-theme="dark"] [style*="background:var(--red)"]{color:#0E0C07 !important;}
html[data-theme="dark"] .btn-primary *,
html[data-theme="dark"] [style*="background:var(--red)"] *{color:#0E0C07 !important;}
/* Sauf si c'est un sigma-form / lien rouge dans nav etc. — restaurer pour ces cas */
html[data-theme="dark"] a.btn-primary,
html[data-theme="dark"] button.btn-primary{color:#0E0C07 !important;}
/* Navy en dark : on garde un fond plus contrasté */
html[data-theme="dark"] [style*="background:var(--navy)"]{color:#0E0C07 !important;}
/* Marquee logos : meilleur contraste */
html[data-theme="dark"] .marquee,html[data-theme="dark"] .marquee .logochip{background:#1A1610 !important;border-color:#F1ECDF !important;color:#E8E2D2 !important;}
/* Form inputs en dark */
html[data-theme="dark"] input[type="email"],
html[data-theme="dark"] input[type="text"],
html[data-theme="dark"] textarea{background:#1A1610;color:#F1ECDF;border-color:#F1ECDF;}
html[data-theme="dark"] input::placeholder,
html[data-theme="dark"] textarea::placeholder{color:#9B968A;}
/* FAQ / accordions */
html[data-theme="dark"] details,html[data-theme="dark"] .accord-item{border-color:#3A3625;}
html[data-theme="dark"] summary{color:#F1ECDF;}
/* Hover liens : pas de pb mais on garde explicite */
html[data-theme="dark"] .footer a:hover,html[data-theme="dark"] .bigfoot a:hover{color:#FF4A40 !important;}

/* Toggle button (injecté par script.js) */
.theme-toggle{position:fixed;bottom:18px;left:18px;width:46px;height:46px;background:var(--ink);color:var(--paper);border:var(--bw) solid var(--ink);box-shadow:4px 4px 0 var(--red);cursor:pointer;z-index:9000;display:flex;align-items:center;justify-content:center;font-size:20px;line-height:1;transition:transform .15s ease,box-shadow .15s ease;}
.theme-toggle:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--red);}
@media (max-width:720px){.theme-toggle{width:40px;height:40px;bottom:14px;left:14px;font-size:18px;}}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',sans-serif;background:var(--paper);color:var(--ink);line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
h1,h2,h3,h4,.anton{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;line-height:0.95;letter-spacing:0.01em;}
.mono{font-family:'Space Mono',monospace;}
.wrap{max-width:1120px;margin:0 auto;padding:0 28px;position:relative;z-index:2;}
.wrap-narrow{max-width:820px;margin:0 auto;padding:0 28px;position:relative;z-index:2;}
section{padding:84px 0;position:relative;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}

/* ============================================
   NAV — HEADER FIN + DROPDOWNS PROPRES
   ============================================ */
nav{position:sticky;top:0;z-index:60;background:var(--paper);border-bottom:var(--bw) solid var(--ink);}
.navin{max-width:1240px;margin:0 auto;padding:11px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:54px;}
.logo{font-family:'Anton';font-size:20px;text-transform:uppercase;display:flex;align-items:center;gap:8px;flex-shrink:0;}
.logo .htag{font-family:'Space Mono';font-size:9.5px;font-weight:700;letter-spacing:0.1em;background:var(--red);color:var(--paper);padding:3px 7px;}

/* Burger mobile : caché par défaut (desktop), visible sur tablet/mobile */
.navburger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px;align-items:center;justify-content:center;}
.navburger span{display:block;width:24px;height:2.5px;background:var(--ink);transition:transform .2s ease,opacity .2s ease;}
.navburger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
.navburger.open span:nth-child(2){opacity:0;}
.navburger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}

/* Liens nav desktop : ligne horizontale fine */
.navlinks{display:flex;gap:24px;font-family:'Space Mono';font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;align-items:center;}
.navlinks > a{position:relative;color:inherit;text-decoration:none;}
.navlinks > a:hover{color:var(--red);}
.navlinks > a::after{content:"";position:absolute;left:0;right:100%;bottom:-4px;height:2px;background:var(--red);transition:right .2s ease;}
.navlinks > a:hover::after{right:0;}
.navlinks > a.cur{color:var(--red);}
.navlinks > a.cur::after{right:0;}

/* Triggers dropdown : même style que les liens */
.navdrop{position:relative;}
.navdrop-trigger{font:inherit;background:none;border:none;cursor:pointer;color:inherit;padding:0;text-transform:uppercase;letter-spacing:0.05em;font-weight:700;font-size:11.5px;font-family:'Space Mono';}
.navdrop-trigger:hover{color:var(--red);}

/* Mega-menu : MASQUÉ par défaut, s'ouvre uniquement au hover ou si .open */
.navdrop-menu,.navdrop-menu-mini{display:none;position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%);background:var(--paper);border:var(--bw) solid var(--ink);box-shadow:6px 6px 0 var(--ink);padding:18px 22px;z-index:80;}
.navdrop-menu{gap:24px;}
.navdrop-menu-mini{min-width:200px;}
/* Ouverture : hover desktop OU classe .open (utilisée par le JS) */
.navdrop:hover > .navdrop-menu,
.navdrop:hover > .navdrop-menu-mini,
.navdrop.open > .navdrop-menu,
.navdrop.open > .navdrop-menu-mini{display:flex;}
.navdrop-menu-mini.navdrop-menu-mini,
.navdrop:hover > .navdrop-menu-mini,
.navdrop.open > .navdrop-menu-mini{flex-direction:column;}
/* Pont invisible entre trigger et menu pour éviter le hover qui se ferme */
.navdrop::after{content:"";position:absolute;top:100%;left:0;right:0;height:14px;display:none;}
.navdrop:hover::after{display:block;}

.navdrop-col{display:flex;flex-direction:column;gap:6px;min-width:170px;}
.navdrop-h{font-family:'Space Mono';font-size:10px;font-weight:700;letter-spacing:0.13em;text-transform:uppercase;color:var(--red);padding-bottom:6px;border-bottom:1.5px solid var(--ink);margin-bottom:6px;white-space:nowrap;}
.navdrop-col a{font-family:'Space Grotesk';font-size:13.5px;font-weight:600;text-transform:none;letter-spacing:0;color:var(--ink);white-space:nowrap;padding:3px 0;text-decoration:none;}
.navdrop-col a:hover{color:var(--red);}

.navcta{padding:9px 16px !important;font-size:11.5px !important;box-shadow:4px 4px 0 var(--ink) !important;flex-shrink:0;}

/* BITS */
.kicker{display:inline-flex;align-items:center;gap:8px;font-family:'Space Mono';font-size:12px;font-weight:700;letter-spacing:0.13em;text-transform:uppercase;padding:6px 12px;background:var(--ink);color:var(--paper);}
.btn{font-family:'Space Grotesk';font-weight:700;font-size:15px;padding:14px 26px;display:inline-block;border:var(--bw) solid var(--ink);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;position:relative;}
.btn:hover{transform:translate(-3px,-3px);}
.btn-primary{background:var(--red);color:var(--paper);box-shadow:6px 6px 0 var(--ink);}
.btn-primary:hover{box-shadow:9px 9px 0 var(--ink);}
.btn-ghost{background:var(--panel);color:var(--ink);box-shadow:6px 6px 0 var(--ink);}
.btn-ghost:hover{box-shadow:9px 9px 0 var(--ink);}

/* HERO */
.hero{padding:88px 0 78px;overflow:hidden;}
.hero .focus{position:absolute;inset:-20% -20% auto -20%;height:140%;pointer-events:none;
  background:repeating-conic-gradient(from 0deg at 72% 32%, rgba(21,18,11,0.075) 0deg, rgba(21,18,11,0.075) 0.42deg, transparent 1deg, transparent 3.6deg);
  -webkit-mask-image:linear-gradient(to bottom, #000 62%, transparent 97%);mask-image:linear-gradient(to bottom, #000 62%, transparent 97%);}

/* === HOMOGÉNÉISATION DES FONDS — un seul beige clair (paper) pour toutes les sections claires ===
   On neutralise le 2e beige "panel" et les bordures noires décoratives qui cassaient la cohérence.
   Seules les sections sombres (var(--ink)) restent des contrastes voulus (rythme + emphase). */
section[style*="background:var(--panel)"]{background:var(--paper)!important;border-top:none!important;border-bottom:none!important;}
html[data-theme="dark"] section[style*="background:var(--panel)"]{background:#0E0C07!important;}
/* Texte clair dans les sections à fond sombre inline (prose, listes) — light & dark */
section[style*="background:var(--ink)"] .prose,
section[style*="background:var(--ink)"] .prose p,
section[style*="background:var(--ink)"] .prose li{color:#E8E2D2;}
section[style*="background:var(--ink)"] .prose b,
section[style*="background:var(--ink)"] .prose strong{color:#FFFFFF;}
section[style*="background:var(--ink)"] .prose i{color:#D9D4C4;}

/* === LIGNES DE FUITE — signature, uniquement au hero (toutes pages) + CTA box ===
   Point de fuite hors-cadre (coin haut-droit) + bords dégradés = pas de moiré / "pâtés". */
html[data-theme="dark"] .hero .focus{background:repeating-conic-gradient(from 0deg at 72% 32%, rgba(241,236,223,0.085) 0deg, rgba(241,236,223,0.085) 0.42deg, transparent 1deg, transparent 3.6deg);}
.hero h1{font-size:clamp(44px,6.4vw,84px);margin:20px 0 0;}
.hero h1 .hl{color:var(--red);-webkit-text-stroke:2.5px var(--ink);}
.hero h1 .stroke{color:var(--paper);-webkit-text-stroke:2.5px var(--ink);}
.hero .sub{font-family:'Space Grotesk';font-size:clamp(17px,2.1vw,21px);font-weight:500;color:var(--ink-dim);max-width:620px;margin-top:24px;}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px;}

/* SECT-CTA */
.sect-cta{display:inline-flex;align-items:center;gap:8px;margin-top:34px;font-family:'Space Grotesk';font-weight:700;font-size:14.5px;
  padding:13px 24px;border:var(--bw) solid var(--ink);background:var(--panel);color:var(--ink);box-shadow:5px 5px 0 var(--ink);transition:transform .12s ease,box-shadow .12s ease;position:relative;}
.sect-cta:hover{transform:translate(-3px,-3px);box-shadow:8px 8px 0 var(--ink);}
.sect-cta.red{background:var(--red);color:var(--paper);}

/* INTERTITRE DE SECTION */
.chap{display:inline-flex;align-items:center;font-family:'Space Mono';font-size:13.5px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent);}
.chapn{background:var(--accent);color:var(--paper);padding:3px 9px;margin-right:10px;font-size:12.5px;letter-spacing:0.06em;}
.shead{font-size:clamp(31px,4.7vw,55px);margin:12px 0 0;}
.shead .hl{color:var(--accent);}
.slead{font-family:'Space Grotesk';font-size:17px;font-weight:500;color:var(--ink-dim);max-width:620px;margin-top:14px;}

/* CARDS GENERIQUES */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:42px;}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:42px;}
.panel{background:var(--panel);border:var(--bw) solid var(--ink);padding:24px;box-shadow:6px 6px 0 var(--accent);transition:transform .16s ease,box-shadow .16s ease;}
.panel:hover{transform:translate(-3px,-3px);box-shadow:10px 10px 0 var(--accent);}
.panel .pn{font-family:'Anton';font-size:42px;color:var(--accent);-webkit-text-stroke:2.5px var(--ink);}
.panel h3{font-size:21px;margin:4px 0 8px;}
.panel p{font-size:14.5px;color:var(--ink-dim);}

/* PROSE */
.prose{font-family:'Space Grotesk';font-size:17px;font-weight:500;color:var(--ink-dim);line-height:1.7;}
.prose p{margin-bottom:18px;}
.prose p b,.prose p strong{color:var(--ink);font-weight:700;}
.prose h2{font-size:clamp(26px,3.4vw,38px);color:var(--ink);margin:32px 0 14px;}
.prose h3{font-size:clamp(20px,2.4vw,26px);color:var(--ink);margin:24px 0 10px;}
.prose ul,.prose ol{margin:0 0 18px 24px;color:var(--ink-dim);}
.prose li{margin-bottom:6px;}
.prose blockquote{border-left:var(--bw) solid var(--accent);padding-left:18px;font-weight:600;color:var(--ink);margin:18px 0;}

/* OFFRE DETAIL */
.offer-hero{display:grid;grid-template-columns:1.2fr 0.9fr;gap:36px;align-items:center;margin-top:34px;}
.offer-card{border:var(--bw) solid var(--ink);background:var(--panel);padding:28px;box-shadow:8px 8px 0 var(--accent);}
.offer-card.feat{background:var(--ink);color:var(--paper);}
.offer-card.feat .of-name{color:var(--paper);}
.offer-tag{font-family:'Space Mono';font-size:11px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent);}
.of-name{font-family:'Anton';font-size:46px;margin-top:6px;text-transform:uppercase;}
.of-price{font-family:'Anton';font-size:32px;color:var(--accent);margin-top:10px;}
.of-sub{font-family:'Space Grotesk';font-size:14px;color:var(--ink-dim);margin-top:8px;}
.feature-list{margin-top:30px;display:flex;flex-direction:column;gap:14px;}
.feature-list li{list-style:none;padding-left:32px;position:relative;font-size:15.5px;color:var(--ink-dim);line-height:1.55;}
.feature-list li::before{content:"";position:absolute;left:0;top:6px;width:18px;height:18px;background:var(--accent);border:2px solid var(--ink);}
.feature-list li b{color:var(--ink);}

/* === FIX QA — texte clair forcé dans les cartes à fond sombre inline (ex: pilotage 4500€) === */
.offer-card[style*="background:var(--ink)"] .feature-list li,
.offer-card[style*="background:var(--ink)"] .feature-list li b,
.offer-card[style*="background:var(--ink)"] .of-name{color:var(--paper)!important;}
/* === FIX QA — bouton "ghost" sur section sombre : fond transparent (sinon blanc sur blanc) === */
section[style*="background:var(--ink)"] .btn-ghost,
[style*="background:var(--ink)"] > .wrap .btn-ghost,
[style*="background:var(--ink)"] .wrap-narrow .btn-ghost{background:transparent!important;color:var(--paper)!important;border:var(--bw) solid var(--paper)!important;box-shadow:6px 6px 0 var(--red)!important;}
section[style*="background:var(--ink)"] .btn-ghost:hover{box-shadow:9px 9px 0 var(--red)!important;}
/* === FIX dark mode — cartes "toujours sombres" : forcer le texte clair === */
/* (var(--paper) s'inverse en sombre en dark mode → texte sombre sur carte sombre) */
/* Home · carte fondateur : le nom "Mehdi Naceri" */
html[data-theme="dark"] .gmcard .gmname{color:#F8F4E8;}
/* Home · carte "Avec Growth Consult" (versus) : on re-sombre le fond + texte clair */
html[data-theme="dark"] .vs-new{background:#1A1610;}
html[data-theme="dark"] .vs-new .vs-title{color:#F8F4E8;}
/* Accompagnement & Pilotage · bonus 100+ agents IA */
html[data-theme="dark"] .agents-mini .am-head,
html[data-theme="dark"] .agents-mini .am-desc b{color:#F8F4E8;}
/* Pilotage · carte offre 4 500 € (section "Pour qui ?") */
html[data-theme="dark"] .offer-card[style*="background:var(--ink)"] .of-name,
html[data-theme="dark"] .offer-card[style*="background:var(--ink)"] .feature-list li,
html[data-theme="dark"] .offer-card[style*="background:var(--ink)"] .feature-list li b{color:#F1ECDF!important;}
/* === Indice dark mode (1re visite) : pulse du bouton thème + tooltip === */
@keyframes gcThemeHint{0%,100%{box-shadow:4px 4px 0 var(--red);}50%{box-shadow:0 0 0 9px rgba(225,44,34,0.22),4px 4px 0 var(--red);transform:scale(1.09) rotate(-7deg);}}
.theme-toggle.gc-hint{animation:gcThemeHint 1.5s ease-in-out 3;}
.theme-hint-tip{position:fixed;bottom:22px;left:76px;z-index:9001;background:var(--ink);color:var(--paper);font-family:'Space Mono';font-size:12px;font-weight:700;padding:9px 13px;border:2px solid var(--ink);box-shadow:3px 3px 0 var(--red);max-width:210px;line-height:1.35;opacity:0;transform:translateX(-8px);transition:opacity .3s ease,transform .3s ease;pointer-events:none;}
.theme-hint-tip.show{opacity:1;transform:none;}
html[data-theme="dark"] .theme-hint-tip{background:#F1ECDF;color:#0E0C07;border-color:#F1ECDF;box-shadow:3px 3px 0 #FF4A40;}

/* FORM */
.form-card{border:var(--bw) solid var(--ink);background:var(--panel);padding:28px;box-shadow:8px 8px 0 var(--red);}
.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.form-row label{font-family:'Space Mono';font-size:11px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-dim);}
.form-row input,.form-row textarea,.form-row select{font-family:'Space Grotesk';font-size:15px;padding:11px 13px;border:2px solid var(--ink);background:var(--paper);color:var(--ink);outline:none;width:100%;}
.form-row input:focus,.form-row textarea:focus{background:#FFF;}
.form-row textarea{min-height:120px;resize:vertical;}
.form-cgu{font-family:'Space Mono';font-size:11px;color:var(--ink-dim);margin-top:6px;}
.form-cgu a{color:var(--red);}

/* TANU FAB */
.tanu-fab{position:fixed;right:22px;bottom:22px;z-index:80;display:flex;align-items:flex-end;gap:4px;}
.tanu-fab .fab-bubble{position:relative;background:var(--panel);border:var(--bw) solid var(--ink);border-radius:14px;padding:10px 13px;font-family:'Space Grotesk';font-weight:600;font-size:13px;box-shadow:4px 4px 0 var(--ink);max-width:188px;}
.tanu-fab .fab-bubble::before{content:"";position:absolute;right:-16px;bottom:13px;border:8px solid transparent;border-left-color:var(--ink);border-right:0;}
.tanu-fab .fab-bubble::after{content:"";position:absolute;right:-9px;bottom:15px;border:6px solid transparent;border-left-color:var(--panel);border-right:0;}
.tanu-fab .fab-svg{width:104px;flex-shrink:0;display:block;}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@media (prefers-reduced-motion:no-preference){.fab-svg{animation:float 4.6s ease-in-out infinite;}}

/* CTA SECTION */
.ctawrap{overflow:hidden;}
.ctabox{border:var(--bw) solid var(--ink);background:var(--red);color:var(--paper);padding:62px 30px;text-align:center;box-shadow:9px 9px 0 var(--ink);position:relative;}
.ctabox .focus{position:absolute;inset:0;pointer-events:none;background:repeating-conic-gradient(from 0deg at 100% 0%, rgba(21,18,11,0.05) 0deg, rgba(21,18,11,0.05) 0.4deg, transparent 1.6deg, transparent 6deg);}
html[data-theme="dark"] .ctabox .focus{background:repeating-conic-gradient(from 0deg at 100% 0%, rgba(241,236,223,0.06) 0deg, rgba(241,236,223,0.06) 0.4deg, transparent 1.6deg, transparent 6deg);}
.ctabox > *{position:relative;z-index:2;}
.ctabox h2{font-size:clamp(40px,6vw,72px);}
.ctabox p{font-family:'Space Grotesk';font-weight:500;font-size:17px;margin:14px auto 26px;max-width:490px;}
.ctabox .btn-primary{background:var(--paper);color:var(--ink);border-color:var(--ink);box-shadow:6px 6px 0 var(--ink);}

/* BIGFOOT */
.bigfoot{background:var(--ink);color:var(--paper);padding:64px 0 24px;border-top:var(--bw) solid var(--ink);position:relative;}
.ftop{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr 0.9fr;gap:28px;}
.fcol h4{font-family:'Anton';font-size:18px;color:var(--paper);text-transform:uppercase;letter-spacing:0.04em;margin-bottom:16px;border-bottom:2px solid var(--red);padding-bottom:8px;display:inline-block;}
.fcol ul{list-style:none;display:flex;flex-direction:column;gap:9px;}
.fcol a{font-family:'Space Grotesk';font-size:14px;font-weight:500;color:#C8C3B2;transition:color .15s ease;white-space:nowrap;display:inline-block;}
.fcol a:hover{color:var(--red);}
.flogo{font-family:'Anton';font-size:30px;color:var(--paper);text-transform:uppercase;line-height:1;}
.flogo span{color:var(--red);}
.fhtag{display:inline-block;font-family:'Space Mono';font-size:10px;font-weight:700;letter-spacing:0.1em;background:var(--red);color:var(--paper);padding:3px 7px;margin-left:6px;vertical-align:middle;}
.ftag{font-family:'Space Grotesk';font-size:14px;color:#A8A292;margin-top:10px;line-height:1.55;max-width:330px;}
.fnews{margin-top:22px;max-width:340px;}
.fnews label{font-family:'Space Mono';font-size:11px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--red);display:block;margin-bottom:6px;}
.fnews-form{display:flex;border:2px solid var(--paper);}
.fnews-form input{flex:1;min-width:0;padding:10px 12px;border:none;background:var(--paper);font-family:'Space Grotesk';font-size:14px;color:var(--ink);outline:none;}
.fnews-form button{background:var(--red);color:var(--paper);border:none;padding:0 16px;font-family:'Anton';font-size:20px;cursor:pointer;transition:background .15s ease;}
.fnews-form button:hover{background:#B81F17;}
.fnews-note{font-family:'Space Mono';font-size:10.5px;color:#9B968A;margin-top:6px;display:block;}
.fnews-alt{margin-top:10px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.fnews-alt .fnews-or{font-family:'Space Mono';font-size:10.5px;color:#9B968A;text-transform:uppercase;letter-spacing:0.08em;}
.fnews-alt a{font-family:'Space Grotesk';font-size:12px;font-weight:700;color:var(--paper);border:1.5px solid var(--paper);padding:4px 10px;text-decoration:none;transition:background .15s ease,color .15s ease;}
.fnews-alt a:hover{background:var(--red);border-color:var(--red);color:var(--paper);}
.fbig{margin-top:48px;padding:24px 28px;border:2px dashed #5B5648;display:flex;align-items:center;gap:24px;justify-content:space-between;flex-wrap:wrap;}
.fbig-msg{display:flex;align-items:center;gap:14px;}
.fbig-tanu{width:64px;flex-shrink:0;}
.fbig-msg p{font-family:'Anton';font-size:22px;text-transform:uppercase;color:var(--paper);line-height:1.15;}
.fbottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-top:32px;padding-top:24px;border-top:1px solid #3A3625;font-family:'Space Mono';font-size:11px;color:#9B968A;letter-spacing:0.04em;text-transform:uppercase;}
.flinks{display:flex;gap:18px;flex-wrap:wrap;}
.flinks a{color:#9B968A;transition:color .15s ease;}
.flinks a:hover{color:var(--red);}

/* CTA PEEK */
.cta-peek{position:absolute;right:-14px;top:0;width:70px;pointer-events:none;opacity:0;transform:translateY(10px) scale(0.5) rotate(12deg);transform-origin:bottom right;transition:opacity .2s ease,transform .28s cubic-bezier(.34,1.56,.64,1);z-index:6;}
.sect-cta:hover .cta-peek,.btn-primary:hover .cta-peek,.btn-ghost:hover .cta-peek{opacity:1;transform:translateY(-34px) scale(1) rotate(-7deg);}

/* EGGS */
.egg{position:absolute;cursor:pointer;opacity:0.3;z-index:1;transition:opacity .2s ease,transform .2s ease;}
.egg:hover{opacity:0.95;transform:scale(1.25) rotate(-9deg);}
.egg svg{display:block;}
.eggpop{position:fixed;inset:0;z-index:9700;display:flex;align-items:flex-end;justify-content:center;padding:0 18px 26px;background:rgba(21,18,11,0.4);transform:none;left:0;right:0;}
.eggpop[hidden]{display:none;}
.eggpop-card{display:flex;align-items:flex-end;gap:2px;max-width:470px;animation:eggin .25s ease;}
@keyframes eggin{from{transform:translateY(24px);opacity:0;}to{transform:none;opacity:1;}}
.eggpop-card svg{width:104px;flex-shrink:0;}
.eggpop-bubble{position:relative;background:var(--panel);border:var(--bw) solid var(--ink);border-radius:16px;padding:15px 18px;box-shadow:6px 6px 0 var(--ink);}
.eggpop-bubble::after{content:"";position:absolute;left:-15px;bottom:18px;border:9px solid transparent;border-right-color:var(--ink);border-left:0;}
.eggname{font-family:'Space Mono';font-size:10px;font-weight:700;letter-spacing:0.13em;text-transform:uppercase;color:var(--red);margin-bottom:5px;}
.eggmsg{font-family:'Space Grotesk';font-weight:600;font-size:14.5px;}
.eggpop-close{margin-top:12px;font-family:'Space Grotesk';font-weight:700;font-size:13px;background:var(--red);color:var(--paper);border:2px solid var(--ink);padding:7px 16px;cursor:pointer;}

/* REVEAL */
@media (prefers-reduced-motion:no-preference){
  html.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .62s ease,transform .62s cubic-bezier(.2,.75,.25,1);}
  html.js .reveal.in{opacity:1;transform:none;}
  html.js .reveal.d1{transition-delay:.09s;}
  html.js .reveal.d2{transition-delay:.18s;}
  html.js .reveal.d3{transition-delay:.27s;}
}

/* === HOME — COMPOSANTS RICHES === */

/* HERO GRID + MASCOTTE */
.hero-grid{display:grid;grid-template-columns:1.35fr 0.8fr;gap:30px;align-items:center;}
.hero-right{display:flex;flex-direction:column;align-items:center;}
.hero-right .tanu-svg{width:100%;max-width:290px;display:block;}
.tanu-bubble{position:relative;background:var(--panel);border:var(--bw) solid var(--ink);border-radius:16px;padding:13px 17px;font-family:'Space Grotesk';font-weight:600;font-size:15px;box-shadow:5px 5px 0 var(--ink);max-width:280px;margin-bottom:16px;}
.tanu-bubble::before{content:"";position:absolute;left:38px;bottom:-19px;border:10px solid transparent;border-top-color:var(--ink);border-bottom:0;}
.tanu-bubble::after{content:"";position:absolute;left:41px;bottom:-13px;border:7px solid transparent;border-top-color:var(--panel);border-bottom:0;}

/* STATSTRIP */
.statstrip{display:flex;margin-top:46px;border:var(--bw) solid var(--ink);background:var(--panel);box-shadow:7px 7px 0 var(--ink);}
.statstrip .st{flex:1;padding:18px 20px;border-right:2px solid var(--ink);}
.statstrip .st:last-child{border-right:none;}
.statstrip .sn{font-family:'Anton';font-size:34px;color:var(--red);}
.statstrip .st:nth-child(2) .sn,.statstrip .st:nth-child(4) .sn{color:var(--navy);}
.statstrip .sl{font-family:'Space Mono';font-size:11px;text-transform:uppercase;letter-spacing:0.04em;color:var(--ink-dim);}

/* BANDE CLIENTS */
.logos{padding:30px 0;background:var(--ink);border-top:var(--bw) solid var(--ink);border-bottom:var(--bw) solid var(--ink);overflow:hidden;}
.logos-head{text-align:center;margin-bottom:22px;padding:0 20px;}
.logos-label{font-family:'Bangers';font-size:24px;letter-spacing:0.06em;color:var(--paper);}
.logos-label .star{color:var(--red);}
.logos-count{display:block;font-family:'Space Mono';font-size:11.5px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:#9B968A;margin-top:4px;}
.marquee{display:flex;width:100%;overflow:hidden;}
.marquee+.marquee{margin-top:12px;}
.mtrack{display:flex;flex-shrink:0;will-change:transform;}
.logochip{flex-shrink:0;display:flex;align-items:center;justify-content:center;height:52px;padding:0 22px;margin:0 7px;border:2.5px solid var(--paper);font-family:'Anton';font-size:17px;text-transform:uppercase;letter-spacing:0.02em;color:var(--paper);white-space:nowrap;transition:background .15s ease,color .15s ease,border-color .15s ease;}
.logochip:hover{background:var(--red);border-color:var(--red);color:var(--paper);}

/* PANELS HOME — rotations en quinconce */
.grid3 .panel:nth-child(1){transform:rotate(-1.2deg);}
.grid3 .panel:nth-child(3){transform:rotate(1.2deg);}
.grid3 .panel:hover{transform:rotate(0) translate(-4px,-4px);}

/* OS — ACCORDEON METHODE */
.osbox{border:var(--bw) solid var(--ink);background:var(--panel);margin-top:32px;box-shadow:7px 7px 0 var(--navy);}
.osrow{border-bottom:2px solid var(--ink);}
.osrow:last-child{border-bottom:none;}
.osrow summary{display:flex;align-items:center;gap:16px;padding:17px 24px;cursor:pointer;list-style:none;transition:background .15s ease;}
.osrow summary::-webkit-details-marker{display:none;}
.osrow summary:hover{background:rgba(21,18,11,0.05);}
.ohash{font-family:'Space Mono';font-weight:700;font-size:13px;color:var(--accent);min-width:24px;}
.oname{font-family:'Anton';font-size:21px;text-transform:uppercase;min-width:215px;}
.osbar{flex:1;height:14px;border:2px solid var(--ink);background:linear-gradient(90deg,var(--accent) var(--w,90%),var(--paper) var(--w,90%));}
.otoggle{width:26px;height:26px;border:2px solid var(--ink);background:var(--panel);position:relative;flex-shrink:0;margin-left:auto;transition:background .15s ease;}
.otoggle::before,.otoggle::after{content:"";position:absolute;background:var(--ink);}
.otoggle::before{left:5px;right:5px;top:10.75px;height:2.5px;}
.otoggle::after{top:5px;bottom:5px;left:10.75px;width:2.5px;}
.osrow[open] .otoggle{background:var(--accent);}
.osrow[open] .otoggle::before{background:var(--paper);}
.osrow[open] .otoggle::after{display:none;}
.osdesc{padding:2px 24px 20px 64px;font-size:14.5px;color:var(--ink-dim);max-width:780px;}

/* OFFRES — TRIPTYQUE */
.modes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:42px;}
.mode{border:var(--bw) solid var(--ink);background:var(--panel);display:flex;flex-direction:column;box-shadow:6px 6px 0 var(--accent);transition:transform .16s ease,box-shadow .16s ease;color:inherit;text-decoration:none;}
.mode:hover{transform:translate(-4px,-4px);box-shadow:11px 11px 0 var(--accent);}
.mode .mtop{padding:20px 22px;border-bottom:var(--bw) solid var(--ink);}
.mode .mtag{font-family:'Space Mono';font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--accent);}
.mode .mname{font-family:'Anton';font-size:34px;text-transform:uppercase;margin-top:6px;}
.mode .mbody{padding:22px;flex:1;}
.mode .mbody p{font-size:14px;color:var(--ink-dim);}
.mode .mbody .mwho{font-family:'Space Grotesk';font-weight:600;font-size:14px;color:var(--ink);margin-bottom:8px;}
.mode.feat{background:var(--ink);}
.mode.feat .mtop{border-color:var(--paper);}
.mode.feat .mname{color:var(--paper);}
.mode.feat .mbody .mwho{color:var(--paper);}
.mode.feat .mbody p{color:#B7B2A2;}

/* Fix .mwho hors mbody (placé directement sous .mtop) */
.mode > .mwho{font-family:'Space Grotesk';font-weight:600;font-size:14.5px;color:var(--ink);padding:18px 22px 0;line-height:1.45;}
.mode.feat > .mwho{color:var(--paper);}

/* Liste features dans les cards .mode (sortait des bords par défaut) */
.mode ul.feat{list-style:none;padding:8px 22px 22px;margin:0;display:flex;flex-direction:column;gap:9px;}
.mode ul.feat li{position:relative;padding-left:22px;font-family:'Space Grotesk';font-size:13.5px;line-height:1.5;color:var(--ink-dim);}
.mode ul.feat li::before{content:"";position:absolute;left:0;top:7px;width:11px;height:11px;background:var(--red);border:2px solid var(--ink);}
.mode.feat ul.feat li{color:#D4CFC0;}
.mode.feat ul.feat li::before{background:var(--red);border-color:var(--paper);}
.mode > a{margin:0 22px 22px;}

/* Dark mode des modes */
html[data-theme="dark"] .mode{background:#1A1610;border-color:#F1ECDF;box-shadow:6px 6px 0 #FF4A40;}
html[data-theme="dark"] .mode .mtop{border-bottom-color:#F1ECDF;}
html[data-theme="dark"] .mode > .mwho{color:#F1ECDF;}
html[data-theme="dark"] .mode .mname{color:#F1ECDF;}
html[data-theme="dark"] .mode .mbody p{color:#E8E2D2 !important;}
html[data-theme="dark"] .mode ul.feat li{color:#E8E2D2;}
html[data-theme="dark"] .mode.feat{background:#0E0C07;}
html[data-theme="dark"] .mode.feat .mtop{border-bottom-color:#F1ECDF;}
html[data-theme="dark"] .mode.feat > .mwho,
html[data-theme="dark"] .mode.feat .mname{color:#F8F4E8;}
html[data-theme="dark"] .mode.feat .mbody p{color:#D4CFC0 !important;}
html[data-theme="dark"] .mode.feat ul.feat li{color:#D4CFC0;}

/* RESULTATS — LOOT */
.loot{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:42px;}
.loottile{border:2px solid var(--ink);padding:20px;background:var(--panel);box-shadow:5px 5px 0 var(--accent);transition:transform .16s ease,box-shadow .16s ease;}
.loottile:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--accent);}
.loottile .lr{font-family:'Space Mono';font-size:10px;font-weight:700;letter-spacing:0.09em;text-transform:uppercase;color:var(--accent);}
.loottile .lv{font-family:'Anton';font-size:36px;color:var(--accent);margin-top:3px;}
.loottile .ld{font-family:'Space Grotesk';font-size:13.5px;font-weight:500;color:var(--ink-dim);margin-top:4px;}

/* FONDATEUR */
.gm{display:grid;grid-template-columns:0.95fr 1.3fr;gap:30px;align-items:center;margin-top:42px;}
.gmcard{border:var(--bw) solid var(--ink);background:var(--ink);color:var(--paper);padding:30px;box-shadow:7px 7px 0 var(--accent);position:relative;}
.gmcard .gmname{font-family:'Anton';font-size:40px;text-transform:uppercase;color:var(--paper);}
.gmcard .gmrole{font-family:'Space Mono';font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.07em;color:var(--red);margin-top:4px;}
.gmcard .gmstats{font-family:'Space Mono';font-size:12px;margin-top:18px;line-height:1.9;color:#C8C3B2;}
.gmphoto{position:relative;background:#FBF9F1;padding:10px 10px 36px;border:2px solid var(--ink);box-shadow:6px 6px 0 var(--red);transform:rotate(-2.2deg);max-width:230px;margin:-6px auto 24px;}
.gmphoto::before{content:"";position:absolute;top:-11px;left:50%;transform:translateX(-50%) rotate(-4deg);width:62px;height:16px;background:rgba(225,44,34,0.88);}
.gmphoto svg,.gmphoto img{display:block;width:100%;height:auto;border:2px solid var(--ink);background:#EDE2C9;}
.gmphoto-cap{position:absolute;bottom:10px;left:0;right:0;text-align:center;font-family:'Space Mono';font-size:10.5px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink);}
.gmcard-id{display:flex;align-items:center;gap:14px;}
.gmavatar{width:64px;height:64px;border-radius:50%;border:3px solid var(--paper);object-fit:cover;flex-shrink:0;box-shadow:3px 3px 0 var(--red);}
.gm .gmtext p{font-size:15.5px;color:var(--ink-dim);margin-bottom:14px;}
.gm .gmtext p b{color:var(--ink);}
.whyme{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:38px;}
.whycard{border:2px solid var(--ink);background:var(--panel);padding:18px 20px;box-shadow:5px 5px 0 var(--ink);transition:transform .16s ease,box-shadow .16s ease;}
.whycard:hover{transform:translate(-3px,-3px);box-shadow:8px 8px 0 var(--accent);}
.whycard .wt{font-family:'Anton';font-size:19px;color:var(--accent);}
.whycard p{font-size:13.5px;color:var(--ink-dim);margin-top:5px;}

/* GROWTH HORDE */
.versus{display:grid;grid-template-columns:1fr auto 1fr;align-items:stretch;margin-top:40px;}
.vs-card{border:var(--bw) solid var(--ink);padding:26px 24px;}
.vs-old{background:var(--panel);box-shadow:7px 7px 0 var(--ink);}
.vs-new{background:var(--ink);color:var(--paper);box-shadow:7px 7px 0 var(--navy);}
.vs-tag{font-family:'Space Mono';font-size:11px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;}
.vs-old .vs-tag{color:var(--ink-dim);}
.vs-new .vs-tag{color:var(--red);}
.vs-title{font-family:'Anton';font-size:30px;text-transform:uppercase;margin:6px 0 16px;line-height:1;}
.vs-new .vs-title{color:var(--paper);}
.vs-list{list-style:none;display:flex;flex-direction:column;gap:11px;}
.vs-list li{font-size:14px;padding-left:28px;position:relative;line-height:1.5;}
.vs-old .vs-list li{color:var(--ink-dim);}
.vs-new .vs-list li{color:#D9D4C4;}
.vs-list li::before{position:absolute;left:0;top:-1px;font-family:'Bangers';font-size:18px;}
.vs-old .vs-list li::before{content:"\2715";color:var(--red);}
.vs-new .vs-list li::before{content:"\2713";color:var(--red);}
.vs-bolt{align-self:center;display:flex;align-items:center;justify-content:center;width:64px;height:64px;margin:0 -16px;z-index:4;border-radius:50%;background:var(--navy);color:var(--paper);border:var(--bw) solid var(--ink);font-family:'Bangers';font-size:26px;letter-spacing:0.04em;box-shadow:4px 4px 0 var(--ink);}
.horde-sub{font-family:'Anton';font-size:24px;text-transform:uppercase;margin-top:44px;}
.hordegrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px;}
.hchip{border:2px solid var(--ink);background:var(--panel);padding:18px;display:flex;align-items:flex-start;gap:13px;box-shadow:5px 5px 0 var(--ink);transition:transform .16s ease,box-shadow .16s ease;}
.hchip:hover{transform:translate(-3px,-3px);box-shadow:8px 8px 0 var(--accent);}
.hchip .hicon{width:36px;height:36px;flex-shrink:0;border:2px solid var(--ink);display:flex;align-items:center;justify-content:center;font-family:'Space Mono';font-weight:700;font-size:17px;background:var(--accent);color:var(--paper);}
.hchip .hname{font-family:'Anton';font-size:17px;text-transform:uppercase;line-height:1.05;}
.hchip .hdesc{font-size:12.5px;color:var(--ink-dim);margin-top:4px;}
.hordenote{margin-top:26px;font-family:'Space Grotesk';font-weight:600;font-size:15.5px;border-left:var(--bw) solid var(--accent);padding:4px 0 4px 18px;}

/* TEMOIGNAGES — CARROUSEL */
.tcarousel{display:flex;gap:20px;margin-top:38px;overflow-x:auto;padding-bottom:18px;scroll-snap-type:x mandatory;}
.tcarousel::-webkit-scrollbar{height:12px;}
.tcarousel::-webkit-scrollbar-track{background:var(--panel);border:2px solid var(--ink);}
.tcarousel::-webkit-scrollbar-thumb{background:var(--red);border:2px solid var(--ink);}
.tcard{flex:0 0 328px;scroll-snap-align:start;border:var(--bw) solid var(--ink);background:var(--panel);padding:22px 24px;box-shadow:6px 6px 0 var(--accent);display:flex;flex-direction:column;transition:transform .16s ease,box-shadow .16s ease;}
.tcard:hover{transform:translate(-3px,-3px);box-shadow:10px 10px 0 var(--accent);}
.tcard .tquote{font-family:'Bangers';font-size:46px;line-height:0.55;color:var(--accent);}
.tcard .tq{font-family:'Space Grotesk';font-weight:600;font-size:14px;flex:1;margin-top:10px;}
.tcard .twho{display:flex;align-items:center;gap:11px;margin-top:16px;padding-top:14px;border-top:2px solid var(--ink);}
.tcard .tav{width:42px;height:42px;border-radius:50%;border:2px solid var(--ink);background:var(--accent);color:var(--paper);display:flex;align-items:center;justify-content:center;font-family:'Anton';font-size:14px;flex-shrink:0;}
.tcard .tn{font-family:'Space Grotesk';font-weight:700;font-size:13.5px;}
.tcard .tr{font-family:'Space Mono';font-size:10.5px;color:var(--ink-dim);}
.tnav{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:6px;}
.tnav-hint{font-family:'Space Mono';font-size:12px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-dim);}
.tnav-btns{display:flex;gap:8px;}
.tnav-btn{width:46px;height:46px;border:var(--bw) solid var(--ink);background:var(--panel);font-family:'Anton';font-size:20px;cursor:pointer;box-shadow:3px 3px 0 var(--ink);transition:transform .1s ease,background .1s ease,color .1s ease;}
.tnav-btn:hover{transform:translate(-2px,-2px);background:var(--red);color:var(--paper);}

/* FAQ — ACCORDEON */
.faqlist{margin-top:38px;}
.faq-item{border:var(--bw) solid var(--ink);background:var(--panel);margin-bottom:13px;box-shadow:5px 5px 0 var(--accent);}
.faq-item summary{display:flex;align-items:center;gap:14px;padding:18px 20px;cursor:pointer;list-style:none;transition:background .15s ease;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary:hover{background:rgba(21,18,11,0.04);}
.faq-item .fq{font-family:'Anton';font-size:18px;text-transform:uppercase;flex:1;line-height:1.1;}
.faq-item .fa{padding:0 20px 20px 20px;font-size:14.5px;color:var(--ink-dim);max-width:840px;}
.faq-item .fa b{color:var(--ink);}

/* BICHROMIE — cohérence couleurs par section (home) */
#probleme .panel:nth-child(2){--accent:var(--navy);}
#offres .mode:nth-child(3){--accent:var(--navy);}
#fondateur .whycard:nth-child(2){--accent:var(--navy);}
#temoignages .tcard:nth-child(even){--accent:var(--navy);}
#methode .osrow:nth-child(3){--accent:var(--red);}
#resultats .loottile:nth-child(3n+2){--accent:var(--red);}
#horde .hchip:nth-child(3n+2){--accent:var(--red);}
#faq .faq-item:nth-child(even){--accent:var(--red);}

/* MARQUEE + FLOAT */
@keyframes scroll-l{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes scroll-r{from{transform:translateX(-50%)}to{transform:translateX(0)}}
@media (prefers-reduced-motion:no-preference){
  .mtrack{animation:scroll-l 52s linear infinite;}
  .mtrack.rev{animation:scroll-r 60s linear infinite;}
  .marquee:hover .mtrack{animation-play-state:paused;}
  .tanu-svg{animation:float 4.6s ease-in-out infinite;}
}

/* REVEAL */
@media (prefers-reduced-motion:no-preference){
  html.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .62s ease,transform .62s cubic-bezier(.2,.75,.25,1);}
  html.js .reveal.in{opacity:1;transform:none;}
  html.js .reveal.d1{transition-delay:.09s;}
  html.js .reveal.d2{transition-delay:.18s;}
  html.js .reveal.d3{transition-delay:.27s;}
}

/* ============================================
   RESPONSIVE — MOBILE FIRST PRIORITY
   ============================================ */

/* TABLET <= 980px : burger menu + grilles allégées */
@media (max-width:980px){
  .navin{padding:11px 18px;gap:12px;}
  .navburger{display:flex;order:3;}
  .navcta{display:none;}
  .navlinks{position:fixed;inset:54px 0 0 0;background:var(--paper);flex-direction:column;align-items:stretch;justify-content:flex-start;padding:24px 24px 40px;gap:0;overflow-y:auto;display:none !important;border-top:var(--bw) solid var(--ink);z-index:55;}
  .navlinks.open{display:flex !important;}
  .navlinks > a,.navdrop-trigger{padding:16px 0;border-bottom:1.5px solid rgba(21,18,11,0.1);font-size:14px;text-align:left;width:100%;display:block;}
  .navlinks > a::after{display:none;}
  .navdrop{width:100%;position:static;}
  .navdrop::after{display:none !important;}
  .navdrop-menu,.navdrop-menu-mini{display:none !important;position:static;transform:none;box-shadow:none;border:none;background:rgba(21,18,11,0.04);padding:10px 18px 14px;margin-bottom:4px;flex-direction:column !important;gap:14px;}
  .navdrop.open > .navdrop-menu,.navdrop.open > .navdrop-menu-mini{display:flex !important;}
  .navdrop-col{min-width:0;}
  .navdrop-col a{font-size:14px;padding:4px 0;}
  .grid3,.modes,.loot,.hordegrid{grid-template-columns:repeat(2,1fr);gap:14px;}
  .versus{grid-template-columns:1fr;}
  .vs-bolt{margin:-22px auto;}
  .ftop{grid-template-columns:repeat(3,1fr);gap:22px;}
  .fcol-brand{grid-column:1 / -1;}
}

/* MOBILE <= 720px : 1 colonne partout */
@media (max-width:720px){
  section{padding:54px 0;}
  .wrap,.wrap-narrow{padding:0 18px;}
  .grid3,.grid2,.offer-hero,.modes,.loot,.gm,.whyme,.hordegrid{grid-template-columns:1fr;}
  .grid3 .panel:nth-child(1),.grid3 .panel:nth-child(3){transform:none;}
  .statstrip{flex-wrap:wrap;}
  .statstrip .st{flex:1 1 50%;border-bottom:2px solid var(--ink);}
  .statstrip .st:last-child,.statstrip .st:nth-last-child(2){border-bottom:none;}
  .statstrip .sn{font-size:28px;}
  .osrow summary{flex-wrap:wrap;}
  .oname{min-width:auto;font-size:18px;}
  .osbar{order:5;flex-basis:100%;}
  .osdesc{padding-left:24px;}
  .hero{padding:54px 0 46px;}
  .hero h1{font-size:clamp(38px,9vw,52px);}
  .hero .sub{font-size:16px;}
  .hero-grid{grid-template-columns:1fr;gap:8px;}
  .hero-right{max-width:280px;margin:16px auto 0;}
  .tanu-fab{right:14px;bottom:14px;}
  .tanu-fab .fab-bubble{display:none;}
  .tanu-fab .fab-svg{width:72px;}
  .tcard{flex-basis:82vw;}
  .egg{transform:scale(0.7);}
  .ftop{grid-template-columns:repeat(2,1fr);gap:20px;}
  .fcol-brand{grid-column:1 / -1;}
  .fnews{max-width:100%;}
  .fbig{padding:20px;flex-direction:column;align-items:stretch;text-align:center;}
  .fbig-msg{justify-content:center;}
  .fbottom{flex-direction:column;align-items:flex-start;font-size:10px;}
  .ctabox{padding:42px 22px;}
  .ctabox h2{font-size:clamp(32px,8vw,48px);}
  .shead{font-size:clamp(28px,7vw,38px);}
  .logos-label{font-size:18px;}
  .logochip{height:42px;padding:0 14px;font-size:14px;margin:0 5px;}
  .btn{padding:13px 22px;font-size:14px;}
}

/* SMALL MOBILE <= 420px */
@media (max-width:420px){
  .ftop{grid-template-columns:1fr;}
  .statstrip .st{flex:1 1 100%;border-right:none;}
  .logo{font-size:18px;}
  .logo .htag{font-size:9px;}
}

/* ============================================
   MOBILE UI/UX PATCH — Polish complet
   ============================================ */

@media (max-width:980px){
  .btn,.cal-link,.fnews-form button,.sect-cta{min-height:44px;display:inline-flex;align-items:center;justify-content:center;}
  .navdrop-trigger{min-height:48px;}
  .navlinks > a,.navdrop-col a{min-height:44px;display:flex !important;align-items:center;}
  .hero{padding:48px 0 36px;}
  .kicker{font-size:11px;}
  .statstrip{flex-wrap:wrap;border-width:2.5px;box-shadow:5px 5px 0 var(--ink);}
  .statstrip .st{flex:1 1 50%;padding:14px 16px;border-right:2px solid var(--ink);border-bottom:2px solid var(--ink);}
  .statstrip .st:nth-child(2n){border-right:none;}
  .statstrip .st:nth-last-child(-n+2){border-bottom:none;}
  .panel,.tool,.mode,.loottile,.tcard,.gmcard,.offer-card,.what-card,.vs-card,.faq-item,.osbox,.hchip,.whycard{box-shadow:4px 4px 0 var(--ink);}
  .panel:hover,.mode:hover,.loottile:hover,.tcard:hover,.hchip:hover,.whycard:hover{transform:none;box-shadow:4px 4px 0 var(--accent,var(--ink));}
  .tanu-fab{right:14px;bottom:14px;}
  .tanu-fab .fab-bubble{display:none;}
  .tanu-fab .fab-svg{width:66px;}
}

@media (max-width:720px){
  .hero h1{font-size:clamp(34px,9vw,46px);letter-spacing:0;}
  .shead{font-size:clamp(26px,6.5vw,34px);letter-spacing:0;}
  .hero .sub,.sub{font-size:15.5px;line-height:1.55;}
  .cta,.hero .cta{flex-direction:column;align-items:stretch;gap:10px;}
  .cta .btn,.hero .cta .btn{width:100%;text-align:center;}
  section{padding:48px 0;}
  .audit-hero,.hero{padding:44px 0 30px;}
  .about-hero{grid-template-columns:1fr !important;gap:24px;}
  .about-photos{flex-direction:row !important;justify-content:center;gap:16px;}
  .polaroid{transform:rotate(-2deg) !important;max-width:180px !important;}
  .portrait{width:130px !important;height:130px !important;}
  .gm{grid-template-columns:1fr !important;gap:22px;}
  .gmphoto{max-width:200px;}
  .gmcard{padding:24px 22px;}
  .gmcard .gmname{font-size:32px;}
  .offer-hero{grid-template-columns:1fr !important;gap:24px;}
  .offer-card{padding:22px;}
  .of-name{font-size:38px;}
  .expertise{grid-template-columns:1fr !important;gap:12px;}
  .versus{gap:18px;}
  .vs-bolt{margin:-12px auto;width:54px;height:54px;font-size:22px;}
  .vs-title{font-size:24px;}
  .hordegrid{grid-template-columns:1fr !important;}
  .tcarousel{gap:14px;padding-bottom:14px;-webkit-overflow-scrolling:touch;}
  .tcard{flex-basis:78vw;padding:20px;}
  .tnav{justify-content:center;}
  .tnav-hint{display:none;}
  .faq-item .fq{font-size:16px;}
  .faq-item summary{padding:14px 16px;}
  .faq-item .fa{padding:0 16px 16px 16px;font-size:14px;}
  .osrow summary{padding:14px 16px;}
  .osdesc{padding:0 16px 16px 16px;}
  .oname{font-size:16px;min-width:0 !important;}
  .ohash{font-size:12px;}
  .ftop{grid-template-columns:1fr 1fr !important;gap:22px;}
  .fcol-brand{grid-column:1 / -1 !important;}
  .fcol h4{font-size:16px;margin-bottom:12px;}
  .fcol a{font-size:13.5px;white-space:normal;}
  .flogo{font-size:24px;}
  .fbig{padding:18px;}
  .fbig-tanu{width:54px;}
  .fbig-msg p{font-size:17px;}
  .ctabox{padding:38px 20px;box-shadow:6px 6px 0 var(--ink);}
  .ctabox h2{font-size:clamp(28px,8vw,42px);}
  section[style*="background:var(--ink)"] .shead,
  section[style*="background:var(--ink)"] h2{font-size:clamp(26px,7vw,36px);}
  .logos{padding:22px 0;}
  .logochip{height:38px;padding:0 12px;font-size:13px;margin:0 4px;border-width:2px;}
  .logos-label{font-size:17px;}
  .logos-count{font-size:10.5px;}
  .egg{opacity:0.22;transform:scale(0.65);}
  .egg:hover{transform:scale(0.85) rotate(-6deg);}
  .eggpop-card{flex-direction:column-reverse;align-items:flex-start;gap:6px;}
  .eggpop-card svg{width:82px;}
  .eggpop-bubble::after{display:none;}
  .form-card{padding:22px 18px;box-shadow:5px 5px 0 var(--red);}
  .form-row input,.form-row textarea,.form-row select{padding:13px 14px;font-size:16px;}
  .fnews-alt{gap:8px;}
}

@media (max-width:480px){
  .hero h1{font-size:clamp(30px,8.5vw,40px);}
  .btn{width:100%;text-align:center;padding:14px 18px;font-size:14px;}
  .btn-primary{box-shadow:4px 4px 0 var(--ink);}
  .audit-form-wrap{padding:18px 14px;}
  .statstrip .st{flex:1 1 100%;border-right:none;border-bottom:2px solid var(--ink);}
  .statstrip .st:last-child{border-bottom:none;}
  .statstrip .sn{font-size:28px;}
  .about-photos{flex-direction:column !important;align-items:center;}
  .polaroid{max-width:200px !important;}
  .portrait{width:120px !important;height:120px !important;}
  section{padding:40px 0;}
  .hero{padding:34px 0 24px;}
  .wrap,.wrap-narrow{padding:0 16px;}
  .tcard{flex-basis:88vw;}
  .ftop{grid-template-columns:1fr !important;}
  .tanu-fab .fab-svg{width:58px;}
}

@media (max-width:380px){
  .hero h1{font-size:28px;}
  .shead{font-size:24px;}
  .logo{font-size:16px;}
  .logo .htag{display:none;}
  .navin{padding:9px 14px;}
  .ctabox{padding:30px 16px;}
  .btn{font-size:13px;padding:13px 16px;}
  .gmcard .gmname{font-size:28px;}
  .of-name{font-size:32px;}
  .vs-title{font-size:21px;}
}

a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,.btn:focus-visible{outline:3px solid var(--red);outline-offset:2px;}
section[id]{scroll-margin-top:64px;}

@media (max-width:720px){
  .grid2.g4cols,div[style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:1fr !important;}
}
@media (min-width:721px) and (max-width:980px){
  div[style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:repeat(2,1fr) !important;}
}

html,body{max-width:100%;overflow-x:hidden;}
img,svg{max-width:100%;height:auto;}

/* === MICROINTERACTIONS MÉMORABLES === */

/* Sticky CTA mobile : bouton flottant qui apparaît au scroll */
.sticky-cta-mobile{
  position:fixed;left:50%;bottom:18px;transform:translateX(-50%) translateY(120px);
  background:var(--red);color:var(--paper);
  font-family:'Space Grotesk';font-weight:700;font-size:14.5px;
  padding:14px 26px;border:3px solid var(--ink);box-shadow:5px 5px 0 var(--ink);
  text-decoration:none;z-index:75;letter-spacing:0.01em;
  transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .25s ease;
  opacity:0;pointer-events:none;display:none;
}
.sticky-cta-mobile.visible{transform:translateX(-50%) translateY(0);opacity:1;pointer-events:auto;}
.sticky-cta-mobile:hover,.sticky-cta-mobile:active{transform:translateX(-50%) translateY(-3px);box-shadow:8px 8px 0 var(--ink);}
@media (max-width:820px){.sticky-cta-mobile{display:inline-block;}}

/* Logo tilt subtil au scroll */
.logo{transition:transform .35s cubic-bezier(.2,.75,.25,1);transform-origin:left center;}

/* Boutons primaires : effet "shimmer" au hover */
.btn-primary{position:relative;overflow:hidden;}
.btn-primary::before{
  content:"";position:absolute;top:0;left:-100%;width:55%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,0.22),transparent);
  transition:left .55s ease;pointer-events:none;
}
.btn-primary:hover::before{left:120%;}

/* Cards : effet "lift + tilt" subtil au hover (desktop only) */
@media (hover:hover) and (min-width:981px){
  .panel:hover,.mode:hover,.loottile:hover,.tcard:hover{transform:translate(-4px,-5px) rotate(-0.3deg);}
  .mode.feat:hover{transform:translate(-4px,-5px) rotate(0.3deg);}
}

/* Liens du footer : underline cool */
.fcol a{position:relative;transition:color .15s ease;}
.fcol a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1px;background:var(--red);transition:right .25s ease;}
.fcol a:hover::after{right:0;}

/* Easter egg popup : amélioration de l'animation */
.eggpop{animation:eggpop-bg .25s ease;}
@keyframes eggpop-bg{from{background:rgba(21,18,11,0);}to{background:rgba(21,18,11,0.4);}}

/* Tanu FAB : pulse subtil */
@keyframes tanu-pulse{0%,100%{transform:scale(1);}50%{transform:scale(1.04);}}
@media (prefers-reduced-motion:no-preference){
  .tanu-fab{animation:tanu-pulse 3.4s ease-in-out infinite;}
}

/* Smooth scroll global */
html{scroll-behavior:smooth;}

/* Sélection texte : couleur de marque */
::selection{background:var(--red);color:var(--paper);}
::-moz-selection{background:var(--red);color:var(--paper);}

/* Print : éviter de bouffer la marge sur audit/contact */
@media print{
  .tanu-fab,.sticky-cta-mobile,.eggpop,.egg{display:none !important;}
  body{background:#fff;color:#000;}
  .hero,.bigfoot{padding:20px 0;}
}

/* === SCROLL PROGRESS, READING TIME, A11Y === */

/* Barre de progression scroll en haut */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0%;
  background:linear-gradient(90deg,var(--red) 0%,var(--red) 50%,var(--navy) 100%);
  z-index:90;transition:width .08s linear;pointer-events:none;
}

/* Tag temps de lecture sur articles blog */
.reading-time{
  display:inline-block;margin-left:10px;padding:3px 10px;
  background:var(--ink);color:var(--paper);
  font-family:'Space Mono',monospace;font-size:11px;font-weight:700;
  letter-spacing:0.06em;text-transform:uppercase;
}

/* Skip to content : invisible, visible au focus clavier */
.skip-link{
  position:absolute;top:-100px;left:8px;z-index:200;
  background:var(--red);color:var(--paper);
  padding:10px 18px;border:3px solid var(--ink);box-shadow:4px 4px 0 var(--ink);
  font-family:'Space Grotesk';font-weight:700;font-size:14px;text-decoration:none;
  transition:top .2s ease;
}
.skip-link:focus{top:8px;}

/* Focus visible global amélioré */
*:focus-visible{outline:3px solid var(--red);outline-offset:3px;border-radius:2px;}
button:focus-visible,a:focus-visible{outline-offset:4px;}

/* Reduced motion : respecter la préférence utilisateur */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
    scroll-behavior:auto !important;
  }
  .tanu-fab,.mtrack{animation:none !important;}
  .scroll-progress{transition:none !important;}
}

/* High contrast mode (Windows) */
@media (forced-colors:active){
  .btn,.panel,.mode,.tool{border-width:2px;}
}
