/* =========================================================
   L'Accélérateur Carnet Plein® by Mad Makers
   Landing artisans du bâtiment - styles globaux
   ========================================================= */

/* ========== FONTS ==========
   AeonikPro + DotConnect (custom, .woff2 dans assets/fonts/).
   Fallback : Geist (Bunny Fonts) + Geist Mono.
   Voir assets/fonts/README.md pour licence et drop-in. */
@font-face{
  font-family:'AeonikPro';
  src:url('assets/fonts/AeonikPro-Regular.woff2') format('woff2');
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'AeonikPro';
  src:url('assets/fonts/AeonikPro-Medium.woff2') format('woff2');
  font-weight:500;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'DotConnect';
  src:url('assets/fonts/DotConnect-Medium.woff2') format('woff2');
  font-weight:500;font-style:normal;font-display:swap;
}

/* ========== TOKENS ========== */
:root{
  /* Palette */
  --encre: #0a0a0a;
  --encre-soft: #1a1c18;
  --papier: #f3f2ee;
  --papier-chaud: #ebe7dc;
  --paper-dark: #0f0f0e;
  --accent: #e0541b;
  --accent-hover: #c8471a;
  --accent-soft: rgba(224, 84, 27, 0.12);
  --ink: #1a1c18;
  --ink-dim: #3a3d36;
  --paper: #e8e6df;
  --paper-dim: rgba(255,255,255,0.62);
  --paper-dimmer: rgba(255,255,255,0.35);
  --rule-dark: rgba(255,255,255,0.10);
  --rule-light: rgba(0,0,0,0.08);
  --rule-strong: rgba(0,0,0,0.16);
  --green: #2d9a5f;
  --red-soft: #c43c2a;

  /* Typo - AeonikPro everywhere, DotConnect pour les accents <em> */
  --f-body: 'AeonikPro', 'Geist', ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --f-display: 'AeonikPro', 'Geist', ui-sans-serif, system-ui, sans-serif;
  --f-accent: 'DotConnect', 'AeonikPro', 'Geist', ui-sans-serif, system-ui, sans-serif;
  --f-mono: 'Geist Mono', 'SF Mono', Consolas, monospace;
  --f-cta: 'AeonikPro', 'Geist', ui-sans-serif, system-ui, sans-serif;
  --opentype-features: "dlig", "ss02", "ss08";

  /* Espacement */
  --section-pad: clamp(60px, 8vw, 120px);
  --container-max: 1280px;
  --container-pad: clamp(20px, 4vw, 48px);

  /* Rayons */
  --r-xs: 6px;
  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 24px;
  --r-xl: 32px;
}

/* ========== RESET / BASE ========== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--papier);
  color:var(--ink);
  font-family:var(--f-body);
  font-size:16px;
  font-weight:400;
  line-height:1.5;
  letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-feature-settings:var(--opentype-features);
}
img,video{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{margin:0;padding:0;list-style:none}
::selection{background:var(--accent);color:#fff}

/* ========== TYPO ========== */
h1,h2,h3,h4{
  font-family:var(--f-display);
  font-weight:500;
  margin:0;
  letter-spacing:-0.02em;
  line-height:1.0;
  color:var(--encre);
  font-feature-settings:var(--opentype-features);
}
h1{font-size:clamp(44px, 7vw, 101px);font-weight:500;line-height:0.9;letter-spacing:-0.025em}
h2.big-title{font-size:clamp(30px, 4.2vw, 56px);font-weight:500;line-height:1.0;letter-spacing:-0.025em;text-wrap:pretty}
h3{font-size:clamp(22px, 2.4vw, 32px);font-weight:500;letter-spacing:-0.02em;line-height:1.1}
em{
  font-style:normal;
  font-family:var(--f-accent);
  font-weight:500;
  color:var(--accent);
  font-feature-settings:var(--opentype-features);
}

p{margin:0 0 1em 0}
p:last-child{margin-bottom:0}
.lead{font-size:clamp(17px, 1.7vw, 21px);line-height:1.4;letter-spacing:-0.012em;color:var(--ink-dim);max-width:64ch}
.dark .lead{color:var(--paper)}
.body-l{font-size:17px;line-height:1.65}
.dim{opacity:0.55}

/* Eyebrow */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--f-mono);font-size:12px;font-weight:500;
  text-transform:uppercase;letter-spacing:0.14em;
  color:var(--accent);
}
.eyebrow .sq{
  width:8px;height:8px;background:var(--accent);
  display:inline-block;border-radius:1px;
}
.dark .eyebrow{color:var(--accent)}
.dark .eyebrow .sq{background:var(--accent)}
@media (max-width:640px){
  .eyebrow-regions{display:none}
}

