/* ============================================================
    FIGHTERZ — Feuille de styles principale
   ============================================================ */

/* ===== BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --black:#080808;
  --black2:#111;
  --black3:#1c1c1c;
  --gold:#C9A84C;
  --gold2:#E8C96A;
  --gold-dim:rgba(201,168,76,0.15);
  --gold-border:rgba(201,168,76,0.25);
  --white:#F5F0E8;
  --white-muted:rgba(245,240,232,0.55);
  --white-dim:rgba(245,240,232,0.2);
  --border:rgba(245,240,232,0.07);
}
html{scroll-behavior:smooth}
#programme,#coachs,#format{scroll-margin-top:80px}
body{background:var(--black);color:var(--white);font-family:'Barlow',sans-serif;font-size:16px;line-height:1.6;overflow-x:hidden}

/* ===== KEYFRAMES ===== */
@keyframes lineGrow{from{width:0}to{width:60px}}
@keyframes fadeUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeLeft{from{opacity:0;transform:translateX(-40px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeRight{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(0.92)}to{opacity:1;transform:scale(1)}}
@keyframes lineGrowH{from{width:0}to{width:100%}}
@keyframes counterUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes glitch1{
  0%,100%{clip-path:inset(0 0 98% 0);transform:translateX(0)}
  20%{clip-path:inset(30% 0 50% 0);transform:translateX(-4px)}
  40%{clip-path:inset(60% 0 20% 0);transform:translateX(4px)}
  60%{clip-path:inset(10% 0 80% 0);transform:translateX(-2px)}
}
@keyframes glitch2{
  0%,100%{clip-path:inset(0 0 98% 0);transform:translateX(0)}
  20%{clip-path:inset(50% 0 30% 0);transform:translateX(4px)}
  40%{clip-path:inset(20% 0 60% 0);transform:translateX(-4px)}
  60%{clip-path:inset(80% 0 10% 0);transform:translateX(2px)}
}
@keyframes borderSweep{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
@keyframes slideInUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideOutUp{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}
@keyframes blobMove{
  0%,100%{border-radius:60% 40% 30% 70%/60% 30% 70% 40%;transform:translate(0,0) scale(1)}
  25%{border-radius:30% 60% 70% 40%/50% 60% 30% 60%;transform:translate(20px,-15px) scale(1.05)}
  50%{border-radius:50% 60% 30% 40%/40% 30% 60% 50%;transform:translate(-10px,20px) scale(0.95)}
  75%{border-radius:40% 30% 60% 70%/60% 40% 40% 30%;transform:translate(10px,10px) scale(1.02)}
}
@keyframes pulseRing{
  0%{transform:scale(1);opacity:.6}
  100%{transform:scale(1.4);opacity:0}
}
@keyframes goldSweep{from{transform:scaleX(0);transform-origin:left}to{transform:scaleX(1);transform-origin:left}}
@keyframes numPop{
  0%{transform:scale(0.5);opacity:0}
  70%{transform:scale(1.1)}
  100%{transform:scale(1);opacity:1}
}
@keyframes shimmerGold{
  0%{background-position:-200% center}
  100%{background-position:200% center}
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

/* ===== HERO INTRO ANIMATIONS ===== */
.anim{opacity:0;animation:fadeUp .7s ease forwards}
.a1{animation-delay:.1s}.a2{animation-delay:.25s}.a3{animation-delay:.4s}.a4{animation-delay:.55s}.a5{animation-delay:.7s}

/* ===== TICKER ===== */
.strip{background:var(--gold);color:var(--black);text-align:center;padding:9px 20px;font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase}

/* ===== HEADER CAROUSEL ===== */
.header-carousel{
  background:var(--gold);
  height:38px;
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}
.header-slide{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Bebas Neue',sans-serif;
  font-size:13px;
  letter-spacing:4px;
  color:var(--black);
  text-transform:uppercase;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transform:translateY(8px);
}
.header-slide.active{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
  animation:slideInUp .4s ease forwards;
}
.header-slide.leaving{
  animation:slideOutUp .35s ease forwards;
}
/* Dots de navigation */
.header-carousel-dots{
  position:absolute;
  bottom:5px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:5px;
}
.header-dot{
  width:4px;
  height:4px;
  border-radius:50%;
  background:rgba(8,8,8,0.25);
  transition:background .3s;
}
.header-dot.active{background:rgba(8,8,8,0.6)}

/* ===== NAV ===== */
nav{display:flex;justify-content:space-between;align-items:center;padding:18px 6%;border-bottom:1px solid var(--border);position:sticky;top:0;background:rgba(8,8,8,0.97);backdrop-filter:blur(10px);z-index:100}
.nav-logo{font-family:'Bebas Neue',sans-serif;font-size:32px;letter-spacing:6px;color:var(--white);line-height:1}
.nav-logo span{color:var(--gold)}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--white-muted);text-decoration:none;transition:color .2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s ease}
.nav-links a:hover{color:var(--gold)}
.nav-links a:hover::after{width:100%}
.nav-cta{background:var(--gold);color:var(--black);border:none;padding:10px 22px;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:12px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:background .2s}
.nav-cta:hover{background:var(--gold2)}

/* ===== HAMBURGER & MOBILE NAV ===== */
.nav-hamburger{display:none;flex-direction:column;justify-content:space-between;width:26px;height:18px;background:none;border:none;cursor:pointer;padding:0;z-index:200;flex-shrink:0}
.nav-hamburger span{display:block;width:100%;height:2px;background:var(--white);transition:transform .3s,opacity .3s,width .3s}
.nav-hamburger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0;width:0}
.nav-hamburger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

.nav-mobile{display:none;position:fixed;inset:0;background:rgba(8,8,8,0.98);backdrop-filter:blur(12px);z-index:150;flex-direction:column;justify-content:center;align-items:center;gap:0}
.nav-mobile.open{display:flex}
.nav-mobile a{font-family:'Bebas Neue',sans-serif;font-size:clamp(36px,10vw,56px);letter-spacing:6px;color:var(--white);text-decoration:none;padding:16px 0;transition:color .2s;border-bottom:1px solid var(--border);width:80%;text-align:center}
.nav-mobile a:last-of-type{border-bottom:none}
.nav-mobile a:hover,.nav-mobile a:focus{color:var(--gold)}
.nav-mobile-cta{background:var(--gold);color:var(--black);border:none;padding:15px 48px;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:14px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;margin-top:32px;transition:background .2s}
.nav-mobile-cta:hover{background:var(--gold2)}
.nav-mobile-close{position:absolute;top:20px;right:6%;background:none;border:none;color:var(--white-muted);font-size:32px;cursor:pointer;line-height:1;font-family:'Bebas Neue',sans-serif}

/* ===== HERO ===== */
.hero{min-height:95vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:80px 6% 60px;position:relative;overflow:hidden;gap:60px}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 30% 50%,rgba(201,168,76,0.05) 0%,transparent 70%);pointer-events:none}
.hero-ghost{position:absolute;right:-3%;top:50%;transform:translateY(-50%);font-family:'Bebas Neue',sans-serif;font-size:clamp(200px,28vw,420px);color:rgba(201,168,76,0.03);pointer-events:none;letter-spacing:-4px;line-height:1;user-select:none;white-space:nowrap}
.hero-left{position:relative;z-index:2}
.eyebrow{display:inline-flex;align-items:center;gap:10px;background:var(--gold-dim);border:1px solid var(--gold-border);padding:6px 16px;font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:28px}
.eyebrow::before{content:'';display:inline-block;width:5px;height:5px;background:var(--gold);border-radius:50%}
h1{font-family:'Bebas Neue',sans-serif;font-size:clamp(60px,8vw,110px);line-height:.92;letter-spacing:2px;color:var(--white);margin-bottom:8px}
h1 em{font-style:normal;color:var(--gold)}
.hero-divider{width:0;height:2px;background:var(--gold);margin:20px 0;animation:lineGrow .8s ease .5s forwards}
.hero-sub{font-family:'Barlow Condensed',sans-serif;font-size:clamp(16px,2vw,22px);font-weight:600;color:var(--white-muted);letter-spacing:.5px;margin-bottom:20px;text-transform:uppercase}
.hero-body{font-size:16px;color:var(--white-muted);max-width:520px;margin-bottom:32px;line-height:1.75}
.hero-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:36px}
.htag{background:var(--black3);border:1px solid var(--border);padding:5px 13px;font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:600;letter-spacing:1px;color:var(--white-muted)}
.cta-group{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.micro{font-size:11px;color:rgba(245,240,232,0.28);letter-spacing:2px;text-transform:uppercase;font-family:'Barlow Condensed',sans-serif;margin-top:16px}
.hero-right{position:relative;z-index:2;display:flex;flex-direction:column;gap:12px}
.hero-blob{position:absolute;width:500px;height:500px;background:rgba(201,168,76,0.04);right:-100px;top:50%;transform:translateY(-50%);animation:blobMove 12s ease-in-out infinite;pointer-events:none;z-index:0}

/* ===== GLITCH ===== */
.glitch-wrap{position:relative;display:inline-block}
.glitch-wrap::before,.glitch-wrap::after{content:attr(data-text);position:absolute;top:0;left:0;width:100%;height:100%;font-family:'Bebas Neue',sans-serif;font-size:inherit;letter-spacing:inherit;line-height:inherit}
.glitch-wrap::before{color:#C9A84C;animation:glitch1 4s infinite;animation-delay:2s}
.glitch-wrap::after{color:#fff;animation:glitch2 4s infinite;animation-delay:2.2s}

/* ===== BUTTONS ===== */
.btn-primary{background:var(--gold);color:var(--black);border:none;padding:15px 36px;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:14px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:background .2s,transform .15s;position:relative;overflow:hidden}
.btn-primary:hover{background:var(--gold2);transform:translateY(-1px)}
.btn-primary::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.15),transparent);transform:translateX(-100%);transition:transform 0s}
.btn-primary:hover::after{transform:translateX(100%);transition:transform .5s ease}
.btn-secondary{background:transparent;color:var(--white-muted);border:1px solid var(--gold-border);padding:15px 26px;font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:14px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s}
.btn-secondary:hover{border-color:var(--gold);color:var(--gold)}
.btn-pulse-wrap{position:relative;display:inline-block}
.btn-pulse-wrap::before,.btn-pulse-wrap::after{content:'';position:absolute;inset:-4px;border:1px solid rgba(201,168,76,0.5);animation:pulseRing 2s ease-out infinite;pointer-events:none}
.btn-pulse-wrap::after{animation-delay:1s}

