/* ==========================================================================
   JD PROGRAM - Editorial / Neon design system
   Gedeelde stijl voor alle pagina's. 1 plek aanpassen = overal mee.
   ========================================================================== */
:root{
  --black-void:#050304;
  --paper-white:#ffffff;
  --smoke:#3a3338;
  --neon:#ff3a1d;
  --neon-2:#ff8a3c;
  --font:'Inter',ui-sans-serif,system-ui,-apple-system,sans-serif;
  --tracking-label:0.6px;
  --tracking-display:-0.022em;
  --wrap:1080px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--black-void);color:var(--paper-white);font-family:var(--font);font-weight:400;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.6}
@media(hover:hover) and (pointer:fine){body{cursor:none}a,button{cursor:none}}
img{display:block;max-width:100%}
section{position:relative;z-index:2}
a{color:inherit}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 38px}
.glow{color:var(--neon-2);text-shadow:0 0 18px rgba(255,90,40,.55),0 0 40px rgba(255,90,40,.25)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ---------- NEON CURSOR + TRAIL ---------- */
#trail{position:fixed;inset:0;z-index:9000;pointer-events:none}
#cursor-dot{position:fixed;top:0;left:0;z-index:9100;pointer-events:none;width:8px;height:8px;border-radius:50%;
  background:var(--neon);box-shadow:0 0 10px var(--neon),0 0 22px var(--neon),0 0 40px var(--neon-2);
  transform:translate(-50%,-50%);transition:width .25s,height .25s;mix-blend-mode:screen}
#cursor-ring{position:fixed;top:0;left:0;z-index:9090;pointer-events:none;width:40px;height:40px;border-radius:50%;
  border:1px solid rgba(255,80,40,.55);box-shadow:0 0 18px rgba(255,80,40,.35),inset 0 0 12px rgba(255,80,40,.2);
  transform:translate(-50%,-50%);transition:width .3s,height .3s,border-color .3s;mix-blend-mode:screen}
body.hovering #cursor-dot{width:5px;height:5px}
body.hovering #cursor-ring{width:66px;height:66px;border-color:rgba(255,138,60,.9)}

#scroll-bar{position:fixed;top:0;left:0;height:2px;width:0;z-index:300;
  background:linear-gradient(90deg,var(--neon),var(--neon-2));box-shadow:0 0 10px var(--neon),0 0 20px var(--neon-2)}

/* ---------- INTRO (opening animation) ---------- */
#intro{position:fixed;inset:0;z-index:9999;background:#050304;display:flex;align-items:center;justify-content:center;
  transition:opacity 1s ease .2s,visibility 1s ease .2s}
#intro.done{opacity:0;visibility:hidden}
#intro .mark{width:120px;height:120px;filter:brightness(0) invert(1);opacity:0;transform:scale(.82);
  animation:introMark 1.8s cubic-bezier(.16,1,.3,1) forwards}
#intro .mark.on{filter:brightness(0) invert(1) drop-shadow(0 0 16px var(--neon)) drop-shadow(0 0 40px var(--neon-2))}
@keyframes introMark{0%{opacity:0;transform:scale(.82)}45%{opacity:1;transform:scale(1)}100%{opacity:1;transform:scale(1)}}
#intro .line{position:absolute;bottom:38%;height:1px;width:0;background:linear-gradient(90deg,transparent,var(--neon),transparent);
  box-shadow:0 0 12px var(--neon);animation:introLine 1.4s ease .6s forwards}
@keyframes introLine{to{width:220px}}

/* ---------- NAV ---------- */
.hairline{position:fixed;top:0;left:0;height:1px;width:0;z-index:200;
  background:linear-gradient(90deg,var(--neon),rgba(255,255,255,.5));box-shadow:0 0 10px rgba(255,80,40,.4);
  animation:drawLine 1.2s cubic-bezier(.16,1,.3,1) 2.8s forwards}
@keyframes drawLine{to{width:100%}}
nav{position:fixed;top:0;left:0;width:100%;z-index:210;display:flex;align-items:center;justify-content:space-between;
  padding:20px 38px;opacity:0;transform:translateY(-8px);animation:fadeNav 1s ease 3.1s forwards;
  font-size:12px;text-transform:uppercase;letter-spacing:var(--tracking-label);
  backdrop-filter:blur(8px);background:linear-gradient(180deg,rgba(5,3,4,.7),transparent)}