/* ========== LAYOUT ========== */
section{padding:var(--section-pad) 0;position:relative}
.container{
  max-width:var(--container-max);
  margin:0 auto;
  padding:0 var(--container-pad);
  position:relative;
}
.dark{background:var(--encre);color:var(--paper)}
.dark h1,.dark h2,.dark h3,.dark h4{color:#fff}
.cream{background:var(--papier)}
.cream-warm{background:var(--papier-chaud)}

/* ========== BUTTONS ========== */
.btn-primary,.btn-secondary,.btn-ghost{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--f-cta);font-weight:500;font-size:13px;
  text-transform:uppercase;letter-spacing:0.08em;
  padding:18px 28px;border-radius:999px;
  transition:transform .2s ease, background .2s ease, color .2s ease;
  white-space:nowrap;
}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}
.btn-secondary{background:var(--encre);color:#fff}
.btn-secondary:hover{background:var(--encre-soft);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--encre);border:1px solid var(--rule-strong)}
.btn-ghost:hover{background:var(--encre);color:#fff;border-color:var(--encre)}
.dark .btn-ghost{color:#fff;border-color:var(--rule-dark)}
.dark .btn-ghost:hover{background:#fff;color:var(--encre)}
.btn-primary .ar,.btn-secondary .ar,.btn-ghost .ar{
  font-size:14px;transition:transform .25s ease;
}
.btn-primary:hover .ar,.btn-secondary:hover .ar{transform:translateX(3px)}

/* ========== NAV ========== */
.nav{
  position:fixed;top:0;left:50%;transform:translateX(-50%);
  width:calc(100% - 32px);max-width:1220px;
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 20px;
  background:rgba(243,242,238,0.78);
  backdrop-filter:blur(14px) saturate(160%);
  -webkit-backdrop-filter:blur(14px) saturate(160%);
  border:1px solid var(--rule-light);
  border-top:none;
  border-radius:0 0 20px 20px;
  z-index:100;
  transition:background .3s ease, border-color .3s ease;
}
.nav.is-scrolled{
  background:rgba(243,242,238,0.94);
  border-color:var(--rule-strong);
}
.brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.brand .mk{
  width:30px;height:30px;background:var(--encre);
  border-radius:7px;
  position:relative;
}
.brand .mk::after{
  content:'';position:absolute;inset:8px;
  background:var(--accent);border-radius:2px;
}
.brand-name{
  font-family:var(--f-display);font-weight:500;font-size:17px;
  color:var(--encre);letter-spacing:-0.01em;
}
.brand-name b{color:var(--accent);font-family:var(--f-accent);font-weight:500}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{
  font-family:var(--f-body);font-size:14px;font-weight:500;
  padding:8px 14px;border-radius:999px;
  color:var(--ink);transition:background .2s, color .2s;
}
.nav-links a:hover{background:rgba(0,0,0,0.05);color:var(--encre)}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--encre);color:#fff;
  padding:10px 18px;border-radius:999px;
  font-family:var(--f-cta);font-weight:500;font-size:12px;
  text-transform:uppercase;letter-spacing:0.08em;
  transition:background .2s, transform .2s;
}
.nav-cta:hover{background:var(--accent);transform:translateY(-1px)}
.nav-burger{
  display:none;width:36px;height:36px;
  flex-direction:column;justify-content:center;align-items:center;gap:5px;
}
.nav-burger span{
  display:block;width:18px;height:1.6px;
  background:var(--encre);border-radius:2px;
  transition:transform .25s, opacity .25s;
}
@media (max-width:880px){
  .nav-links{
    position:absolute;top:calc(100% + 12px);left:0;right:0;
    flex-direction:column;align-items:stretch;
    padding:18px;
    background:var(--papier);
    border:1px solid var(--rule-strong);
    border-radius:24px;
    opacity:0;pointer-events:none;
    transform:translateY(-8px);
    transition:opacity .25s, transform .25s;
  }
  .nav-links a{padding:14px 16px;border-radius:14px;font-size:16px}
  .nav.is-open .nav-links{opacity:1;pointer-events:auto;transform:translateY(0)}
  .nav.is-open .nav-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.is-open .nav-burger span:nth-child(2){opacity:0}
  .nav.is-open .nav-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav-cta{display:none}
  .nav-burger{display:flex}
}

/* ========== HERO ========== */
.hero{
  min-height:100vh;
  padding:140px 0 80px;
  display:flex;align-items:center;
  position:relative;overflow:hidden;
  background:var(--encre);
  color:#fff;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-video{width:100%;height:100%;object-fit:cover}
.hero-tint{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(10,10,10,0.55) 0%, rgba(10,10,10,0.78) 80%, rgba(10,10,10,0.92) 100%),
    radial-gradient(at 70% 30%, rgba(224,84,27,0.20), transparent 55%);
}
.hero-inner{position:relative;z-index:2;width:100%}
.hero h1{color:#fff;max-width:18ch}
.hero h1 em{color:var(--accent)}
.hero-sub{
  font-size:clamp(17px, 1.6vw, 21px);line-height:1.55;
  max-width:58ch;color:var(--paper);
  margin:22px 0 32px;
}
.hero-chips{
  display:flex;flex-wrap:wrap;gap:10px;margin-bottom:36px;
}
.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 16px;border-radius:999px;
  background:rgba(255,255,255,0.08);
  border:1px solid var(--rule-dark);
  font-family:var(--f-mono);font-size:12px;
  letter-spacing:0.05em;color:#fff;
  backdrop-filter:blur(6px);
}
.chip .dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 4px rgba(224,84,27,0.20);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 4px rgba(224,84,27,0.20)}
  50%{box-shadow:0 0 0 8px rgba(224,84,27,0.05)}
}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-scroll-hint{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-mono);font-size:12px;text-transform:uppercase;
  color:var(--paper-dimmer);letter-spacing:0.12em;
  padding:8px 0;
}
.hero-scroll-hint:hover{color:#fff}

/* ========== FIT GRID (POUR QUI) ========== */
.fit-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
  margin-top:48px;
}
@media (max-width:780px){.fit-grid{grid-template-columns:1fr}}
.fit-col{
  background:#fff;border:1px solid var(--rule-light);
  border-radius:var(--r-lg);
  padding:32px;
  position:relative;
}
.dark .fit-col{
  background:rgba(255,255,255,0.03);
  border-color:var(--rule-dark);
}
.fit-col.fit-yes{border-left:3px solid var(--green)}
.fit-col.fit-no{border-left:3px solid var(--red-soft)}
.fit-head{
  display:flex;align-items:center;gap:12px;
  font-family:var(--f-cta);font-size:13px;font-weight:500;
  text-transform:uppercase;letter-spacing:0.08em;
  margin-bottom:24px;
}
.fit-icon{
  width:32px;height:32px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.fit-yes .fit-icon{background:var(--green);color:#fff}
.fit-no .fit-icon{background:var(--red-soft);color:#fff}
.fit-col ul{display:flex;flex-direction:column;gap:14px}
.fit-col li{
  position:relative;padding-left:24px;font-size:16px;line-height:1.5;
  color:var(--ink);
}
.dark .fit-col li{color:var(--paper)}
.fit-col li::before{
  content:'';position:absolute;left:0;top:9px;
  width:8px;height:8px;border-radius:50%;
}
.fit-yes li::before{background:var(--green)}
.fit-no li::before{background:var(--red-soft)}

/* ========== PAIN CARDS ========== */
.pain-grid{
  display:grid;grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:18px;margin-top:48px;
}
.pain-card{
  background:#fff;border:1px solid var(--rule-light);
  border-radius:var(--r-md);padding:28px;
  position:relative;transition:transform .3s, box-shadow .3s;
}
.dark .pain-card{
  background:rgba(255,255,255,0.04);
  border-color:var(--rule-dark);
}
.pain-card:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,0.08)}
.pain-card .quote{
  font-family:var(--f-accent);font-size:22px;font-weight:500;
  line-height:1.25;color:var(--encre);letter-spacing:-0.012em;
  margin:0;position:relative;
}
.dark .pain-card .quote{color:#fff}
.pain-card .quote::before{
  content:'"';position:absolute;top:-18px;left:-4px;
  font-size:64px;color:var(--accent);opacity:0.4;
  font-family:var(--f-display);
}
.pain-card .who{
  font-family:var(--f-mono);font-size:11px;text-transform:uppercase;
  letter-spacing:0.12em;color:var(--ink-dim);
  margin-top:20px;
}
.dark .pain-card .who{color:var(--paper-dim)}

/* ========== BUNDLE COMPONENTS ========== */
.bundle-grid{
  display:grid;grid-template-columns:repeat(2, 1fr);gap:24px;
  margin-top:56px;
}
@media (max-width:880px){.bundle-grid{grid-template-columns:1fr}}
.bundle-item{
  background:#fff;border:1px solid var(--rule-light);
  border-radius:var(--r-lg);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .3s, box-shadow .3s;
}
.bundle-item:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(0,0,0,0.10)}
.bundle-item-mockup{
  aspect-ratio:3/2;
  background:var(--papier-chaud);
  overflow:hidden;position:relative;
  border-bottom:1px solid var(--rule-light);
}
.bundle-item-mockup img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.bundle-item-body{
  padding:28px 28px 30px;
  display:flex;flex-direction:column;gap:12px;
  flex:1;
}
.bundle-item-head{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.bundle-item-num{
  font-family:var(--f-mono);font-size:13px;font-weight:500;
  color:var(--accent);letter-spacing:0.08em;
}
.bundle-item-value{
  font-family:var(--f-mono);font-size:11px;
  background:var(--accent-soft);color:var(--accent);
  padding:5px 11px;border-radius:999px;
  text-transform:uppercase;letter-spacing:0.08em;font-weight:500;
}
.bundle-item h3{
  font-family:var(--f-display);font-size:26px;font-weight:500;
  line-height:1.15;color:var(--encre);
  margin-top:6px;
}
.bundle-item p{
  font-size:15.5px;line-height:1.55;color:var(--ink-dim);
}
.bundle-item-04-copy{
  background:var(--papier);
  display:grid;grid-template-columns:1fr 1px 1fr;gap:18px;
  padding:24px;align-items:start;
}
.copy-col{padding:8px}
.copy-divider{background:var(--rule-light)}
.copy-label{
  font-family:var(--f-mono);font-size:10px;font-weight:500;
  text-transform:uppercase;letter-spacing:0.14em;
  margin-bottom:14px;
}
.copy-label.before{color:var(--ink-dim);opacity:0.55}
.copy-label.after{color:var(--accent)}
.copy-text{
  font-family:var(--f-display);font-size:15px;line-height:1.35;
  font-weight:500;color:var(--encre);
}
.copy-col.before .copy-text{opacity:0.5;color:var(--ink-dim)}
.copy-stat{
  display:inline-block;margin-top:12px;
  font-family:var(--f-mono);font-size:10px;
  padding:3px 8px;border-radius:4px;letter-spacing:0.06em;
}
.copy-stat.bad{background:rgba(196,60,42,0.10);color:var(--red-soft)}
.copy-stat.good{background:rgba(45,154,95,0.12);color:var(--green)}
@media (max-width:520px){
  .bundle-item-04-copy{grid-template-columns:1fr;gap:8px}
  .copy-divider{display:none}
}

/* ========== ROADMAP ========== */
.roadmap{margin-top:56px;position:relative}
.roadmap-rail{
  position:relative;height:40px;margin-bottom:36px;
  display:flex;align-items:center;
}
.roadmap-rail::before{
  content:'';position:absolute;left:5%;right:5%;top:50%;height:1.5px;
  background:linear-gradient(90deg, var(--accent), var(--accent) 100%);
  background-size:200% 100%;
  opacity:0.3;
}
.roadmap-rail::after{
  content:'';position:absolute;left:5%;top:50%;height:1.5px;
  background:var(--accent);
  width:var(--rail-progress, 0%);
  transition:width 2.4s ease;
}
.roadmap-nodes{
  position:absolute;inset:0;
  display:flex;justify-content:space-between;align-items:center;
  padding:0 5%;
}
.roadmap-node{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  position:relative;
}
.roadmap-node-dot{
  width:12px;height:12px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 6px var(--papier);
  position:relative;z-index:2;
}
.dark .roadmap-node-dot{box-shadow:0 0 0 6px var(--encre)}
.roadmap-node-lbl{
  font-family:var(--f-mono);font-size:11px;font-weight:500;
  color:var(--accent);letter-spacing:0.08em;
  position:absolute;top:24px;white-space:nowrap;
}

.roadmap-grid{
  display:grid;grid-template-columns:repeat(4, 1fr);gap:20px;
}
@media (max-width:980px){.roadmap-grid{grid-template-columns:repeat(2, 1fr)}}
@media (max-width:560px){.roadmap-grid{grid-template-columns:1fr}}
.roadmap-card{
  background:#fff;border:1px solid var(--rule-light);
  border-radius:var(--r-lg);padding:26px;
  display:flex;flex-direction:column;gap:8px;
  transition:transform .3s, box-shadow .3s;
}
.dark .roadmap-card{
  background:rgba(255,255,255,0.04);
  border-color:var(--rule-dark);
}
.roadmap-card:hover{transform:translateY(-2px)}
.roadmap-card-head{
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--f-mono);font-size:11px;letter-spacing:0.1em;
  color:var(--accent);text-transform:uppercase;
}
.roadmap-card-when{color:var(--ink-dim);font-weight:500}
.dark .roadmap-card-when{color:var(--paper-dim)}
.roadmap-card h3{
  font-family:var(--f-display);font-size:22px;line-height:1.15;
  margin-top:4px;color:var(--encre);
}
.dark .roadmap-card h3{color:#fff}
.roadmap-card p{font-size:15px;line-height:1.55;color:var(--ink-dim)}
.dark .roadmap-card p{color:var(--paper)}

/* ========== GARANTIE / SEAL ========== */
.guarantee{
  background:var(--encre);color:#fff;
  position:relative;overflow:hidden;
}
.guarantee::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(at 80% 30%, rgba(224,84,27,0.18), transparent 50%);
  pointer-events:none;
}
.guarantee-grid{
  display:grid;grid-template-columns:280px 1fr;gap:80px;align-items:center;
  position:relative;z-index:2;
}
@media (max-width:880px){
  .guarantee-grid{grid-template-columns:1fr;gap:48px;text-align:center}
  .guarantee-seal{margin:0 auto}
  .seal-text{align-items:center}
}
.guarantee h2.big-title{color:#fff;margin-top:16px}
.guarantee p{color:var(--paper);font-size:17px;line-height:1.6;max-width:62ch}
.guarantee p strong{color:#fff;font-weight:500}
.legal-note{
  font-size:13px;color:var(--paper-dimmer);
  margin-top:18px;line-height:1.5;letter-spacing:0;
}

/* The Seal */
.guarantee-seal{
  width:260px;height:260px;
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.seal-ring{
  position:absolute;inset:0;border-radius:50%;
  border:2px solid var(--accent);
  animation:slow-spin 60s linear infinite;
}
.seal-ring::before,.seal-ring::after{
  content:'';position:absolute;inset:14px;border-radius:50%;
  border:1px dashed rgba(224,84,27,0.55);
}
.seal-ring::after{
  inset:auto;width:8px;height:8px;
  top:-5px;left:50%;transform:translateX(-50%);
  background:var(--accent);border:none;border-radius:50%;
  box-shadow:0 0 0 4px rgba(224,84,27,0.30);
}
@keyframes slow-spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.seal-content{
  position:relative;width:200px;height:200px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;
}
.seal-content::before{
  content:'';position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle, rgba(224,84,27,0.10), transparent 70%);
}
.seal-eyebrow{
  font-family:var(--f-mono);font-size:9px;letter-spacing:0.22em;
  text-transform:uppercase;color:var(--accent);
  position:relative;z-index:2;
}
.seal-name{
  font-family:var(--f-accent);font-weight:500;
  font-size:30px;line-height:1;color:#fff;
  margin:6px 0;position:relative;z-index:2;
  letter-spacing:-0.02em;
}
.seal-name sup{font-size:11px;font-style:normal;color:var(--accent)}
.seal-foot{
  font-family:var(--f-mono);font-size:10px;letter-spacing:0.18em;
  color:var(--paper-dim);text-transform:uppercase;
  position:relative;z-index:2;
}

/* ========== BONUS STACK ========== */
.bonus-intro{max-width:60ch}
.bonus-grid{
  display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:18px;margin-top:48px;
}
.bonus-card{
  background:var(--papier-chaud);
  border-radius:var(--r-lg);
  overflow:hidden;
  display:flex;flex-direction:column;
  border:1px solid var(--rule-light);
  transition:transform .3s;
}
.dark .bonus-card{background:rgba(255,255,255,0.04);border-color:var(--rule-dark)}
.bonus-card:hover{transform:translateY(-3px)}
.bonus-mockup{
  aspect-ratio:4/3;background:#fff;overflow:hidden;
  border-bottom:1px solid var(--rule-light);
}
.bonus-card.bonus-loom .bonus-mockup{aspect-ratio:16/9}
.bonus-mockup img{width:100%;height:100%;object-fit:cover}
.bonus-body{padding:22px 24px 24px;display:flex;flex-direction:column;gap:8px;flex:1}
.bonus-head{
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--f-mono);font-size:11px;letter-spacing:0.08em;
  text-transform:uppercase;
}
.bonus-num{color:var(--accent);font-weight:500}
.bonus-value{
  background:var(--accent-soft);color:var(--accent);
  padding:4px 9px;border-radius:999px;font-size:10.5px;
}
.bonus-card h4{
  font-family:var(--f-display);font-size:21px;line-height:1.2;
  margin-top:2px;color:var(--encre);
}
.dark .bonus-card h4{color:#fff}
.bonus-card p{font-size:14.5px;line-height:1.5;color:var(--ink-dim);margin-top:4px}
.dark .bonus-card p{color:var(--paper)}

/* ========== RÉCAP VALEUR ========== */
.recap{
  background:var(--encre);color:#fff;
  border-radius:var(--r-xl);
  padding:clamp(40px, 6vw, 72px);
  margin-top:64px;
  position:relative;overflow:hidden;
}
.recap::before{
  content:'';position:absolute;top:-50%;right:-20%;
  width:560px;height:560px;
  background:radial-gradient(circle, rgba(224,84,27,0.18), transparent 60%);
  pointer-events:none;
}
.recap-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;
  position:relative;z-index:2;
}
@media (max-width:780px){.recap-grid{grid-template-columns:1fr;gap:32px}}
.recap-numbers{display:flex;flex-direction:column;gap:18px}
.recap-line{
  display:flex;align-items:baseline;justify-content:space-between;
  padding:14px 0;border-bottom:1px solid var(--rule-dark);
  gap:24px;
}
.recap-line:last-child{border-bottom:none}
.recap-line-lbl{
  font-family:var(--f-mono);font-size:12px;letter-spacing:0.10em;
  text-transform:uppercase;color:var(--paper-dim);
}
.recap-line-val{
  font-family:var(--f-display);font-weight:500;font-size:24px;
  color:#fff;letter-spacing:-0.01em;
}
.recap-line-val.strike{text-decoration:line-through;opacity:0.45;font-size:20px}
.recap-line-val.accent{color:var(--accent)}
.recap-final{
  background:rgba(224,84,27,0.10);
  border:1px solid rgba(224,84,27,0.40);
  padding:24px;border-radius:var(--r-lg);
  margin-top:18px;
}
.recap-final-lbl{
  font-family:var(--f-mono);font-size:11px;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--accent);
}
.recap-final-val{
  font-family:var(--f-display);font-size:42px;font-weight:500;
  color:#fff;line-height:1;margin-top:6px;letter-spacing:-0.02em;
}
.recap-final-foot{
  font-family:var(--f-body);font-size:13px;color:var(--paper-dim);
  margin-top:8px;
}
.recap-side{display:flex;flex-direction:column;gap:14px}
.recap-side h3{
  font-family:var(--f-display);font-size:30px;line-height:1.15;
  font-weight:500;color:#fff;
}
.recap-side h3 em{color:var(--accent)}
.recap-side ul{display:flex;flex-direction:column;gap:10px}
.recap-side li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:15px;color:var(--paper);line-height:1.5;
}
.recap-side li::before{
  content:'✓';color:var(--accent);font-weight:500;
  flex-shrink:0;line-height:1.5;
}
.recap-side .pay-options{
  font-family:var(--f-mono);font-size:12px;letter-spacing:0.06em;
  color:var(--paper-dim);text-transform:uppercase;
  padding-top:14px;border-top:1px solid var(--rule-dark);margin-top:8px;
}