/* ===== FORMAT CARDS (hero) ===== */
.format-card{background:var(--black2);border:1px solid var(--border);padding:20px 24px;display:flex;align-items:center;gap:20px;transition:border-color .3s}
.format-card:hover{border-color:var(--gold-border)}
.format-card-num{font-family:'Bebas Neue',sans-serif;font-size:40px;color:var(--gold);line-height:1;min-width:60px}
.format-card-title{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--white);margin-bottom:4px}
.format-card-text{font-size:13px;color:var(--white-muted);line-height:1.5}

/* ===== SECTIONS ===== */
section{padding:90px 6%}
.section-label{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.section-label.visible::after{content:'';display:block;height:1px;background:var(--gold);width:30px;margin-top:6px;animation:goldSweep .6s ease .3s both}
h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(38px,5vw,66px);line-height:1;letter-spacing:2px;color:var(--white);margin-bottom:24px}
h2 em{font-style:normal;color:var(--gold)}

/* ===== PARTICLES ===== */
#particles-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;opacity:0.4}

/* ===== REVEAL ANIMATIONS ===== */
.reveal{opacity:0;transition:none}
.reveal.visible{animation:fadeUp .7s cubic-bezier(.22,.68,0,1.2) forwards}
.reveal-left.visible{animation:fadeLeft .7s cubic-bezier(.22,.68,0,1.2) forwards}
.reveal-right.visible{animation:fadeRight .7s cubic-bezier(.22,.68,0,1.2) forwards}
.reveal-scale.visible{animation:scaleIn .6s cubic-bezier(.22,.68,0,1.2) forwards}
.reveal-delay-1{animation-delay:.1s!important}
.reveal-delay-2{animation-delay:.2s!important}
.reveal-delay-3{animation-delay:.3s!important}
.reveal-delay-4{animation-delay:.4s!important}
.reveal-delay-5{animation-delay:.5s!important}
.reveal-delay-6{animation-delay:.6s!important}
.gold-line{display:block;height:2px;background:var(--gold);width:0;transition:width .8s cubic-bezier(.22,.68,0,1.2)}
.gold-line.visible{width:60px}

