/* =========================================================
   BJJ INDUSTRY — styles.css
   Palette : #16130C · #FFFFFF · #83878A · #B31128
   Theme jour/nuit · rouge reserve a l'action "S'abonner"
   Site concu par Bloom · Louka Nicolaeff · bloomagency.fr
   ========================================================= */
@font-face{font-family:"Quanta Grotesk Pro";src:url("../fonts/quanta/QuantaGroteskPro-Thin.woff2") format("woff2");font-weight:100;font-style:normal;font-display:swap}
@font-face{font-family:"Quanta Grotesk Pro";src:url("../fonts/quanta/QuantaGroteskPro-ExtraLight.woff2") format("woff2");font-weight:200;font-style:normal;font-display:swap}
@font-face{font-family:"Quanta Grotesk Pro";src:url("../fonts/quanta/QuantaGroteskPro-Light.woff2") format("woff2");font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:"Quanta Grotesk Pro";src:url("../fonts/quanta/QuantaGroteskPro-Regular.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Quanta Grotesk Pro";src:url("../fonts/quanta/QuantaGroteskPro-Medium.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Quanta Grotesk Pro";src:url("../fonts/quanta/QuantaGroteskPro-SemiBold.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Quanta Grotesk Pro";src:url("../fonts/quanta/QuantaGroteskPro-Bold.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Quanta Grotesk Pro";src:url("../fonts/quanta/QuantaGroteskPro-ExtraBold.woff2") format("woff2");font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:"Quanta Grotesk Pro";src:url("../fonts/quanta/QuantaGroteskPro-Black.woff2") format("woff2");font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:"Quanta Grotesk Pro";src:url("../fonts/quanta/QuantaGroteskPro-BlackItalic.woff2") format("woff2");font-weight:900;font-style:italic;font-display:swap}
@font-face{font-family:"Archivo";src:url("../fonts/archivo-latin-100-normal.woff2") format("woff2");font-weight:100;font-style:normal;font-display:swap}
@font-face{font-family:"Archivo";src:url("../fonts/archivo-latin-200-normal.woff2") format("woff2");font-weight:200;font-style:normal;font-display:swap}
@font-face{font-family:"Archivo";src:url("../fonts/archivo-latin-300-normal.woff2") format("woff2");font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:"Archivo";src:url("../fonts/archivo-latin-400-normal.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Archivo";src:url("../fonts/archivo-latin-500-normal.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Archivo";src:url("../fonts/archivo-latin-600-normal.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Archivo";src:url("../fonts/archivo-latin-700-normal.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Archivo";src:url("../fonts/archivo-latin-800-normal.woff2") format("woff2");font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:"Archivo";src:url("../fonts/archivo-latin-900-normal.woff2") format("woff2");font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:"Archivo";src:url("../fonts/archivo-latin-900-italic.woff2") format("woff2");font-weight:900;font-style:italic;font-display:swap}

:root{--noir:#16130C;--blanc:#FFFFFF;--gris:#83878A;--rouge:#B31128;--rouge-d:#8E0C1F;
--f-display:"Quanta Grotesk Pro","Archivo",system-ui,sans-serif;
--f-text:"Helvetica Neue","Helvetica","Arimo",Arial,sans-serif;
--f:var(--f-display);--maxw:1240px;--r-lg:18px;--r-md:12px;--pad:clamp(20px,4vw,40px);}
:root,[data-theme="night"]{--bg:#16130C;--bg-2:#1E1A12;--surface:#201B13;--surface-2:#272118;
--text:#F4F2EC;--text-dim:#B0B2B3;--text-mute:#8d877c;--border:rgba(255,255,255,.11);--border-strong:rgba(255,255,255,.22);
--hair:rgba(255,255,255,.10);--logo-night:block;--logo-day:none;--inv-bg:#F4F2EC;--inv-text:#16130C;}
[data-theme="day"]{--bg:#F4F2EC;--bg-2:#FFFFFF;--surface:#FFFFFF;--surface-2:#EEEBE3;
--text:#16130C;--text-dim:#5A554C;--text-mute:#9b958a;--border:rgba(22,19,12,.13);--border-strong:rgba(22,19,12,.26);
--hair:rgba(22,19,12,.10);--logo-night:none;--logo-day:block;--inv-bg:#16130C;--inv-text:#F4F2EC;}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--f-text);font-weight:400;background:var(--bg);color:var(--text);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden;max-width:100%;transition:background .35s,color .35s}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
section{padding:clamp(70px,9vw,118px) 0;position:relative}
:focus-visible{outline:2px solid var(--rouge);outline-offset:3px;border-radius:4px}
::selection{background:var(--rouge);color:#fff}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}}

.h-display{font-weight:900;text-transform:uppercase;letter-spacing:-.02em;line-height:.92}
.h1{font-size:clamp(44px,8.4vw,108px)}
.h2{font-size:clamp(32px,4.8vw,58px)}
.h3{font-weight:800;text-transform:uppercase;letter-spacing:-.01em;font-size:clamp(20px,2.4vw,26px);line-height:1.05}
.punch{font-weight:900;font-style:italic;text-transform:uppercase;letter-spacing:.01em}
.eyebrow{font-weight:800;text-transform:uppercase;font-size:12px;letter-spacing:.28em;color:var(--text);display:flex;align-items:center;gap:12px;margin-bottom:20px}
.eyebrow span:first-child{color:var(--text-mute)}
.eyebrow::after{content:"";flex:1;height:1px;background:var(--hair)}
.lead{font-weight:500;font-size:clamp(16px,1.6vw,19px);color:var(--text-dim);max-width:60ch}
.body-s{font-weight:400;font-size:15px;color:var(--text-dim)}
.num-light{font-weight:200;font-variant-numeric:tabular-nums}
.label{font-weight:600;text-transform:uppercase;font-size:11px;letter-spacing:.18em;color:var(--text-mute)}
.ghost{position:absolute;inset:auto 0 0 0;pointer-events:none;user-select:none;overflow:hidden;line-height:.8;font-weight:100;text-transform:uppercase;letter-spacing:-.02em;color:transparent;-webkit-text-stroke:1px var(--hair);font-size:clamp(90px,18vw,260px);white-space:nowrap}

.btn{display:inline-flex;align-items:center;gap:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:13px;background:var(--text);color:var(--bg);padding:14px 26px;border-radius:999px;border:1.5px solid var(--text);cursor:pointer;transition:transform .2s,background .2s,color .2s,border-color .2s}
.btn:hover{transform:translateY(-1px);background:transparent;color:var(--text)}
.btn.ghost-btn{background:transparent;border-color:var(--border-strong);color:var(--text)}
.btn.ghost-btn:hover{border-color:var(--text)}
.btn.sub{background:var(--rouge);border-color:var(--rouge);color:#fff}
.btn.sub:hover{background:var(--rouge-d);border-color:var(--rouge-d);color:#fff}

/* ===== HEADER ===== */
.skip-link{position:absolute;left:10px;top:10px;transform:translateY(-160%);background:var(--rouge);color:#fff;padding:11px 18px;border-radius:8px;z-index:100;font-family:var(--f-display);font-weight:700;text-transform:uppercase;font-size:12px;letter-spacing:.1em;transition:transform .2s}
.skip-link:focus{transform:none}
.site-header{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .3s,border-color .3s;border-bottom:1px solid transparent}
.site-header.scrolled{background:color-mix(in srgb,var(--bg) 90%,transparent);backdrop-filter:blur(12px);border-bottom-color:var(--border)}
.nav{display:flex;align-items:center;gap:clamp(12px,2.5vw,28px);max-width:var(--maxw);margin:0 auto;padding:12px var(--pad);min-height:72px}
.brand{display:inline-flex;align-items:center;flex-shrink:0}
.brand img{height:clamp(34px,4.2vw,44px);width:auto}
.logo-night{display:var(--logo-night)}
.logo-day{display:var(--logo-day)}
.nav-links{display:flex;gap:clamp(16px,2.2vw,28px);list-style:none;margin:0 auto;padding:0;align-items:center}
.nav-links a{display:inline-block;font-family:var(--f-display);font-weight:600;text-transform:uppercase;font-size:12.5px;letter-spacing:.13em;color:var(--text-dim);transition:color .2s;padding:6px 2px;white-space:nowrap}
.nav-links a:hover{color:var(--text)}
.nav-links a[aria-current="page"]{color:var(--text);border-bottom:2px solid var(--rouge);padding-bottom:4px}
.nav-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}
.nav-cta-m{display:none}
.theme-toggle{background:transparent;border:1.5px solid var(--border-strong);color:var(--text);width:44px;height:44px;border-radius:999px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:border-color .2s,transform .2s;flex-shrink:0}
.theme-toggle:hover{border-color:var(--text);transform:translateY(-1px)}
.theme-toggle svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2}
[data-theme="night"] .theme-toggle .i-moon{display:none}
[data-theme="day"] .theme-toggle .i-sun{display:none}
.burger{display:none;background:none;border:0;cursor:pointer;width:44px;height:44px;position:relative;flex-shrink:0;border-radius:8px}
.burger span{position:absolute;left:11px;right:11px;height:2px;background:var(--text);border-radius:2px;transition:transform .3s,opacity .3s,top .3s}
.burger span:nth-child(1){top:16px}.burger span:nth-child(2){top:21px}.burger span:nth-child(3){top:26px}
.burger[aria-expanded="true"] span:nth-child(1){top:21px;transform:rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){top:21px;transform:rotate(-45deg)}
@media(max-width:920px){
  .brand,.nav-actions{position:relative;z-index:70}
  .nav-actions{margin-left:auto}
  .nav-links{position:fixed;inset:0;height:100svh;background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:4px;margin:0;padding:96px 24px 48px;transform:translateY(-100%);transition:transform .35s ease;overflow-y:auto;z-index:65}
  .nav-links.open{transform:none}
  .nav-links a{font-size:21px;letter-spacing:.06em;padding:14px}
  .nav-cta-d{display:none}
  .nav-cta-m{display:block;margin-top:18px}
  .nav-cta-m .btn{font-size:15px;padding:16px 38px}
  .burger{display:block}
}
@media(max-width:380px){.nav-actions{gap:8px}.theme-toggle{width:42px;height:42px}}

.hero{min-height:100svh;display:flex;align-items:flex-end;position:relative;overflow:hidden;padding:0;background:#100d08}
.hero-media{position:absolute;inset:0}
.hero-media video,.hero-media img{width:100%;height:100%;object-fit:cover;filter:grayscale(.7) contrast(1.12) brightness(.6)}
.hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,13,8,.55) 0%,rgba(16,13,8,.2) 38%,rgba(16,13,8,.95) 100%)}
.hero-inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:150px var(--pad) 60px;color:#F4F2EC}
.hero-kicker{display:block;margin-bottom:18px;color:#cfcabf}
.hero h1{max-width:12ch}
.hero h1 .red{color:transparent;-webkit-text-stroke:2px rgba(255,255,255,.9)}
.hero .lead{margin-top:22px;color:#d6d2c8}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.hero-cta .btn{background:#F4F2EC;color:#16130C;border-color:#F4F2EC}
.hero-cta .btn:hover{background:transparent;color:#fff;border-color:#fff}
.hero-cta .btn.ghost-btn{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.hero-cta .btn.ghost-btn:hover{border-color:#fff}
.hero-cta .btn.sub{background:var(--rouge);color:#fff;border-color:var(--rouge)}
.hero-cta .btn.sub:hover{background:var(--rouge-d);border-color:var(--rouge-d)}
.hero-stats{display:flex;gap:clamp(24px,5vw,62px);flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.14);margin-top:50px;padding:26px 0 36px}
.hero-stats .stat b{display:block;font-weight:200;font-size:clamp(34px,4.6vw,58px);line-height:1;color:#fff;font-variant-numeric:tabular-nums}
.hero-stats .stat b em{font-style:normal;font-weight:200;color:#9a9489}
.hero-stats .stat span{font-weight:600;text-transform:uppercase;font-size:11px;letter-spacing:.18em;color:#8d877c}

.tape{background:var(--inv-bg);transform:rotate(-1.6deg);padding:14px 0;overflow:hidden;position:relative;z-index:3;width:108%;margin-left:-4%}
.tape .track{display:flex;gap:48px;white-space:nowrap;animation:slide 26s linear infinite;will-change:transform}
.tape span{font-weight:900;font-style:italic;text-transform:uppercase;font-size:clamp(15px,2vw,20px);color:var(--inv-text);letter-spacing:.04em}
.tape span i{font-style:normal;color:var(--gris)}
@keyframes slide{to{transform:translateX(-50%)}}

.light{background:var(--bg-2);color:var(--text);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}

.ph{position:relative;overflow:hidden;border-radius:var(--r-lg);background:var(--surface-2);min-height:200px}
.ph img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;filter:grayscale(.85) contrast(1.06) brightness(.85);transition:transform .6s,filter .5s}
.ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 38%,rgba(16,13,8,.88));pointer-events:none}
.ph:hover img{transform:scale(1.045);filter:grayscale(.35) contrast(1.08) brightness(.95)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.card-d{aspect-ratio:4/5;display:flex;align-items:flex-end;padding:24px;position:relative}
.card-d .in{position:relative;z-index:2}
.card-d .in .label{color:#cfcabf}
.card-d .in h3{margin-top:6px;color:#fff}
.card-d .in p{font-weight:400;font-size:13.5px;color:#cfcabf;margin-top:8px;max-width:30ch}
.card-d .num{position:absolute;top:18px;right:22px;z-index:2;font-weight:100;font-size:54px;line-height:1;color:rgba(255,255,255,.4)}
.card-d .more{margin-top:14px;font-weight:700;text-transform:uppercase;font-size:11.5px;letter-spacing:.16em;color:#fff}
.card-d.feature{background:var(--surface)}
.card-d.feature .in p{color:var(--text-dim)}
.card-d.feature .in h3,.card-d.feature .more,.card-d.feature .in .label{color:var(--text)}
.card-d.feature .num{color:var(--border-strong)}

.price-card{background:var(--surface);border:1px solid var(--border);border-radius:22px;padding:clamp(28px,4vw,46px);position:relative;overflow:hidden}
.price-card.featured{border-color:var(--text);border-width:2px}
.price-card .tagtop{position:absolute;top:0;right:0;background:var(--text);color:var(--bg);font-weight:700;text-transform:uppercase;font-size:10.5px;letter-spacing:.16em;padding:8px 18px;border-radius:0 0 0 14px}
.price-line{display:flex;align-items:baseline;gap:8px;margin:18px 0 6px}
.price-line .amount{font-weight:200;font-size:clamp(64px,9vw,104px);line-height:.9;color:var(--text);font-variant-numeric:tabular-nums}
.price-line .per{font-weight:600;text-transform:uppercase;font-size:12px;letter-spacing:.16em;color:var(--text-mute)}
.tick{list-style:none;margin-top:22px;display:flex;flex-direction:column;gap:11px}
.tick li{padding-left:26px;position:relative;font-weight:500;font-size:15px;color:var(--text-dim)}
.tick li::before{content:"";position:absolute;left:0;top:7px;width:12px;height:7px;border-left:2.5px solid var(--text);border-bottom:2.5px solid var(--text);transform:rotate(-45deg)}
.tick li.off{opacity:.45}.tick li.off::before{border-color:var(--text-mute)}
.small-print{font-weight:400;font-size:12.5px;color:var(--text-mute);margin-top:20px}

.plan-wrap{overflow-x:auto;border-radius:var(--r-lg);border:1px solid var(--border)}
table.plan{border-collapse:collapse;width:100%;min-width:760px;background:var(--surface)}
table.plan th,table.plan td{border:1px solid var(--border);padding:12px 10px;text-align:center;vertical-align:middle}
table.plan th{font-weight:800;text-transform:uppercase;font-size:11.5px;letter-spacing:.14em;color:var(--text-dim);background:var(--surface-2)}
table.plan td{font-weight:400;font-size:13px;color:var(--text-dim)}
table.plan td .slot{display:block;border-radius:8px;padding:8px 6px;font-weight:700;text-transform:uppercase;font-size:11px;letter-spacing:.08em}
.slot small{font-weight:400;letter-spacing:0}
.slot.s-muscu{background:color-mix(in srgb,var(--text) 9%,transparent);color:var(--text)}
.slot.s-jjb{background:color-mix(in srgb,var(--text) 16%,transparent);color:var(--text)}
.slot.s-lutte{background:color-mix(in srgb,var(--text) 24%,transparent);color:var(--text)}
.slot.s-grap{background:color-mix(in srgb,var(--gris) 42%,transparent);color:var(--text)}
.slot.s-danse{background:color-mix(in srgb,var(--gris) 22%,transparent);color:var(--text)}
.legend{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.legend span{font-weight:600;text-transform:uppercase;font-size:10.5px;letter-spacing:.14em;padding:7px 14px;border-radius:999px}

.faq{border-top:1px solid var(--border)}
.faq details{border-bottom:1px solid var(--border)}
.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:22px 4px;font-weight:700;font-size:clamp(15px,1.8vw,18px);color:var(--text)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-weight:300;font-size:26px;color:var(--text-dim);transition:transform .25s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .ans{padding:0 4px 24px;font-weight:400;font-size:15px;color:var(--text-dim);max-width:70ch}

.coach .ph{aspect-ratio:3/4}
.coach h3{margin-top:14px;color:var(--text)}
.coach .label{margin-top:4px}

.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(24px,4vw,56px);align-items:start}
form .field{margin-bottom:18px}
form label{display:block;font-weight:600;text-transform:uppercase;font-size:11px;letter-spacing:.18em;color:var(--text-mute);margin-bottom:8px}
form input,form select,form textarea{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:12px;color:var(--text);font-family:var(--f-text);font-weight:400;font-size:15px;padding:14px 16px;transition:border-color .2s}
form input:focus,form select:focus,form textarea:focus{outline:none;border-color:var(--text)}
form textarea{min-height:140px;resize:vertical}
.info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px}
.info-card+.info-card{margin-top:16px}
.info-card h3{color:var(--text);margin-bottom:10px}
.info-card p,.info-card a{font-weight:400;font-size:15px;color:var(--text-dim)}
.info-card a:hover{color:var(--text)}

.legal dl{max-width:760px}
.legal dt{font-weight:700;text-transform:uppercase;font-size:12px;letter-spacing:.16em;color:var(--text);margin-top:26px}
.legal dd{font-weight:400;font-size:15px;color:var(--text-dim);margin-top:6px}

.cta-final{background:var(--inv-bg);color:var(--inv-text);text-align:center;position:relative;overflow:hidden}
.cta-final .diag{position:absolute;inset:-40% -20%;opacity:.06;background:repeating-linear-gradient(105deg,var(--inv-text) 0 3px,transparent 3px 110px)}
.cta-final h2{font-size:clamp(34px,6vw,76px);position:relative}
.cta-final .btn{background:var(--inv-text);color:var(--inv-bg);border-color:var(--inv-text);margin-top:30px;position:relative}
.cta-final .btn:hover{background:transparent;color:var(--inv-text)}
.cta-final .btn.sub{background:var(--rouge);color:#fff;border-color:var(--rouge)}
.cta-final .btn.sub:hover{background:var(--rouge-d);border-color:var(--rouge-d)}

footer{background:var(--bg-2);padding:64px 0 30px;border-top:1px solid var(--border)}
.f-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:34px}
.f-grid img{height:50px;width:auto}
.f-grid p{font-weight:400;font-size:14px;color:var(--text-dim);margin-top:14px;max-width:36ch}
.f-grid h4{font-weight:800;text-transform:uppercase;font-size:12px;letter-spacing:.2em;color:var(--text-dim);margin-bottom:14px}
.f-grid ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.f-grid ul a{font-weight:400;font-size:14px;color:var(--text-mute)}
.f-grid ul a:hover{color:var(--text)}
.f-bottom{border-top:1px solid var(--border);margin-top:44px;padding-top:22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-weight:400;font-size:12.5px;color:var(--text-mute)}
.f-bottom a{color:var(--text-dim)}.f-bottom a:hover{color:var(--text)}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}

@media(max-width:880px){.grid-3{grid-template-columns:1fr 1fr}.contact-grid,.grid-2{grid-template-columns:1fr}.f-grid{grid-template-columns:1fr}}
@media(max-width:560px){.grid-3{grid-template-columns:1fr}.hero-stats{gap:22px}}


/* ---- Header au-dessus du hero sombre : forcer blanc tant que non scrollé (accueil) ---- */
.site-header.has-hero:not(.scrolled):not(.nav-open) .logo-night{display:block}
.site-header.has-hero:not(.scrolled):not(.nav-open) .logo-day{display:none}
.site-header.has-hero:not(.scrolled):not(.nav-open) .nav-links a{color:rgba(255,255,255,.82)}
.site-header.has-hero:not(.scrolled):not(.nav-open) .nav-links a:hover,
.site-header.has-hero:not(.scrolled):not(.nav-open) .nav-links a[aria-current="page"]{color:#fff}
.site-header.has-hero:not(.scrolled):not(.nav-open) .theme-toggle{color:#fff;border-color:rgba(255,255,255,.32)}
.site-header.has-hero:not(.scrolled):not(.nav-open) .theme-toggle:hover{border-color:#fff}
.site-header.has-hero:not(.scrolled):not(.nav-open) .burger span{background:#fff}

/* ---- Helvetica (Arimo) self-hosté pour le texte courant ---- */
@font-face{font-family:"Arimo";src:url("../fonts/arimo-latin-400-normal.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Arimo";src:url("../fonts/arimo-latin-500-normal.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Arimo";src:url("../fonts/arimo-latin-700-normal.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}

/* ---- Quanta/Archivo réservé aux displays, labels, boutons, nav ---- */
.h-display,.h1,.h2,.h3,.punch,.eyebrow,.label,.num-light,.ghost,.btn,
.nav ul a,.theme-toggle,
.hero-kicker,.hero-stats .stat b,.hero-stats .stat span,.tape span,
.card-d .in .label,.card-d .in h3,.card-d .more,.card-d .num,
.price-line .amount,.price-line .per,.price-card .tagtop,
table.plan th,table.plan td .slot,.legend span,
.faq summary,.coach h3,form label,.info-card h3,.legal dt,
.cta-final h2,.f-grid h4{font-family:var(--f-display)}

/* Le texte courant hérite déjà de --f-text (body). Renforcé ici : */
.lead,.body-s,.small-print,.faq .ans,.info-card p,.info-card a,
.legal dd,.f-grid p,.f-grid ul a,.f-bottom,.tick li{font-family:var(--f-text)}