/* ========== COHORT ========== */
.cohort{
  background:var(--papier-chaud);
  position:relative;overflow:hidden;
}
.cohort::before{
  content:'';position:absolute;top:-30%;left:-20%;
  width:600px;height:600px;
  background:radial-gradient(circle, rgba(224,84,27,0.10), transparent 65%);
  pointer-events:none;
}
.cohort-card{
  background:#fff;border:1px solid var(--rule-strong);
  border-radius:var(--r-xl);
  padding:clamp(36px, 5vw, 60px);
  max-width:840px;margin:0 auto;
  position:relative;z-index:2;
  display:flex;flex-direction:column;gap:24px;align-items:center;
  text-align:center;
}
.cohort-status{
  display:inline-flex;align-items:center;gap:10px;
  padding:9px 18px;border-radius:999px;
  background:var(--accent-soft);
  border:1px solid rgba(224,84,27,0.30);
  font-family:var(--f-mono);font-size:12px;
  letter-spacing:0.08em;text-transform:uppercase;
  color:var(--accent);font-weight:500;
}
.cohort-status .dot{
  width:8px;height:8px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 4px rgba(224,84,27,0.20);
  animation:pulse 2s ease-in-out infinite;
}
.cohort h2{font-size:clamp(32px, 4.5vw, 52px);line-height:1.05}
.cohort h2 em{color:var(--accent)}
.cohort-stats{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:48px;margin:18px 0 8px;
}
.cohort-stat{display:flex;flex-direction:column;align-items:center;gap:6px}
.cohort-stat-num{
  font-family:var(--f-display);font-size:54px;font-weight:500;
  color:var(--encre);line-height:1;letter-spacing:-0.02em;
}
.cohort-stat-num em{color:var(--accent)}
.cohort-stat-lbl{
  font-family:var(--f-mono);font-size:11px;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--ink-dim);
}
.cohort-deadline{
  font-family:var(--f-body);font-size:15px;color:var(--ink-dim);
  line-height:1.55;max-width:46ch;
}
.cohort-deadline strong{color:var(--encre);font-weight:500}
.cohort-cta{margin-top:8px}