/* ===== PROBLEM ===== */
.problem-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:40px;align-items:start}
.problem-body{font-size:17px;color:var(--white-muted);line-height:1.8;margin-bottom:28px}
.problem-list{list-style:none}
.problem-list li{padding:14px 0;border-bottom:1px solid var(--border);color:var(--white-muted);font-family:'Barlow Condensed',sans-serif;font-size:17px;font-weight:600;letter-spacing:.3px;display:flex;align-items:center;gap:14px}
.problem-list li::before{content:'×';color:var(--gold);font-size:20px;font-family:'Bebas Neue',sans-serif;flex-shrink:0}
.closing-box{border:1px solid var(--gold-border);background:var(--gold-dim);padding:28px;margin-top:0}
.closing-box p{font-size:18px;color:var(--white);line-height:1.65;font-style:italic}
.closing-box .author{font-family:'Barlow Condensed',sans-serif;font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-top:14px}

/* ===== POURQUI ===== */
.pourqui-section{background:var(--black2);padding:90px 6%}
.pourqui-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1px;background:var(--border);margin-top:40px}
.pourqui-item{background:var(--black2);padding:28px;display:flex;align-items:flex-start;gap:16px;transition:background .2s,transform .2s}
.pourqui-item:hover{background:var(--black3);transform:translateX(4px)}
.pourqui-num{font-family:'Bebas Neue',sans-serif;font-size:32px;color:var(--gold);line-height:1;flex-shrink:0;min-width:32px}
.pourqui-text{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:600;color:var(--white-muted);line-height:1.5}
.pourqui-not{margin-top:32px;padding:20px 28px;border-left:2px solid rgba(201,168,76,0.3);background:rgba(201,168,76,0.05)}
.pourqui-not-label{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(245,240,232,0.3);margin-bottom:8px}
.pourqui-not-text{font-size:14px;color:rgba(245,240,232,0.4);line-height:1.6}