/* op subpagina's (zonder intro) meteen tonen */
body.no-intro nav{animation-delay:.2s}
body.no-intro .hairline{animation-delay:0s}
@keyframes fadeNav{to{opacity:1;transform:translateY(0)}}
.wordmark{display:flex;align-items:center;gap:9px;font-weight:600}
.wordmark .bar{width:1px;height:12px;background:var(--neon);box-shadow:0 0 8px var(--neon)}
.nav-links{display:flex;gap:32px}
.nav-links a,.wordmark a{text-decoration:none;opacity:.82;transition:opacity .3s,text-shadow .3s}
.nav-links a:hover{opacity:1;text-shadow:0 0 12px var(--neon)}
.pill{border:1px solid rgba(255,255,255,.85);border-radius:70px;padding:11px 22px;background:transparent;color:#fff;
  font:inherit;font-size:12px;text-transform:uppercase;letter-spacing:var(--tracking-label);display:inline-flex;align-items:center;gap:8px;
  text-decoration:none;transition:transform .35s cubic-bezier(.16,1,.3,1),background .35s,color .35s,box-shadow .35s}
.pill .dot{width:5px;height:5px;border-radius:50%;background:var(--neon);box-shadow:0 0 8px var(--neon)}
.pill:hover{background:linear-gradient(90deg,var(--neon),var(--neon-2));border-color:transparent;color:#fff;box-shadow:0 0 26px rgba(255,80,40,.6)}
.pill:hover .dot{background:#fff;box-shadow:0 0 8px #fff}

/* ---------- LOOPING LOGO HERO ---------- */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.embers{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.embers span{position:absolute;bottom:-24px;width:5px;height:5px;border-radius:50%;background:var(--neon-2);
  box-shadow:0 0 8px var(--neon),0 0 14px var(--neon-2);opacity:0;animation:rise linear infinite}
@keyframes rise{0%{transform:translateY(0) scale(.5);opacity:0}12%{opacity:.85}80%{opacity:.6}100%{transform:translateY(-92vh) scale(1.1);opacity:0}}
.hero .stage{position:relative;width:min(78vw,440px);aspect-ratio:1/1;display:grid;place-items:center;z-index:2;margin-top:clamp(14px,4vh,46px)}
.halo{position:absolute;border-radius:50%;filter:blur(44px)}
.halo.h1{width:135%;height:135%;opacity:0;
  background:conic-gradient(from 0deg,rgba(255,58,29,0),rgba(255,58,29,.6),rgba(255,138,60,.15),rgba(255,58,29,0));
  animation:haloIn 1.4s ease .3s forwards,spin 13s linear infinite}
.halo.h2{width:108%;height:108%;opacity:0;mix-blend-mode:screen;
  background:conic-gradient(from 180deg,rgba(255,138,60,0),rgba(255,138,60,.45),rgba(255,58,29,.1),rgba(255,138,60,0));
  animation:haloIn 1.4s ease .5s forwards,spinR 9s linear infinite}
@keyframes haloIn{to{opacity:.85}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes spinR{to{transform:rotate(-360deg)}}
.pulse{position:absolute;width:72%;height:72%;border-radius:50%;background:radial-gradient(circle,rgba(255,80,40,.55),transparent 65%);
  filter:blur(28px);animation:pulse 3.4s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(.9);opacity:.5}50%{transform:scale(1.1);opacity:.95}}
.logo-float{position:relative;z-index:3;width:74%;display:grid;place-items:center;animation:floaty 6s ease-in-out 2.1s infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.logo-img{width:100%;height:auto;opacity:0;transform:scale(.86);
  filter:brightness(0) invert(1) drop-shadow(0 0 12px var(--neon)) drop-shadow(0 0 30px var(--neon-2));
  animation:logoIn 1.5s cubic-bezier(.16,1,.3,1) .5s forwards,logoGlow 3.6s ease-in-out 2.1s infinite}
@keyframes logoIn{to{opacity:1;transform:scale(1)}}
@keyframes logoGlow{
  0%,100%{filter:brightness(0) invert(1) drop-shadow(0 0 9px var(--neon)) drop-shadow(0 0 22px rgba(255,138,60,.55))}
  50%{filter:brightness(0) invert(1) drop-shadow(0 0 22px var(--neon)) drop-shadow(0 0 52px var(--neon-2))}}
.logo-shine{position:absolute;inset:0;z-index:4;pointer-events:none;
  -webkit-mask:url(../img/logo/jd-logo.svg) center/contain no-repeat;mask:url(../img/logo/jd-logo.svg) center/contain no-repeat;
  background:linear-gradient(115deg,transparent 43%,rgba(255,255,255,.85) 50%,transparent 57%);
  background-size:280% 100%;mix-blend-mode:screen;opacity:0;
  animation:shineOn .1s ease 2s forwards,sweep 4.4s ease-in-out 2.2s infinite}
@keyframes shineOn{to{opacity:.9}}
@keyframes sweep{0%{background-position:180% 0}55%,100%{background-position:-120% 0}}
.hero-head{margin-top:46px;opacity:0;transform:translateY(20px);animation:headIn 1s ease 2.7s forwards;position:relative;z-index:2}
@keyframes headIn{to{opacity:1;transform:translateY(0)}}
.hero .eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:1.4px;color:var(--neon-2);margin-bottom:20px}
.hero h1{font-weight:300;font-size:clamp(30px,5vw,58px);line-height:1.1;letter-spacing:var(--tracking-display)}
.hero .lede{font-size:16px;line-height:1.55;max-width:46ch;margin:24px auto 0;opacity:.8;font-weight:300}
.hero-actions{margin-top:34px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- PAGE HEADER (subpagina's) ---------- */
.page-head{padding:160px 0 70px;text-align:center;position:relative;overflow:hidden;border-bottom:1px solid var(--smoke)}
.page-head h1{font-weight:300;font-size:clamp(32px,5vw,64px);line-height:1.08;letter-spacing:var(--tracking-display)}
.page-head p{max-width:60ch;margin:20px auto 0;opacity:.78;font-weight:300}

/* ---------- SECTIONS ---------- */
.reveal .up{opacity:0;transform:translateY(22px);transition:opacity 1s ease,transform 1.05s cubic-bezier(.16,1,.3,1)}
.reveal.in .up{opacity:1;transform:translateY(0)}
.reveal .up.d1{transition-delay:.1s}.reveal .up.d2{transition-delay:.2s}.reveal .up.d3{transition-delay:.3s}
.block{padding:88px 0;border-top:1px solid var(--smoke)}
.intro-h{text-align:center;max-width:760px;margin:0 auto 52px}
.label{font-size:12px;text-transform:uppercase;letter-spacing:var(--tracking-label);margin-bottom:20px;color:var(--neon-2);
  display:flex;align-items:center;justify-content:center;gap:12px}
.label::before,.label::after{content:"";width:26px;height:1px;background:var(--neon);box-shadow:0 0 8px var(--neon)}
.h2{font-weight:300;font-size:clamp(26px,3.6vw,48px);line-height:1.14;letter-spacing:var(--tracking-display)}
.h2 b{font-weight:600}
.prose{max-width:760px;margin:0 auto;font-weight:300}
.prose h2{font-weight:500;font-size:clamp(20px,2.4vw,28px);letter-spacing:-.01em;margin:40px 0 14px;color:#fff}
.prose h3{font-weight:500;font-size:18px;margin:28px 0 10px}
.prose p{opacity:.82;line-height:1.7;margin-bottom:14px}
.prose a{color:var(--neon-2);text-decoration:underline;text-underline-offset:3px}
.prose ul{margin:0 0 16px 20px;opacity:.82;line-height:1.7}
.aura{position:absolute;border-radius:50%;filter:blur(90px);opacity:.45;z-index:1;pointer-events:none}
.aura.a1{width:380px;height:380px;background:rgba(255,58,29,.2);top:-120px;left:50%;transform:translateX(-50%)}

/* stats / in één oogopslag */
.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.stat{background:#0a0608;border:1px solid var(--smoke);border-radius:12px;padding:28px 18px;text-align:center;transition:border-color .4s}
.stat:hover{border-color:rgba(255,120,70,.4)}
.stat .num{font-weight:300;font-size:clamp(34px,4vw,56px);letter-spacing:-.03em;line-height:1;
  color:var(--neon-2);text-shadow:0 0 22px rgba(255,90,40,.45);display:inline-block}
.stat .num.pop{animation:numPop .55s cubic-bezier(.16,1,.3,1)}
@keyframes numPop{0%{transform:scale(1);text-shadow:0 0 22px rgba(255,90,40,.45)}
  40%{transform:scale(1.18);text-shadow:0 0 30px rgba(255,90,40,.9),0 0 60px rgba(255,138,60,.6)}
  100%{transform:scale(1);text-shadow:0 0 22px rgba(255,90,40,.45)}}
.stat .lbl{margin-top:12px;font-size:11px;text-transform:uppercase;letter-spacing:var(--tracking-label);opacity:.7}
@media(max-width:860px){.stats{grid-template-columns:repeat(2,1fr)}}

/* video showcase */
.video-wrap{display:flex;justify-content:center}
.video-frame{position:relative;width:min(86vw,340px);aspect-ratio:9/16;border-radius:14px;overflow:hidden;
  border:1px solid rgba(255,120,70,.45);box-shadow:0 0 40px rgba(255,80,40,.25),inset 0 0 30px rgba(0,0,0,.5)}
.video-frame video{width:100%;height:100%;object-fit:cover}
.video-frame::after{content:"";position:absolute;inset:0;pointer-events:none;border-radius:14px;box-shadow:inset 0 0 60px rgba(255,80,40,.18)}
.video-side{max-width:380px}
@media(min-width:861px){.video-wrap{gap:50px;align-items:center}.video-side{text-align:left}}

/* coaches */
.coaches{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.coach{background:#0a0608;border:1px solid var(--smoke);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:border-color .4s}
.coach:hover{border-color:rgba(255,120,70,.45)}
.coach .ph{position:relative;width:100%;aspect-ratio:1/1;overflow:hidden;background:#000}
.coach .ph img{width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.04);transition:transform 1.2s ease}
.coach:hover .ph img{transform:scale(1)}
.coach .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 70%,rgba(10,6,8,.9));pointer-events:none}
.coach .info{padding:30px 32px 36px}
.coach .role{font-size:12px;text-transform:uppercase;letter-spacing:var(--tracking-label);color:var(--neon-2);margin-bottom:12px}
.coach h3{font-weight:300;font-size:clamp(26px,3vw,40px);letter-spacing:var(--tracking-display);margin-bottom:16px}
.coach .tags{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:18px}
.coach .tags span{font-size:11px;text-transform:uppercase;letter-spacing:var(--tracking-label);
  border:1px solid rgba(255,120,70,.5);border-radius:70px;padding:6px 13px;opacity:.9;color:#fff}
.coach p{font-size:14px;line-height:1.6;letter-spacing:.3px;opacity:.82;font-weight:300}

/* programmas */
.program{display:grid;grid-template-columns:.5fr 2fr .7fr;align-items:center;gap:24px;padding:28px 22px;
  border:1px solid var(--smoke);border-radius:12px;margin-bottom:12px;transition:background .4s,border-color .4s;position:relative;overflow:hidden}
.program::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--neon);
  box-shadow:0 0 14px var(--neon);transform:scaleY(0);transform-origin:top;transition:transform .4s}
.program:hover{background:linear-gradient(90deg,rgba(255,58,29,.06),transparent);border-color:rgba(255,120,70,.4)}
.program:hover::before{transform:scaleY(1)}
.program .pn{font-weight:300;font-size:clamp(30px,4vw,56px);letter-spacing:-.03em;line-height:.9;opacity:.28;transition:opacity .4s,color .4s,text-shadow .4s}
.program:hover .pn{opacity:1;color:var(--neon-2);text-shadow:0 0 26px rgba(255,90,40,.6)}
.program .pc .meta{font-size:12px;text-transform:uppercase;letter-spacing:var(--tracking-label);color:var(--neon-2);opacity:.85;margin-bottom:9px}
.program .pc p{font-size:14px;line-height:1.5;letter-spacing:.3px;opacity:.8;font-weight:300}
.program .pp{text-align:right;font-weight:300;font-size:clamp(22px,2.4vw,34px);letter-spacing:-.02em;white-space:nowrap}
.program .pp small{display:block;font-size:11px;letter-spacing:var(--tracking-label);opacity:.5;text-transform:uppercase;margin-top:6px}

/* fases */
.phases{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.phase{background:#0a0608;padding:30px 24px;min-height:34vh;display:flex;flex-direction:column;position:relative;overflow:hidden;
  border:1px solid var(--smoke);border-radius:12px}
.phase::after{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--neon);box-shadow:0 0 12px var(--neon);
  transform:scaleX(0);transform-origin:left;transition:transform .6s ease}
.phase:hover::after{transform:scaleX(1)}
.phase .pnum{font-size:13px;letter-spacing:var(--tracking-label);color:var(--neon-2);text-shadow:0 0 12px rgba(255,90,40,.7);margin-bottom:22px}
.phase h4{font-weight:500;font-size:18px;letter-spacing:-.01em;margin-bottom:12px;line-height:1.2}
.phase p{font-size:13.5px;line-height:1.5;letter-spacing:.3px;opacity:.72;font-weight:300;margin-top:auto}

/* portfolio grid */
.pf-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.pf-card{position:relative;aspect-ratio:3/4;overflow:hidden;border:1px solid var(--smoke);border-radius:12px}
.pf-card img{width:100%;height:100%;object-fit:cover;transition:transform 1s ease;filter:saturate(.92)}
.pf-card:hover img{transform:scale(1.07)}
.pf-card .cap{position:absolute;left:0;right:0;bottom:0;padding:14px;font-size:11px;text-transform:uppercase;letter-spacing:var(--tracking-label);
  background:linear-gradient(180deg,transparent,rgba(5,3,4,.92));z-index:2}
.pf-card .cap b{color:var(--neon-2);display:block;margin-bottom:3px;text-shadow:0 0 12px rgba(255,90,40,.5)}

/* reviews */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.review{background:#0a0608;padding:32px 28px;display:flex;flex-direction:column;border:1px solid var(--smoke);border-radius:12px}
.review .q{font-size:44px;line-height:1;color:var(--neon);opacity:.5;margin-bottom:12px;text-shadow:0 0 20px rgba(255,80,40,.5)}
.review p{font-size:15px;line-height:1.55;letter-spacing:.2px;font-weight:300;margin-bottom:24px}
.review .who{margin-top:auto;font-size:12px;text-transform:uppercase;letter-spacing:var(--tracking-label);opacity:.6}
.review .who b{display:block;font-weight:500;opacity:1;margin-bottom:4px;color:#fff}

/* prijzen */
.price-row{display:flex;justify-content:space-between;align-items:baseline;gap:30px;padding:24px 22px;
  border:1px solid var(--smoke);border-radius:12px;margin-bottom:10px;transition:background .4s,border-color .4s}
.price-row:hover{background:linear-gradient(90deg,rgba(255,58,29,.06),transparent);border-color:rgba(255,120,70,.4)}
.price-row .pl{font-weight:300;font-size:clamp(19px,2.2vw,27px);letter-spacing:-.02em}
.price-row .pl small{display:block;font-size:12px;text-transform:uppercase;letter-spacing:var(--tracking-label);opacity:.5;margin-top:7px;font-weight:400}
.price-row .pv{font-weight:300;font-size:clamp(19px,2.2vw,27px);white-space:nowrap;color:var(--neon-2);text-shadow:0 0 16px rgba(255,90,40,.3)}

/* faq */
.faq-item{border:1px solid var(--smoke);border-radius:12px;margin-bottom:10px;overflow:hidden;transition:border-color .3s}
.faq-item.open{border-color:rgba(255,120,70,.4)}
.faq-q{width:100%;background:none;border:none;color:#fff;font:inherit;text-align:left;padding:22px 24px;
  display:flex;justify-content:space-between;align-items:center;gap:20px;font-size:clamp(15px,1.7vw,19px);font-weight:300;letter-spacing:-.01em;transition:color .3s}
.faq-q:hover{color:var(--neon-2)}
.faq-q .plus{font-size:22px;transition:transform .4s;color:var(--neon);text-shadow:0 0 10px var(--neon)}
.faq-item.open .plus{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s ease}
.faq-a p{padding:0 24px 22px;font-size:14.5px;line-height:1.6;opacity:.75;font-weight:300}

/* forms (aanmelden) */
.form-card{max-width:640px;margin:0 auto;background:#0a0608;border:1px solid var(--smoke);border-radius:16px;padding:40px}
.field{margin-bottom:20px}
.field label{display:block;font-size:12px;text-transform:uppercase;letter-spacing:var(--tracking-label);color:var(--neon-2);margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;background:#050304;border:1px solid var(--smoke);border-radius:10px;
  color:#fff;font:inherit;font-size:15px;padding:13px 15px;transition:border-color .3s,box-shadow .3s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--neon-2);box-shadow:0 0 0 3px rgba(255,90,40,.15)}
.field textarea{min-height:120px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.btn-neon{display:inline-flex;align-items:center;gap:10px;border:none;border-radius:70px;cursor:none;
  background:linear-gradient(90deg,var(--neon),var(--neon-2));color:#fff;font:inherit;font-size:13px;text-transform:uppercase;
  letter-spacing:var(--tracking-label);padding:16px 30px;box-shadow:0 0 26px rgba(255,80,40,.5);transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s}
.btn-neon:hover{box-shadow:0 0 40px rgba(255,80,40,.7)}
.fieldset{border:0;margin-bottom:22px}
.fieldset legend{font-size:12px;text-transform:uppercase;letter-spacing:var(--tracking-label);color:var(--neon-2);margin-bottom:12px;padding:0}
.choice-row{display:flex;flex-wrap:wrap;gap:10px}
.choice input{position:absolute;opacity:0;width:1px;height:1px}
.choice label{display:inline-block;border:1px solid var(--smoke);border-radius:70px;padding:9px 16px;font-size:13px;
  color:#fff;transition:border-color .3s,background .3s,box-shadow .3s,color .3s}
.choice input:checked + label{border-color:transparent;background:linear-gradient(90deg,var(--neon),var(--neon-2));box-shadow:0 0 18px rgba(255,80,40,.45)}
.choice input:focus-visible + label{box-shadow:0 0 0 3px rgba(255,90,40,.3)}
.check{display:flex;gap:12px;align-items:flex-start;font-size:13px;line-height:1.55;opacity:.85;margin-bottom:24px}
.check input{margin-top:3px;width:18px;height:18px;accent-color:var(--neon);flex:0 0 auto}
.check a{color:var(--neon-2);text-decoration:underline;text-underline-offset:3px}
.req{color:var(--neon-2)}

/* socials / link-in-bio */
.link-stack{max-width:460px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.link-btn{display:block;border:1px solid var(--smoke);border-radius:14px;padding:18px 22px;text-decoration:none;color:#fff;
  background:#0a0608;transition:border-color .35s,box-shadow .35s,transform .35s,background .35s}
.link-btn:hover{border-color:transparent;background:linear-gradient(90deg,rgba(255,58,29,.16),rgba(255,138,60,.08));
  box-shadow:0 0 26px rgba(255,80,40,.35);transform:translateY(-2px)}
.link-btn.primary{background:linear-gradient(90deg,var(--neon),var(--neon-2));border-color:transparent;box-shadow:0 0 26px rgba(255,80,40,.5)}
.link-btn .t{font-weight:500;font-size:15px;display:block}
.link-btn .s{font-size:12px;opacity:.7;margin-top:4px;display:block}

/* cta */
.cta{padding:120px 0;text-align:center;border-top:1px solid var(--smoke);position:relative;overflow:hidden}
.cta h2{font-weight:300;font-size:clamp(32px,5vw,64px);line-height:1.08;letter-spacing:var(--tracking-display);margin-bottom:24px;position:relative;z-index:2}
.cta p{max-width:54ch;margin:0 auto 36px;opacity:.78;font-weight:300;line-height:1.55;position:relative;z-index:2}
.cta .pill,.cta .btn-neon{position:relative;z-index:2}

/* footer */
footer{padding:48px 0;border-top:1px solid var(--smoke)}
footer .fcols{display:flex;justify-content:space-between;flex-wrap:wrap;gap:28px;
  font-size:12px;text-transform:uppercase;letter-spacing:var(--tracking-label);opacity:.72}
footer .col{display:flex;flex-direction:column;gap:7px}
footer a{text-decoration:none;transition:text-shadow .3s}
footer a:hover{text-shadow:0 0 12px var(--neon)}
footer .legal{margin-top:30px;padding-top:20px;border-top:1px solid var(--smoke);display:flex;gap:22px;flex-wrap:wrap;font-size:11px;opacity:.55}

@media(max-width:860px){
  .nav-links{display:none}
  .coaches,.reviews{grid-template-columns:1fr}
  .phases,.pf-grid{grid-template-columns:repeat(2,1fr)}
  .program{grid-template-columns:1fr;gap:10px}
  .program .pp{text-align:left}
  .wrap{padding:0 22px}
  .video-wrap{flex-direction:column;text-align:center}
  .video-side{text-align:center}
  .field-row{grid-template-columns:1fr}
  .form-card{padding:28px}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;animation-iteration-count:1!important}
  .reveal .up{opacity:1;transform:none}
}