/* ========== PREUVES ========== */
.preuves-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:48px;
}
@media (max-width:780px){.preuves-grid{grid-template-columns:1fr}}
.preuve-card{
  background:#fff;border:1px solid var(--rule-light);
  border-radius:var(--r-lg);
  padding:32px;
  display:flex;flex-direction:column;gap:18px;
}
.dark .preuve-card{
  background:rgba(255,255,255,0.04);
  border-color:var(--rule-dark);
}
.preuve-head{display:flex;align-items:center;gap:18px}
.preuve-photo{
  width:64px;height:64px;border-radius:50%;
  overflow:hidden;flex-shrink:0;
  background:var(--papier-chaud);
}
.preuve-photo img{width:100%;height:100%;object-fit:cover}
.preuve-info .name{
  font-family:var(--f-display);font-weight:500;font-size:20px;
  color:var(--encre);
}
.dark .preuve-info .name{color:#fff}
.preuve-info .role{
  font-family:var(--f-mono);font-size:11px;letter-spacing:0.10em;
  text-transform:uppercase;color:var(--accent);
  margin-top:4px;
}
.preuve-card p{
  font-size:15.5px;line-height:1.55;color:var(--ink-dim);
}
.dark .preuve-card p{color:var(--paper)}
.preuve-foot{
  font-family:var(--f-mono);font-size:11px;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--ink-dim);
  display:flex;flex-wrap:wrap;gap:14px;
  padding-top:14px;border-top:1px solid var(--rule-light);
}
.dark .preuve-foot{color:var(--paper-dim);border-color:var(--rule-dark)}