/* ===== PILIERS ===== */
.piliers-section{padding:90px 6%}
.piliers-intro{font-size:17px;color:var(--white-muted);max-width:600px;line-height:1.75;margin-bottom:48px}
.piliers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--gold-border)}
.pilier-card{background:var(--black2);padding:36px 28px;position:relative;overflow:hidden;transition:background .3s,transform .3s,border-color .3s}
.pilier-card:hover{background:var(--black3);transform:translateY(-4px)}
.pilier-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold)}
.pilier-ghost-num{position:absolute;bottom:-10px;right:10px;font-family:'Bebas Neue',sans-serif;font-size:120px;color:rgba(201,168,76,0.04);line-height:1;pointer-events:none}
.pilier-ghost-num.visible{animation:numPop .6s cubic-bezier(.22,.68,0,1.2) forwards}
.pilier-num-label{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.pilier-title{font-family:'Bebas Neue',sans-serif;font-size:30px;letter-spacing:2px;color:var(--white);margin-bottom:6px}
.pilier-coach{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--white-muted);margin-bottom:20px;opacity:.5}
.pilier-list{list-style:none}
.pilier-list li{padding:8px 0;border-bottom:1px solid var(--border);color:var(--white-muted);font-size:14px;display:flex;align-items:center;gap:10px}
.pilier-list li::before{content:'—';color:var(--gold);font-size:12px;flex-shrink:0}
.pilier-result{margin-top:20px;font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:600;color:var(--gold);opacity:.8;padding-top:16px;border-top:1px solid var(--gold-border)}

/* ===== LIVRABLES ===== */
.livrables-section{background:var(--black2);padding:90px 6%}
.livrables-wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-top:48px;align-items:start}
.livrables-list{list-style:none}
.livrables-list li{padding:14px 0;border-bottom:1px solid var(--border);color:var(--white);font-family:'Barlow Condensed',sans-serif;font-size:17px;font-weight:600;display:flex;align-items:center;gap:14px;transition:color .2s,transform .2s,padding-left .2s}
.livrables-list li:hover{color:var(--gold);transform:translateX(6px);padding-left:4px}
.livrables-list li::before{content:'✓';color:var(--gold);font-size:14px;flex-shrink:0}
.livrables-sticky{position:sticky;top:90px}
.livrables-box{background:var(--black3);border:1px solid var(--gold-border);padding:36px;text-align:center}
.livrables-box h3{font-family:'Bebas Neue',sans-serif;font-size:36px;letter-spacing:2px;color:var(--white);margin-bottom:10px}
.livrables-box p{color:var(--white-muted);font-size:14px;margin-bottom:28px;line-height:1.6}