/* ========== FAQ ========== */
.faq-list{
  display:flex;flex-direction:column;gap:10px;
  max-width:880px;margin:48px auto 0;
}
.faq-item{
  background:#fff;border:1px solid var(--rule-light);
  border-radius:var(--r-md);
  overflow:hidden;
  transition:border-color .2s;
}
.dark .faq-item{
  background:rgba(255,255,255,0.04);
  border-color:var(--rule-dark);
}
.faq-item[open]{border-color:var(--accent)}
.faq-item summary{
  display:flex;align-items:center;gap:18px;
  padding:22px 26px;cursor:pointer;
  list-style:none;
  transition:background .2s;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{background:var(--papier-chaud)}
.dark .faq-item summary:hover{background:rgba(255,255,255,0.02)}
.faq-num{
  font-family:var(--f-mono);font-size:13px;font-weight:500;
  color:var(--accent);min-width:30px;
}
.faq-q{
  flex:1;font-family:var(--f-body);font-size:17px;font-weight:500;
  color:var(--encre);
}
.dark .faq-q{color:#fff}
.faq-toggle{
  width:32px;height:32px;border-radius:50%;
  border:1px solid var(--rule-strong);
  position:relative;flex-shrink:0;
  font-size:0;color:transparent;
  transition:transform .25s, background .2s, border-color .2s;
}
.faq-toggle::before,
.faq-toggle::after{
  content:"";
  position:absolute;top:50%;left:50%;
  background:var(--ink-dim);
  border-radius:1px;
  transition:background .2s;
}
.faq-toggle::before{
  width:11px;height:1.5px;
  transform:translate(-50%,-50%);
}
.faq-toggle::after{
  width:1.5px;height:11px;
  transform:translate(-50%,-50%);
}
.dark .faq-toggle{border-color:var(--rule-dark)}
.dark .faq-toggle::before,
.dark .faq-toggle::after{background:var(--paper-dim)}
.faq-item[open] .faq-toggle{
  transform:rotate(45deg);
  background:var(--accent);border-color:var(--accent);
}
.faq-item[open] .faq-toggle::before,
.faq-item[open] .faq-toggle::after{
  background:#fff;
}
.faq-a{
  padding:0 26px 24px 74px;
  font-size:15.5px;line-height:1.65;color:var(--ink-dim);
}
.dark .faq-a{color:var(--paper)}
.faq-a p{margin:0 0 12px}
.faq-a p:last-child{margin-bottom:0}
.faq-a strong{color:var(--encre);font-weight:500}
.dark .faq-a strong{color:#fff}

/* ========== FOOTER CTA ========== */
.footer-cta{
  position:relative;overflow:hidden;
  padding:clamp(80px, 12vw, 160px) 0;
  text-align:center;color:#fff;
  background:var(--encre);
}
.footer-cta-video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:0;opacity:0.40;
}
.footer-cta-tint{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg, rgba(10,10,10,0.55), rgba(10,10,10,0.85)),
    radial-gradient(at 50% 30%, rgba(224,84,27,0.20), transparent 60%);
}
.footer-cta-inner{position:relative;z-index:2;max-width:760px;margin:0 auto}
.footer-cta h2{
  font-family:var(--f-display);font-weight:500;
  font-size:clamp(46px, 8vw, 101px);line-height:0.88;color:#fff;
  letter-spacing:-0.025em;
}
.footer-cta h2 em{color:var(--accent)}
.footer-cta p{
  font-size:clamp(16px, 1.6vw, 19px);line-height:1.5;
  color:var(--paper);margin:24px auto 36px;max-width:46ch;
}
.footer-cta-buttons{
  display:flex;flex-wrap:wrap;gap:18px;justify-content:center;
  align-items:center;
}
.footer-cta-buttons .btn-primary{
  font-size:14px;padding:20px 32px;
}
.footer-cta-buttons .link{
  font-family:var(--f-mono);font-size:14px;color:var(--paper);
  text-decoration:underline;text-underline-offset:4px;
  transition:color .2s;
}
.footer-cta-buttons .link:hover{color:var(--accent)}

/* ========== FOOTER ========== */
.foot{
  background:var(--paper-dark);color:var(--paper);
  padding:80px 0 32px;
}
.foot-grid{
  max-width:var(--container-max);margin:0 auto;
  padding:0 var(--container-pad);
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;
}
@media (max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:520px){.foot-grid{grid-template-columns:1fr}}
.foot-brand{display:flex;flex-direction:column;gap:14px}
.foot-brand .mk{
  width:38px;height:38px;background:#fff;border-radius:8px;
  position:relative;
}
.foot-brand .mk::after{
  content:'';position:absolute;inset:9px;
  background:var(--accent);border-radius:2px;
}
.foot-brand .addr{
  font-size:14px;line-height:1.5;color:var(--paper-dim);
}
.foot-brand .tag{
  font-family:var(--f-accent);font-size:18px;font-weight:500;
  color:#fff;margin-top:8px;
}
.foot-col h6{
  font-family:var(--f-mono);font-size:11px;font-weight:500;
  text-transform:uppercase;letter-spacing:0.14em;
  color:var(--accent);margin:0 0 18px 0;
}
.foot-col ul{display:flex;flex-direction:column;gap:11px}
.foot-col a{
  font-size:14px;color:var(--paper);transition:color .2s;
}
.foot-col a:hover{color:#fff}
.foot-col.contact .lbl{
  display:block;font-family:var(--f-mono);font-size:10px;
  text-transform:uppercase;letter-spacing:0.1em;
  color:var(--paper-dimmer);margin-bottom:3px;
}
.foot-bottom{
  max-width:var(--container-max);margin:48px auto 0;
  padding:24px var(--container-pad) 0;
  border-top:1px solid var(--rule-dark);
  display:flex;justify-content:space-between;align-items:center;
  gap:16px;flex-wrap:wrap;
  font-family:var(--f-mono);font-size:11px;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--paper-dim);
}
.foot-bottom .social{display:flex;gap:14px}
.foot-bottom .social a{
  width:32px;height:32px;border-radius:50%;
  border:1px solid var(--rule-dark);
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--f-display);font-size:14px;color:var(--paper);
  transition:background .2s, color .2s, border-color .2s;
}
.foot-bottom .social a:hover{
  background:var(--accent);color:#fff;border-color:var(--accent);
}

/* ========== BACK TO TOP ========== */
.back-top{
  position:fixed;bottom:24px;right:24px;
  width:46px;height:46px;border-radius:50%;
  background:var(--encre);color:#fff;
  display:flex;align-items:center;justify-content:center;
  z-index:90;
  opacity:0;pointer-events:none;
  transform:translateY(10px);
  transition:opacity .3s, transform .3s, background .2s;
}
.back-top.is-visible{opacity:1;pointer-events:auto;transform:translateY(0)}
.back-top:hover{background:var(--accent)}
.back-top svg{width:18px;height:18px}

/* ========== REVEAL ANIMATIONS ========== */
[data-reveal]{opacity:0;transform:translateY(20px);transition:opacity .8s ease, transform .8s ease}
[data-reveal].is-revealed{opacity:1;transform:translateY(0)}
[data-reveal-stagger] > *{opacity:0;transform:translateY(16px);transition:opacity .7s ease, transform .7s ease}
[data-reveal-stagger].is-revealed > *{opacity:1;transform:translateY(0)}
[data-reveal-stagger].is-revealed > *:nth-child(1){transition-delay:0ms}
[data-reveal-stagger].is-revealed > *:nth-child(2){transition-delay:90ms}
[data-reveal-stagger].is-revealed > *:nth-child(3){transition-delay:180ms}
[data-reveal-stagger].is-revealed > *:nth-child(4){transition-delay:270ms}
[data-reveal-stagger].is-revealed > *:nth-child(5){transition-delay:360ms}
[data-reveal-stagger].is-revealed > *:nth-child(6){transition-delay:450ms}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  [data-reveal],[data-reveal-stagger] > *{opacity:1;transform:none}
}

/* ========== SECTION HEADS ========== */
.section-head{margin-bottom:0}
.section-head h2{margin-top:14px}
.section-head .lead{margin-top:18px}

/* Big number variant */
.num-anchor{
  font-family:var(--f-accent);font-weight:500;
  color:var(--accent);
}