/* ===== AVANT / APRÈS ===== */
.avantapres{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--gold-border);margin-top:40px}
.avant,.apres{padding:40px}
.avant{background:var(--black2)}.apres{background:var(--black2)}
.aa-label{
  font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:3px;margin-bottom:20px;
  background:linear-gradient(90deg,var(--gold),var(--gold2),var(--gold));
  background-size:200% auto;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.apres .aa-label{animation:shimmerGold 3s linear infinite}
.aa-list{list-style:none}
.aa-list li{padding:11px 0;border-bottom:1px solid var(--border);font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:600;display:flex;align-items:center;gap:12px}
.avant .aa-list li{color:rgba(245,240,232,0.25)}.apres .aa-list li{color:var(--white)}
.avant .aa-list li::before{content:'×';color:rgba(201,168,76,0.25);font-size:18px;font-family:'Bebas Neue',sans-serif}
.apres .aa-list li::before{content:'✓';color:var(--gold);font-size:14px}

/* ===== COACHES ===== */
.coaches-section{background:var(--black2);padding:90px 6%}
.coaches-intro{font-size:17px;color:var(--white-muted);max-width:560px;line-height:1.75;margin-bottom:48px}
.coaches-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--gold-border)}
.coach-card{background:var(--black2);cursor:pointer;transition:background .25s,transform .3s;overflow:hidden;position:relative}
.coach-card:hover{background:var(--black3);transform:translateY(-4px)}
.coach-card:hover .coach-overlay{opacity:1}
.coach-img-wrap{height:360px;overflow:hidden;position:relative;background:#111;display:flex;align-items:center;justify-content:center}
.coach-img-wrap img{width:100%;height:100%;object-fit:contain;object-position:center center;filter:grayscale(20%) contrast(1.05);transition:transform .4s,filter .4s}
.coach-card:hover .coach-img-wrap img{transform:scale(1.03);filter:grayscale(0%) contrast(1.1)}
.coach-overlay{position:absolute;inset:0;background:rgba(201,168,76,0.1);opacity:0;transition:opacity .3s}
.coach-body{padding:24px}
.coach-name{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:2px;color:var(--white);margin-bottom:4px}
.coach-role{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.coach-stats{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:600;color:var(--white-muted);margin-bottom:14px}
.coach-bio{font-size:14px;color:var(--white-muted);line-height:1.6}
.coach-expand{margin-top:16px;font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);opacity:.6}
.coach-detail{display:none;padding:0 24px 24px;border-top:1px solid var(--border)}
.coach-detail.open{display:block}
.coach-detail p{font-size:14px;color:var(--white-muted);line-height:1.7;padding-top:16px}
.coach-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:48px;color:var(--gold);letter-spacing:3px}
.coaches-grid .coach-card:nth-child(1){transition-delay:0s}
.coaches-grid .coach-card:nth-child(2){transition-delay:.05s}
.coaches-grid .coach-card:nth-child(3){transition-delay:.1s}

/* ===== FORMAT ===== */
.format-section{padding:90px 6%}
.format-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--gold-border);margin-top:40px}
.format-item{background:var(--black2);padding:32px;transition:background .2s,transform .25s}
.format-item:hover{background:var(--black3);transform:translateY(-3px)}
.format-icon{font-family:'Bebas Neue',sans-serif;font-size:44px;color:var(--gold);line-height:1;margin-bottom:10px}
.format-item-title{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--white);margin-bottom:8px}
.format-item-text{font-size:14px;color:var(--white-muted);line-height:1.6}

/* ===== TUNNEL ===== */
.tunnel-section{background:var(--black2);padding:90px 6%}
.tunnel-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--gold-border);margin-top:40px}
.tunnel-step{background:var(--black2);padding:36px 28px;position:relative;transition:background .2s,transform .3s}
.tunnel-step:hover{transform:translateY(-4px)}
.tunnel-step::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold)}
.tunnel-step-num{font-family:'Bebas Neue',sans-serif;font-size:56px;color:rgba(201,168,76,0.12);line-height:1;margin-bottom:12px}
.tunnel-step-title{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:2px;color:var(--white);margin-bottom:10px}
.tunnel-step-text{font-size:14px;color:var(--white-muted);line-height:1.65}