/* ========== MÉTIERS GRID (la niche en visages) ========== */
.metiers-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:32px;flex-wrap:wrap;margin-bottom:32px;
}
.metiers-counter{
  font-family:var(--f-mono);font-size:13px;
  color:var(--ink-dim);letter-spacing:0.04em;text-transform:lowercase;
  white-space:nowrap;
}

.metier-filters{
  position:relative;
  display:inline-flex;gap:0;flex-wrap:nowrap;
  margin:0 0 32px;
  padding:6px;
  background:var(--papier-chaud);
  border-radius:999px;
  max-width:100%;
  overflow-x:auto;
  scrollbar-width:none;
  -ms-overflow-style:none;
}
.metier-filters::-webkit-scrollbar{display:none}

/* Sliding thumb : un seul element qui glisse entre les chips */
.metier-chip-thumb{
  position:absolute;
  top:6px;bottom:6px;left:0;
  width:0;
  background:var(--encre);
  border-radius:999px;
  pointer-events:none;
  z-index:1;
  transform:translate3d(0, 0, 0);
  transition:
    transform .5s cubic-bezier(.32, .72, 0, 1),
    width .5s cubic-bezier(.32, .72, 0, 1);
  will-change:transform, width;
}
.metier-chip-thumb.is-init{opacity:0;transition:none}

.metier-chip{
  position:relative;z-index:2;
  font-family:var(--f-cta);font-size:14px;font-weight:500;
  color:var(--encre);
  padding:10px 18px;border-radius:999px;
  display:inline-flex;align-items:center;gap:8px;
  letter-spacing:-0.006em;
  background:transparent;
  cursor:pointer;
  flex-shrink:0;
  white-space:nowrap;
  transition:color .4s cubic-bezier(.32, .72, 0, 1);
}
.metier-chip.is-active{color:#fff}
.metier-chip:not(.is-active):hover{color:var(--accent)}
.metier-chip:not(.is-active):hover .count{color:var(--accent);opacity:0.8}
.metier-chip:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
.metier-chip .count{
  font-family:var(--f-mono);font-size:12px;opacity:0.55;
  transition:color .4s cubic-bezier(.32, .72, 0, 1), opacity .4s cubic-bezier(.32, .72, 0, 1);
}
.metier-chip.is-active .count{opacity:0.7;color:rgba(255,255,255,0.65)}

/* Cleanup : on cache les anciens labels "01, 02, 03" sur les tuiles métier */
.placeholder-initials{display:none}

.metier-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:16px;
}
@media (max-width:1100px){.metier-grid{grid-template-columns:repeat(3, 1fr)}}
@media (max-width:760px){.metier-grid{grid-template-columns:repeat(2, 1fr)}}

.metier-tile{
  position:relative;
  border-radius:20px;
  /* clip-path : haut ouvert (-40% au-dessus pour la tete), sides+bas fermes,
     coins arrondis 20px sur la zone visible. Remplace overflow:visible qui
     liberait tous les cotes. */
  clip-path:inset(-40% 0 0 0 round 20px);
  -webkit-clip-path:inset(-40% 0 0 0 round 20px);
  isolation:isolate;
  aspect-ratio:4/3.4;
  background:#1f2628;
  color:#fff;
  text-decoration:none;
  display:block;
  opacity:1;
  transform:translate3d(0, 0, 0);
  transition:
    transform .58s cubic-bezier(.32, .72, 0, 1),
    opacity .22s cubic-bezier(.4, 0, .2, 1);
  will-change:transform, opacity;
}
/* Leavers / arrivers : subtle scale, opacity stays mostly up (Apple icon style) */
.metier-tile.is-leaving{
  opacity:0;
  transform:scale(0.86);
  pointer-events:none;
}
.metier-tile.is-arriving{
  opacity:0;
  transform:scale(0.86);
}
.metier-tile.is-hidden{display:none}
.metier-tile:hover:not(.is-leaving):not(.is-arriving){
  transform:translate3d(0, -4px, 0);
}

.metier-portrait{
  position:absolute;inset:0;
  border-radius:20px;
  background:
    /* Spotlight halo derriere la tete - donne du relief premium App Store */
    radial-gradient(65% 55% at 50% 28%, rgba(255,255,255,0.10), transparent 72%),
    /* Vignettage subtil aux coins bas pour ancrer le sujet */
    radial-gradient(130% 80% at 50% 110%, rgba(0,0,0,0.55), transparent 65%),
    /* Base degradee chaude-sombre, plus riche que charcoal plat */
    radial-gradient(120% 100% at 50% 0%, #232a2c 0%, #15191b 75%);
  /* visible: laisser l'image deborder en haut */
  overflow:visible;
  /* PAS de z-index ici - pour ne pas creer de stacking context isole.
     Sans ca, le z-index:3 de l'img ne pouvait pas battre le z=2 du badge. */
}
.metier-portrait img{
  position:absolute;
  top:-10%;            /* le haut sort de la tuile */
  left:50%;
  height:110%;         /* bas pile au niveau du bas de la tuile, aucun debordement */
  width:auto;
  max-width:none;
  transform:translateX(-50%);
  display:block;
  /* Harmonisation legere du set : un peu plus de contraste, satu reduite */
  filter:contrast(1.03) saturate(0.94) drop-shadow(0 10px 18px rgba(0,0,0,0.32));
  /* Le bas du portrait se fond dans le degrade sombre, fade entierement contenu */
  -webkit-mask-image:linear-gradient(180deg, #000 0%, #000 85%, transparent 100%);
          mask-image:linear-gradient(180deg, #000 0%, #000 85%, transparent 100%);
  /* z-index 2 : au-dessus du badge (z=1), sous le degrade lisibilite (z=3) */
  z-index:2;
  pointer-events:none;
}
/* Decalage horizontal pour les PNGs ou le sujet est excentre (Olivier, Julien, Bruno) */
.metier-tile[data-shift="right"] .metier-portrait img{
  left:calc(50% + 7%);
}
.metier-portrait .placeholder-initials{display:none}
.metier-tile::after{
  content:'';position:absolute;inset:0;
  border-radius:20px;
  /* Fade lisibilite text - au-dessus du portrait pour assombrir les tenues claires */
  background:linear-gradient(180deg,
    transparent 42%,
    rgba(0,0,0,0.25) 58%,
    rgba(0,0,0,0.65) 78%,
    rgba(0,0,0,0.88) 100%);
  pointer-events:none;
  z-index:3;
}

.metier-badge{
  position:absolute;top:16px;left:16px;z-index:1;
  background:rgba(0,0,0,0.55);
  color:#fff;
  font-family:var(--f-cta);font-size:11px;font-weight:500;
  padding:5px 12px;border-radius:8px;
  letter-spacing:0;
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}

.metier-meta{
  position:absolute;left:16px;right:16px;bottom:16px;
  z-index:4;
  display:flex;align-items:flex-end;justify-content:space-between;gap:12px;
}
.metier-name{
  font-family:var(--f-body);
  font-size:19px;letter-spacing:-0.012em;
  font-weight:500;line-height:1.05;color:#fff;
}
.metier-role{
  font-family:var(--f-mono);font-size:11px;
  letter-spacing:0.06em;text-transform:uppercase;
  color:rgba(252,251,248,0.6);
  margin-top:6px;
}
.metier-arrow{
  width:36px;height:36px;border-radius:999px;
  background:rgba(255,255,255,0.10);
  color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:14px;flex-shrink:0;
  transition:background .2s, color .2s, transform .25s;
}
.metier-tile:hover .metier-arrow{
  background:var(--accent);color:#fff;
  transform:rotate(-45deg);
}

/* Stat tiles intercalés dans la grille */
.metier-stat{
  background:var(--papier-chaud);
  color:var(--encre);
  padding:24px;
  display:flex;flex-direction:column;justify-content:space-between;
  aspect-ratio:4/3.4;
}
.metier-stat::after{display:none}
.metier-stat .stat-big{
  font-family:var(--f-display);
  font-size:clamp(48px, 6vw, 84px);
  letter-spacing:-0.03em;line-height:0.85;
  font-weight:500;
  display:inline-flex;align-items:flex-start;
}
.metier-stat .stat-big sup{
  font-size:0.45em;line-height:1;margin-left:2px;margin-top:4px;
  font-weight:400;color:var(--accent);
}
.metier-stat .stat-label{
  font-size:17px;letter-spacing:-0.012em;line-height:1.3;
  color:var(--ink-dim);
}
.metier-stat.is-accent{
  background:var(--accent);
  color:#fff;
}
.metier-stat.is-accent .stat-label{color:#fff;opacity:0.92}
.metier-stat.is-accent .stat-big{color:#fff}
.metier-stat.is-accent .stat-big sup{color:#fff;opacity:0.7}
.metier-stat.is-join{
  background:var(--encre);color:#fff;
  text-decoration:none;cursor:pointer;
  transition:transform .2s;
}
.metier-stat.is-join:hover{transform:translateY(-2px)}
.metier-stat.is-join .stat-big{
  font-family:var(--f-display);
  font-size:clamp(22px, 2.6vw, 32px);line-height:1.05;
  letter-spacing:-0.02em;
  word-break:keep-all;
  overflow-wrap:break-word;
}
.metier-stat.is-join .stat-big em{color:var(--accent)}
.metier-stat.is-join .stat-label{color:var(--paper-dim)}
.metier-stat.is-join .stat-arrow{
  width:40px;height:40px;border-radius:999px;
  background:var(--accent);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  align-self:flex-end;font-size:16px;
  transition:transform .25s;
}
.metier-stat.is-join:hover .stat-arrow{transform:rotate(-45deg)}

/* =========================================================
   APPLE-STYLE POLISH
   ========================================================= */

/* Section enter : scale subtil + fade + leger translateY */
[data-section-reveal]{
  opacity:0;
  transform:scale(0.965) translateY(28px);
  transition:
    opacity 1.1s cubic-bezier(.32, .72, 0, 1),
    transform 1.3s cubic-bezier(.32, .72, 0, 1);
  will-change:transform, opacity;
}
[data-section-reveal].is-in-view{
  opacity:1;
  transform:scale(1) translateY(0);
}

/* Hover plus iOS sur les cards interactives - lift + shadow plus marquee */
.bundle-item,
.bonus-card,
.roadmap-card,
.preuve-card,
.pain-card,
.metier-stat.is-join{
  transition:
    transform .55s cubic-bezier(.32, .72, 0, 1),
    box-shadow .55s cubic-bezier(.32, .72, 0, 1) !important;
}
.bundle-item:hover,
.bonus-card:hover,
.roadmap-card:hover,
.preuve-card:hover{
  transform:translateY(-6px) !important;
  box-shadow:0 30px 60px -16px rgba(0,0,0,0.14) !important;
}
.dark .bundle-item:hover,
.dark .roadmap-card:hover,
.dark .preuve-card:hover{
  box-shadow:0 30px 60px -16px rgba(0,0,0,0.45) !important;
}
.pain-card:hover{
  transform:translateY(-3px) !important;
  box-shadow:0 18px 38px -12px rgba(0,0,0,0.10) !important;
}

/* Hero video : prepare pour le parallax (JS le pilote) */
.hero-video{
  will-change:transform;
}

/* CTAs magnetiques : transition courte sur transform pour fluidite + un peu plus longue
   au retour pour ressentir l'aimant */
.btn-primary,
.nav-cta{
  transition:
    transform .45s cubic-bezier(.32, .72, 0, 1),
    background-color .25s ease;
}

/* Refine FAQ : transition cubic plus douce a l'open */
.faq-item summary{
  transition:background .25s cubic-bezier(.32, .72, 0, 1);
}
.faq-toggle{
  transition:transform .35s cubic-bezier(.32, .72, 0, 1),
              background .25s ease,
              border-color .25s ease !important;
}
.faq-toggle::before,
.faq-toggle::after{
  transition:background .25s ease;
}

/* Filter chip thumb : easing iOS deja en place, on s'assure du backdrop */
.metier-chip{
  transition:color .45s cubic-bezier(.32, .72, 0, 1) !important;
}

/* Bonus tactile pour les liens cliquables */
@media (hover:hover){
  .bundle-item:active,
  .bonus-card:active,
  .roadmap-card:active,
  .preuve-card:active{
    transform:translateY(-3px) scale(0.995) !important;
    transition-duration:.18s !important;
  }
}

/* Respect prefers-reduced-motion */
@media (prefers-reduced-motion:reduce){
  [data-section-reveal]{
    opacity:1!important;transform:none!important;transition:none!important;
  }
  .hero-video{transform:none!important}
  .btn-primary,.nav-cta{transform:none!important}
}