/* ===== CTA FINAL ===== */
.cta-final{padding:120px 6%;text-align:center;position:relative;overflow:hidden}
.cta-final::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 50% 60% at 50% 50%,rgba(201,168,76,0.07) 0%,transparent 70%);pointer-events:none}
.cta-final::after{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,transparent,transparent 40px,rgba(201,168,76,0.015) 40px,rgba(201,168,76,0.015) 41px);pointer-events:none}
.cta-final h2{font-size:clamp(44px,6vw,88px);margin-bottom:20px}
.cta-final p{max-width:520px;margin:0 auto 44px;color:var(--white-muted);font-size:17px;line-height:1.75}

/* ===== FOOTER ===== */
footer{padding:32px 6%;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer-logo{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:5px}
.footer-logo span{color:var(--gold)}
footer p{font-size:12px;color:rgba(245,240,232,0.2)}

/* ===== MODAL ===== */
#modal-candidature{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.85);z-index:999;overflow-y:auto;padding:40px 20px}
.modal-inner{max-width:600px;margin:0 auto;background:var(--black2);border:1px solid rgba(201,168,76,0.3);position:relative}
.modal-header{background:var(--gold);padding:20px 32px;display:flex;justify-content:space-between;align-items:center}
.modal-header-title{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:4px;color:var(--black)}
.modal-header-sub{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:2px;color:rgba(8,8,8,0.6);text-transform:uppercase;margin-top:4px}
.modal-close{background:none;border:none;cursor:pointer;font-size:28px;color:var(--black);line-height:1;font-family:'Bebas Neue',sans-serif;padding:0;transition:opacity .2s}
.modal-close:hover{opacity:.7}
.modal-body{padding:32px}

/* Champs */
.form-step-label{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:20px}
.form-field{margin-bottom:20px}
.form-field-last{margin-bottom:28px}
.form-label{display:block;font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:rgba(245,240,232,0.5);margin-bottom:8px}
.form-label.form-label-large{margin-bottom:12px}
.form-input,.form-textarea{width:100%;background:var(--black3);border:1px solid rgba(245,240,232,0.1);color:var(--white);padding:12px 16px;font-family:'Barlow',sans-serif;font-size:15px;outline:none;transition:border-color .2s}
.form-input:focus,.form-textarea:focus{border-color:var(--gold)}
.form-textarea{resize:vertical}
.radio-group-col{display:flex;flex-direction:column;gap:8px}
.radio-group-row{display:flex;gap:12px;flex-wrap:wrap}

/* Boutons formulaire */
.form-btn-group{display:flex;gap:12px}
.form-btn-primary{background:var(--gold);color:var(--black);border:none;padding:15px 24px;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:14px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:background .2s}
.form-btn-primary:hover{background:var(--gold2)}
.form-btn-primary-full{width:100%;padding:15px}
.form-btn-primary-flex{flex:2;padding:15px}
.form-btn-secondary{flex:1;background:transparent;color:rgba(245,240,232,0.5);border:1px solid rgba(245,240,232,0.1);padding:15px;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:14px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s}
.form-btn-secondary:hover{border-color:rgba(201,168,76,0.3);color:var(--white)}

/* Écran succès */
.form-success{display:none;text-align:center;padding:20px 0}
.form-success-icon{font-family:'Bebas Neue',sans-serif;font-size:64px;color:var(--gold);line-height:1;margin-bottom:16px}
.form-success-title{font-family:'Bebas Neue',sans-serif;font-size:36px;letter-spacing:2px;color:var(--white);margin-bottom:12px}
.form-success-text{font-size:15px;color:var(--white-muted);line-height:1.7;margin-bottom:28px}
.form-success-box{background:var(--black3);border:1px solid rgba(201,168,76,0.2);padding:20px;margin-bottom:28px}
.form-success-box-label{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.form-success-box-text{font-size:14px;color:var(--white-muted);line-height:1.6}

/* Radio options */
.radio-opt{display:flex;align-items:center;gap:10px;background:var(--black3);border:1px solid rgba(245,240,232,0.08);padding:11px 16px;cursor:pointer;transition:border-color .2s;font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:600;color:rgba(245,240,232,0.6)}
.radio-opt:hover{border-color:rgba(201,168,76,0.3);color:var(--white)}
.radio-opt input[type=radio]{accent-color:var(--gold);width:16px;height:16px;flex-shrink:0}

/* ===== RESPONSIVE — 900px ===== */
@media(max-width:900px){
  .hero{grid-template-columns:1fr;min-height:auto;padding:60px 5% 40px;gap:40px}
  .hero-ghost{display:none}
  .piliers-grid,.coaches-grid,.tunnel-steps{grid-template-columns:repeat(2,1fr)}
  .problem-grid,.livrables-wrap,.avantapres,.format-grid{grid-template-columns:1fr}
}

/* ===== RESPONSIVE — 768px tablette portrait ===== */
@media(max-width:768px){
  nav{padding:16px 5%}
  .nav-links,.nav-cta{display:none}
  .nav-hamburger{display:flex}

  section{padding:64px 5%}
  .pourqui-section,.piliers-section,.livrables-section,.coaches-section,.format-section,.tunnel-section{padding:64px 5%}
  .cta-final{padding:80px 5%}

  .hero{padding:48px 5% 36px;gap:32px}
  .piliers-grid,.coaches-grid,.tunnel-steps{grid-template-columns:1fr}
  .format-grid{grid-template-columns:1fr}
  .livrables-sticky{position:static}
  .coach-img-wrap{height:300px}
  footer{flex-direction:column;text-align:center;gap:10px}
}

/* ===== RESPONSIVE — 480px mobile ===== */
@media(max-width:480px){
  nav{padding:14px 4%}
  h1{font-size:clamp(40px,12vw,68px)}
  h2{font-size:clamp(30px,9vw,50px);margin-bottom:16px}

  section{padding:48px 4%}
  .pourqui-section,.piliers-section,.livrables-section,.coaches-section,.format-section,.tunnel-section{padding:48px 4%}
  .cta-final{padding:56px 4%}

  .hero{padding:36px 4% 28px;gap:24px}
  .hero-body{font-size:15px}
  .hero-tags{gap:6px}

  .format-card{padding:14px 16px;gap:12px}
  .format-card-num{font-size:28px;min-width:40px}
  .format-card-title{font-size:14px}

  .cta-group{flex-direction:column;align-items:stretch}
  .btn-primary,.btn-secondary{text-align:center;padding:14px 20px;font-size:13px}
  .eyebrow{font-size:10px;padding:5px 12px;margin-bottom:20px}

  .pilier-card{padding:24px 18px}
  .pilier-title{font-size:26px}
  .avant,.apres{padding:24px 18px}
  .coach-img-wrap{height:240px}
  .coach-body{padding:18px}

  .tunnel-step{padding:24px 18px}
  footer{padding:24px 4%}
  .pourqui-not{padding:16px 18px}
  .livrables-box{padding:24px}

  .strip{font-size:10px;letter-spacing:2px;padding:8px 16px}
  .header-carousel{height:34px}
  .header-slide{font-size:11px;letter-spacing:2px;padding:0 12px;text-align:center;white-space:normal;line-height:1.2}

  /* Modal */
  #modal-candidature{padding:20px 12px}
  .modal-header{padding:16px 20px}
  .modal-header-title{font-size:22px;letter-spacing:2px}
  .modal-body{padding:20px}
  .radio-group-row{flex-direction:column}
  .form-btn-group{flex-direction:column}
  .form-btn-secondary,.form-btn-primary-flex{flex:none;width:100%}
}

/* ===== PREFERS-REDUCED-MOTION ===== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
  .reveal,.reveal-left,.reveal-right,.reveal-scale{opacity:1!important;transform:none!important}
  .gold-line{width:60px!important}
  #particles-canvas{display:none}
  .hero-blob{animation:none}
  .header-slide,.header-slide.active,.header-slide.leaving{animation:none;transition:opacity .01ms}
  .glitch-wrap::before,.glitch-wrap::after{display:none}
  .apres .aa-label{animation:none}
  .btn-pulse-wrap::before,.btn-pulse-wrap::after{animation:none}
  .pilier-card:hover,.coach-card:hover,.format-item:hover,.tunnel-step:hover{transform:none}
  .livrables-list li:hover{transform:none;padding-left:0}
  .pourqui-item:hover{transform:none}
}
