/* ============================================================
   NOVAGYM - design system
   Nova Black #09090A · Nova White #F9F9F9
   Nova Purple #B300FE (signal only, <5%) · Nova Indigo #1B00AF (CTA gradient only)
   Oswald (display/condensed) + Poppins (body)
   ============================================================ */
:root{
  --bg:#09090A;
  --bg-1:#0d0d0f;
  --bg-2:#141417;
  --bg-3:#1a1a1e;
  --white:#F9F9F9;
  --dim:#b7b7bd;
  --mut:#8e8e96;
  --line:rgba(249,249,249,.10);
  --line-2:rgba(249,249,249,.18);
  --purple:#B300FE;
  --indigo:#1B00AF;
  --grad:linear-gradient(118deg,#1B00AF 0%,#B300FE 100%);
  --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.18,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);color:var(--white);
  font-family:"Poppins",system-ui,sans-serif;font-weight:400;font-size:16.5px;line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
::selection{background:var(--purple);color:#fff}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.osw{font-family:"Oswald",sans-serif}

/* ---------- type ---------- */
h1,h2,h3,.display{font-family:"Oswald",sans-serif;font-weight:600;line-height:.98;letter-spacing:.005em;text-transform:uppercase}
.eyebrow{
  font-family:"Oswald",sans-serif;font-weight:500;font-size:13px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--dim);display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--purple);display:inline-block}
.lead{color:var(--dim);font-size:clamp(16px,2vw,19px);max-width:54ch}
.muted{color:var(--mut)}
.en{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.04em}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:"Oswald",sans-serif;font-weight:600;
  font-size:14px;letter-spacing:.12em;text-transform:uppercase;padding:16px 30px;cursor:pointer;
  border:2px solid transparent;border-radius:0;transition:transform .25s var(--ease),background .25s,color .25s,border-color .25s,box-shadow .25s}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 0 0 0 rgba(179,0,254,.5)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 40px -12px rgba(179,0,254,.7)}
.btn-ghost{border-color:var(--line-2);color:var(--white);background:transparent}
.btn-ghost:hover{border-color:var(--white);transform:translateY(-2px)}
.btn-sm{padding:12px 22px;font-size:12.5px}

/* ---------- nav ---------- */
header.nav{position:fixed;top:0;left:0;right:0;z-index:200;border-bottom:1px solid transparent;
  transition:background .3s var(--ease),border-color .3s,backdrop-filter .3s}
header.nav.scrolled{background:rgba(9,9,10,.82);backdrop-filter:blur(16px);border-bottom-color:var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:78px;gap:24px}
.logo{display:flex;align-items:center;gap:11px}
.logo svg{width:30px;height:30px;color:var(--white);transition:color .3s}
.logo:hover svg{color:var(--purple)}
.logo .wm{font-family:"Oswald",sans-serif;font-weight:700;font-size:23px;letter-spacing:.06em;text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a.link{font-family:"Oswald",sans-serif;font-weight:500;font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);position:relative;padding:6px 0}
.nav-links a.link::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--purple);transition:width .25s var(--ease)}
.nav-links a.link:hover{color:var(--white)}
.nav-links a.link:hover::after,.nav-links a.link.active::after{width:100%}
.nav-links a.link.active{color:var(--white)}
.nav-actions{display:flex;align-items:center;gap:12px;margin-left:6px}
.burger{display:none;flex-direction:column;gap:6px;background:none;border:0;cursor:pointer;padding:8px;z-index:210}
.burger span{width:28px;height:2px;background:var(--white);transition:.3s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;padding:120px 0 70px;overflow:hidden}
.hero.short{min-height:74svh}
.hero-glow{position:absolute;z-index:0;width:90vmax;height:90vmax;left:64%;top:38%;transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(179,0,254,.16) 0%,rgba(27,0,175,.10) 30%,transparent 60%);
  filter:blur(8px);pointer-events:none;animation:breathe 9s ease-in-out infinite}
@keyframes breathe{0%,100%{opacity:.75;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.07)}}
.hero-rule{position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:calc(100%/12) 100%;opacity:.5;
  mask-image:radial-gradient(circle at 60% 40%,#000,transparent 75%)}
.hero-inner{position:relative;z-index:2;width:100%}
.hero h1{font-size:clamp(46px,8.4vw,118px);font-weight:700;margin:24px 0 0}
.hero h1 .pl{display:block}
.hero h1 .accent{position:relative;display:inline-block}
.hero h1 .accent::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:5px;background:var(--grad);
  transform:scaleX(0);transform-origin:left;animation:draw 1s var(--ease) .5s forwards}
@keyframes draw{to{transform:scaleX(1)}}
.hero .lead{margin:30px 0 36px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* punch marquee */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-1);overflow:hidden;white-space:nowrap}
.marquee .track{display:inline-flex;gap:0;will-change:transform;animation:slide 26s linear infinite}
.marquee:hover .track{animation-play-state:paused}
.marquee span{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  font-size:clamp(18px,2.4vw,30px);color:var(--white);padding:20px 34px;display:inline-flex;align-items:center;gap:34px}
.marquee span::after{content:"";width:9px;height:9px;background:var(--purple);transform:rotate(45deg);display:inline-block}
.marquee .dim{color:var(--mut)}
@keyframes slide{to{transform:translateX(-50%)}}

/* ---------- generic section ---------- */
section.block{padding:clamp(74px,11vw,138px) 0;position:relative}
.block.alt{background:var(--bg-1)}
.sec-head{margin-bottom:56px;max-width:62ch}
.sec-head .eyebrow{margin-bottom:22px}
.sec-head h2{font-size:clamp(30px,5.2vw,62px);font-weight:700}
.sec-head h2 .p{color:var(--purple)}
.sec-head p{color:var(--dim);margin-top:18px;max-width:56ch}

/* statement */
.statement{font-size:clamp(28px,5.2vw,64px);font-weight:600;line-height:1.02;max-width:18ch}
.statement em{font-style:normal;color:var(--purple)}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* ---------- differentiators ---------- */
.diff{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.diff .cell{background:var(--bg);padding:42px 38px;transition:background .3s}
.diff .cell:hover{background:var(--bg-2)}
.diff .n{font-family:"Oswald",sans-serif;font-weight:600;color:var(--purple);font-size:15px;letter-spacing:.1em}
.diff h3{font-size:clamp(22px,3vw,30px);font-weight:600;margin:16px 0 10px}
.diff p{color:var(--dim);font-size:15.5px;max-width:46ch}

/* ---------- routes ---------- */
.routes{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.route{position:relative;background:var(--bg-1);border:1px solid var(--line);padding:44px 40px;display:flex;flex-direction:column;
  transition:transform .3s var(--ease),border-color .3s,background .3s;overflow:hidden}
.route::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--grad);transform:scaleY(0);transform-origin:top;transition:transform .35s var(--ease)}
.route:hover{transform:translateY(-6px);border-color:var(--line-2);background:var(--bg-2)}
.route:hover::before{transform:scaleY(1)}
.route .tag{font-family:"Oswald",sans-serif;font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-size:12px;color:var(--mut)}
.route h3{font-size:clamp(30px,4.6vw,46px);font-weight:700;margin:10px 0 6px}
.route .sub{color:var(--purple);font-family:"Oswald",sans-serif;font-weight:500;letter-spacing:.06em;text-transform:uppercase;font-size:15px;margin-bottom:20px}
.route p{color:var(--dim);font-size:15.5px;margin-bottom:24px}
.route ul{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:30px}
.route li{display:flex;gap:12px;font-size:15.5px;color:var(--white)}
.route li svg{flex:0 0 19px;margin-top:3px;color:var(--purple)}
.route .btn{margin-top:auto;align-self:flex-start}

/* ---------- for who / not ---------- */
.fortable{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.forcol{border:1px solid var(--line);padding:40px 38px;background:var(--bg-1)}
.forcol.no{background:var(--bg)}
.forcol .h{display:flex;align-items:center;gap:12px;margin-bottom:26px;font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:20px}
.forcol .badge{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border:2px solid var(--purple);color:var(--purple)}
.forcol.no .badge{border-color:var(--mut);color:var(--mut)}
.forcol ul{list-style:none;display:flex;flex-direction:column;gap:15px}
.forcol li{display:flex;gap:13px;color:var(--dim);font-size:15.5px}
.forcol li b{color:var(--white);font-weight:600}
.forcol li svg{flex:0 0 18px;margin-top:3px}
.forcol .y{color:var(--purple)}.forcol .x{color:var(--mut)}

/* ---------- placeholders (real photos go here) ---------- */
.ph{position:relative;border:1px solid var(--line);overflow:hidden;
  background:repeating-linear-gradient(45deg,rgba(249,249,249,.022) 0 14px,transparent 14px 28px),var(--bg-2);
  display:flex;align-items:center;justify-content:center;text-align:center;min-height:240px}
.ph .lab{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:12.5px;color:var(--mut);max-width:74%;line-height:1.5}
.ph .lab b{display:block;color:var(--dim);font-size:11px;letter-spacing:.22em;margin-bottom:8px}
.ph::after{content:"";position:absolute;top:14px;right:14px;width:10px;height:10px;background:var(--purple);transform:rotate(45deg)}
.ph.tall{min-height:520px}
.ph.wide{min-height:300px}

/* ---------- community band ---------- */
.band{position:relative;padding:clamp(80px,12vw,150px) 0;text-align:center;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.band .hero-glow{left:50%;top:50%;opacity:.6}
.band h2{font-size:clamp(40px,8vw,98px);font-weight:700;position:relative;z-index:2}
.band p{position:relative;z-index:2;color:var(--dim);max-width:48ch;margin:22px auto 0}

/* ---------- reviews ---------- */
.revs{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.rev{border:1px solid var(--line);background:var(--bg-1);padding:34px 32px;display:flex;flex-direction:column;gap:18px}
.rev .stars{color:var(--purple);letter-spacing:3px;font-size:15px}
.rev p{color:var(--white);font-size:16px;line-height:1.6}
.rev .who{margin-top:auto;font-family:"Oswald",sans-serif;letter-spacing:.06em;text-transform:uppercase;font-size:13px;color:var(--mut)}
.rev .who b{color:var(--white);font-weight:600}

/* ---------- facilities ---------- */
.facs{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.fac{background:var(--bg);padding:34px 30px;transition:background .3s}
.fac:hover{background:var(--bg-2)}
.fac .ic{color:var(--purple);margin-bottom:18px}
.fac h3{font-size:20px;font-weight:600;margin-bottom:8px}
.fac p{color:var(--mut);font-size:14.5px}

/* ---------- process steps (Performance) ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.step{background:var(--bg);padding:38px 30px}
.step .num{font-family:"Oswald",sans-serif;font-weight:700;font-size:54px;line-height:1;color:transparent;-webkit-text-stroke:1.5px var(--line-2)}
.step h3{font-size:20px;font-weight:600;margin:16px 0 10px}
.step p{color:var(--dim);font-size:14.5px}
.step .num b{color:var(--purple);-webkit-text-stroke:0}

/* ---------- pricing ---------- */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.plan{border:1px solid var(--line);background:var(--bg-1);padding:38px 34px;display:flex;flex-direction:column;position:relative;transition:transform .3s var(--ease),border-color .3s}
.plan:hover{transform:translateY(-6px);border-color:var(--line-2)}
.plan.feat{border-color:var(--purple)}
.plan .tag{position:absolute;top:0;right:28px;transform:translateY(-50%);background:var(--grad);color:#fff;font-family:"Oswald",sans-serif;font-weight:600;letter-spacing:.12em;text-transform:uppercase;font-size:11px;padding:6px 14px}
.plan .pn{font-family:"Oswald",sans-serif;font-weight:700;font-size:28px;text-transform:uppercase}
.plan .for{color:var(--mut);font-size:13.5px;margin-top:4px;min-height:40px}
.plan .price{display:flex;align-items:baseline;gap:7px;margin:22px 0 4px}
.plan .price .v{font-family:"Oswald",sans-serif;font-weight:700;font-size:54px;line-height:.9}
.plan .price .u{color:var(--mut);font-size:14px}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin:24px 0 28px}
.plan li{display:flex;gap:11px;color:var(--dim);font-size:14.5px}
.plan li svg{flex:0 0 17px;margin-top:3px;color:var(--purple)}
.plan .btn{margin-top:auto;justify-content:center}

/* ---------- intake form ---------- */
.intake{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
form.iform{border:1px solid var(--line);background:var(--bg-1);padding:38px}
form.iform .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:16px}
.field label{display:block;font-family:"Oswald",sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:.05em;font-size:12.5px;color:var(--dim);margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;background:var(--bg);border:1px solid var(--line);color:var(--white);
  padding:14px 15px;font-family:inherit;font-size:15px;transition:border-color .25s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--purple)}
.field textarea{resize:vertical;min-height:90px}
form.iform .btn{width:100%;justify-content:center;margin-top:6px}
form.iform .disc{font-size:12px;color:var(--mut);margin-top:14px;line-height:1.55}
form.iform .disc a{color:var(--dim);text-decoration:underline}
.contact-meta .blk{padding:24px 0;border-top:1px solid var(--line)}
.contact-meta .blk:first-child{border-top:0;padding-top:0}
.contact-meta h4{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:13px;color:var(--purple);margin-bottom:10px}
.contact-meta p,.contact-meta a{color:var(--dim);font-size:15px;display:block;margin-bottom:4px}
.contact-meta a:hover{color:var(--white)}

/* ---------- values ---------- */
.values{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.value{display:grid;grid-template-columns:90px 1fr;gap:24px;padding:34px 4px;border-bottom:1px solid var(--line);align-items:baseline}
.value .vn{font-family:"Oswald",sans-serif;font-weight:700;font-size:30px;color:transparent;-webkit-text-stroke:1.5px var(--line-2)}
.value h3{font-size:clamp(20px,2.6vw,28px);font-weight:600}
.value p{color:var(--dim);font-size:15.5px;margin-top:8px;max-width:60ch}

/* ---------- disclaimer ---------- */
.note{border:1px solid var(--line);border-left:3px solid var(--purple);background:var(--bg-1);padding:24px 28px;color:var(--dim);font-size:14.5px;max-width:70ch}
.note b{color:var(--white)}

/* ---------- CTA band ---------- */
.cta-final{position:relative;text-align:center;padding:clamp(80px,13vw,160px) 0;overflow:hidden}
.cta-final .hero-glow{left:50%;top:50%;opacity:.7}
.cta-final h2{position:relative;z-index:2;font-size:clamp(38px,7.6vw,92px);font-weight:700}
.cta-final p{position:relative;z-index:2;color:var(--dim);max-width:46ch;margin:20px auto 34px}
.cta-final .hero-cta{position:relative;z-index:2;justify-content:center}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);background:var(--bg-1);padding:74px 0 38px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:56px}
.foot-brand .logo{margin-bottom:18px}
.foot-brand p{color:var(--mut);font-size:14.5px;max-width:32ch}
.foot-brand .sig{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--dim);margin-top:16px;font-size:14px}
.fcol h4{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.14em;font-size:12px;color:var(--purple);margin-bottom:18px}
.fcol a,.fcol p{display:block;color:var(--dim);font-size:14.5px;margin-bottom:10px;transition:color .2s}
.fcol a:hover{color:var(--white)}
.fcol .hrs{color:var(--mut);font-size:13.5px;line-height:1.7}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;border-top:1px solid var(--line);padding-top:26px;flex-wrap:wrap}
.foot-bottom .cp{font-family:"Oswald",sans-serif;letter-spacing:.06em;text-transform:uppercase;font-size:12px;color:var(--mut)}
.socials{display:flex;gap:12px}
.socials a{width:42px;height:42px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--dim);transition:.25s var(--ease)}
.socials a:hover{border-color:var(--purple);color:var(--purple);transform:translateY(-2px)}

/* ---------- page intro (sub pages) ---------- */
.pintro{padding:150px 0 0}
.pintro h1{font-size:clamp(44px,8vw,104px);font-weight:700;margin:22px 0 0}
.pintro .lead{margin-top:26px}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .diff,.routes,.fortable,.revs,.facs,.intake{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .plans{grid-template-columns:1fr;max-width:480px;margin:0 auto}
  .foot-grid{grid-template-columns:1fr 1fr}
  form.iform .row{grid-template-columns:1fr}
}
@media(max-width:740px){
  .nav-links{position:fixed;inset:78px 0 auto 0;flex-direction:column;align-items:flex-start;gap:20px;
    background:rgba(9,9,10,.97);backdrop-filter:blur(16px);padding:26px 28px 32px;border-bottom:1px solid var(--line);
    transform:translateY(-130%);transition:transform .4s var(--ease)}
  .nav-links.open{transform:translateY(0)}
  .nav-links a.link{font-size:19px}
  .nav-actions{flex-direction:column;align-items:stretch;width:100%;margin-left:0}
  .nav-actions .btn{justify-content:center}
  .burger{display:flex}
  .steps{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .value{grid-template-columns:1fr;gap:8px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
  .hero h1 .accent::after{transform:scaleX(1)}
}

/* ============================================================
   IMAGERY - real photos + logo
   ============================================================ */
.logo .mark{height:30px;width:auto;display:block;transition:filter .3s}
.logo .word{height:14px;width:auto;display:block;margin-top:2px}
.logo:hover .mark{filter:drop-shadow(0 0 10px rgba(179,0,254,.6))}
.foot-brand .logo{flex-direction:column;align-items:flex-start;gap:10px}
.foot-brand .mark{height:40px}
.foot-brand .word{height:18px}

/* hero with background photo */
.hero-media{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:center;
  animation:heroZoom 18s ease-out forwards}
@keyframes heroZoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero-media::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg,rgba(9,9,10,.94) 0%,rgba(9,9,10,.78) 40%,rgba(9,9,10,.45) 75%,rgba(9,9,10,.55) 100%),
  linear-gradient(180deg,rgba(9,9,10,.30) 0%,rgba(9,9,10,.40) 60%,rgba(9,9,10,.98) 100%)}
.hero.bg .hero-glow{opacity:.4;mix-blend-mode:screen}

/* image building blocks */
.imgwrap{position:relative;overflow:hidden;border:1px solid var(--line);background:var(--bg-2)}
.imgwrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .9s var(--ease)}
.imgwrap:hover img{transform:scale(1.045)}
.imgwrap .grad{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,transparent 45%,rgba(9,9,10,.82) 100%)}
.imgwrap .cap{position:absolute;left:0;bottom:0;z-index:2;padding:18px 22px;
  font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:13px;color:var(--white)}
.imgwrap .cap span{display:block;font-family:"Space Mono",monospace;font-weight:400;font-size:10px;letter-spacing:.2em;color:var(--purple);margin-bottom:5px}
.r1{aspect-ratio:16/10}.r2{aspect-ratio:4/5}.r3{aspect-ratio:21/9}.r43{aspect-ratio:4/3}

/* photo mosaic */
.mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.mosaic .imgwrap{height:100%}
.m-tall{grid-row:span 2}.m-wide{grid-column:span 2}

/* route card image header */
.route .rimg{margin:-44px -40px 26px;border:0;border-bottom:1px solid var(--line);aspect-ratio:16/9}
.route .rimg img{filter:saturate(1.02)}

/* full-bleed band with photo */
.band.bg{padding:0;border:0}
.band-media{position:relative;min-height:62vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.band-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.band-media::after{content:"";position:absolute;inset:0;z-index:1;background:
  radial-gradient(circle at center,rgba(9,9,10,.55),rgba(9,9,10,.86))}
.band-media .inner{position:relative;z-index:2;padding:60px 28px}
.band-media h2{font-size:clamp(40px,8vw,98px);font-weight:700}
.band-media p{color:var(--bone-dim,#cfc7b8);max-width:48ch;margin:20px auto 0;color:#e6e2da}

/* split feature: text + image */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split.rev .col-text{order:2}

@media(max-width:980px){
  .mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}
  .split{grid-template-columns:1fr;gap:34px}
  .split.rev .col-text{order:0}
}
@media(max-width:740px){
  .mosaic{grid-template-columns:1fr;grid-auto-rows:220px}
  .m-wide{grid-column:span 1}.m-tall{grid-row:span 1}
}

/* stacked logo lockup in nav */
header.nav .logo{flex-direction:column;align-items:flex-start;gap:3px}
@media(max-width:740px){ header.nav .logo .word{height:12px} header.nav .logo .mark{height:26px} }

/* four-tier pricing ladder */
.plans.four{grid-template-columns:repeat(4,1fr);gap:14px}
.plans.four .plan{padding:32px 26px}
.plans.four .plan .pn{font-size:25px}
.plans.four .plan .price .v{font-size:46px}
.plan.elite{border-color:var(--line-2);background:linear-gradient(180deg,rgba(179,0,254,.06),var(--bg-1) 42%)}
.plan.elite .pn{color:var(--white)}
.plan .price .v.sm{font-size:38px}
.addon{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;
  border:1px solid var(--line);background:var(--bg-1);padding:20px 26px;margin-top:14px}
.addon .t{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:16px}
.addon .d{color:var(--mut);font-size:14px}
@media(max-width:1080px){.plans.four{grid-template-columns:repeat(2,1fr);max-width:620px;margin:0 auto}}
@media(max-width:560px){.plans.four{grid-template-columns:1fr}}

/* ============================================================
   ENHANCEMENTS - added by build pass
   hero video · stat counters · video lightbox · weekrooster ·
   kaart · scroll progress · magnetic CTA · media cohesion
   ============================================================ */

/* nav links stay on one line */
.nav-links a.link{white-space:nowrap}

/* scroll progress bar */
#progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:300;background:var(--grad);
  box-shadow:0 0 12px rgba(179,0,254,.6);transition:width .08s linear}

/* ---- media cohesion: gentle, brand-leaning unification ---- */
.imgwrap img,.band-media img,.hero-media .hero-poster{filter:saturate(1.06) contrast(1.02)}
/* fine cinematic grain over the big media moments */
.hero-media::before,.band-media::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='140' height='140'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/></svg>");
  mix-blend-mode:overlay}

/* ---- hero video ---- */
.hero-media .hero-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.hero-media video.hero-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 38%;
  z-index:1;opacity:0;transition:opacity 1.1s var(--ease)}
.hero-media video.hero-vid.playing{opacity:1}
.hero-media::after{z-index:2}            /* keep dark overlay above the video */

/* ---- magnetic CTA (transform applied by JS) ---- */
.btn{will-change:transform}

/* ---- video testimonials ---- */
.vfeature{position:relative;border:1px solid var(--line);overflow:hidden;aspect-ratio:16/9;cursor:pointer;background:var(--bg-2);margin-bottom:16px}
.vgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.vcard{position:relative;border:1px solid var(--line);overflow:hidden;aspect-ratio:4/3;cursor:pointer;background:var(--bg-2)}
.vfeature img,.vcard img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease),filter .4s}
.vfeature:hover img,.vcard:hover img{transform:scale(1.05);filter:brightness(.9)}
.vfeature::after,.vcard::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,transparent 40%,rgba(9,9,10,.85))}
.vplay{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;pointer-events:none}
.vplay i{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(9,9,10,.45);backdrop-filter:blur(6px);border:1.5px solid rgba(249,249,249,.55);transition:.3s var(--ease)}
.vplay i svg{width:22px;height:22px;margin-left:3px;color:#fff}
.vfeature:hover .vplay i,.vcard:hover .vplay i{background:var(--grad);border-color:transparent;transform:scale(1.1)}
.vcap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:16px 18px;pointer-events:none}
.vcap b{display:block;font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:15px;color:#fff}
.vcap span{font-family:"Space Mono",monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--purple)}
.vfeature .vcap b{font-size:20px}

/* lightbox modal */
.vmodal{position:fixed;inset:0;z-index:1000;background:rgba(9,9,10,.93);backdrop-filter:blur(12px);
  display:none;align-items:center;justify-content:center;padding:24px}
.vmodal.open{display:flex}
.vmodal .vinner{position:relative;width:min(1040px,94vw)}
.vmodal video{width:100%;max-height:84vh;display:block;background:#000;border:1px solid var(--line-2)}
.vmodal .vclose{position:absolute;top:-46px;right:0;width:40px;height:40px;border:1px solid var(--line-2);
  background:transparent;color:var(--white);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.25s}
.vmodal .vclose:hover{border-color:var(--purple);color:var(--purple)}

/* ---- weekrooster ---- */
.week{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.day{background:var(--bg-1);padding:20px 14px;min-height:178px;transition:background .3s}
.day:hover{background:var(--bg-2)}
.day .dh{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:13px;color:var(--white);padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid var(--line)}
.day .dh span{display:block;font-family:"Space Mono",monospace;font-size:10px;letter-spacing:.12em;color:var(--mut);margin-top:3px}
.slot{display:block;margin-bottom:9px;padding-left:11px;position:relative;font-size:13px;color:var(--dim);line-height:1.4}
.slot::before{content:"";position:absolute;left:0;top:7px;width:5px;height:5px;background:var(--purple);transform:rotate(45deg)}
.slot b{display:block;color:var(--white);font-weight:600;font-size:13px}
.slot.hy::before{background:#5a7bff}
.slot.rest{color:var(--mut)}.slot.rest::before{background:var(--mut)}
.rooster-note{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;margin-top:18px}
.rooster-note p{color:var(--mut);font-size:13.5px;max-width:62ch}

/* ---- kaart / map ---- */
.mapwrap{position:relative;border:1px solid var(--line);overflow:hidden;aspect-ratio:16/6;min-height:300px;background:var(--bg-2)}
.mapwrap iframe{width:100%;height:100%;border:0;filter:invert(.92) hue-rotate(178deg) saturate(.85) contrast(.92) brightness(.95)}
.mapwrap .pin{position:absolute;left:24px;bottom:24px;z-index:2;background:rgba(9,9,10,.82);backdrop-filter:blur(10px);
  border:1px solid var(--line-2);padding:16px 20px;max-width:300px}
.mapwrap .pin h4{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:15px;margin-bottom:6px}
.mapwrap .pin p{color:var(--dim);font-size:13.5px;line-height:1.5}
.mapwrap .pin a{color:var(--purple);font-size:13px;font-family:"Oswald",sans-serif;letter-spacing:.06em;text-transform:uppercase;display:inline-block;margin-top:8px}
@media(max-width:980px){.mapwrap{aspect-ratio:auto;height:360px}}

/* ---- responsive for enhancements ---- */
@media(max-width:980px){
  .vgrid{grid-template-columns:repeat(2,1fr)}
  .week{grid-template-columns:repeat(2,1fr)}
  .day{min-height:auto}
}
@media(max-width:560px){
  .vgrid{grid-template-columns:1fr}
  .week{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  .hero-media video.hero-vid{display:none!important}
  #progress{transition:none}
  .hero-media::before,.band-media::before{display:none}
}

/* ============================================================
   BUILD PASS - refinements (override layer)
   ============================================================ */
/* media cohesion also on sub-page hero <img> */
.hero-media img{filter:saturate(1.06) contrast(1.02)}
/* accent underline clears the letters (was striking through) */
.hero h1 .accent::after{bottom:-.05em;height:6px}
.pintro h1 .accent::after{bottom:-.05em}
/* switch to the mobile menu earlier so the nav never cramps */
@media(max-width:1080px){
  .nav-links{position:fixed;inset:78px 0 auto 0;flex-direction:column;align-items:flex-start;gap:20px;
    background:rgba(9,9,10,.97);backdrop-filter:blur(16px);padding:26px 28px 34px;border-bottom:1px solid var(--line);
    transform:translateY(-135%);transition:transform .4s var(--ease);max-height:calc(100svh - 78px);overflow:auto}
  .nav-links.open{transform:translateY(0)}
  .nav-links a.link{font-size:19px}
  .nav-links a.link::after{display:none}
  .nav-actions{flex-direction:column;align-items:stretch;width:100%;margin-left:0;gap:10px}
  .nav-actions .btn{justify-content:center}
  .burger{display:flex}
}

/* ---- coach portrait row (over page) ---- */
.coachrow{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;margin-top:26px}
.coachrow .imgwrap{aspect-ratio:4/5;flex:0 1 calc(33.333% - 11px)}
.coachrow .imgwrap img{object-position:center 22%}
@media(max-width:980px){.coachrow .imgwrap{flex-basis:calc(50% - 8px)}}
@media(max-width:560px){.coachrow .imgwrap{flex-basis:100%;max-width:420px}}

/* ---- facility cards: icon chip + correct icon sizing (fixes oversized glyphs) ---- */
.fac .ic{display:inline-flex;width:50px;height:50px;align-items:center;justify-content:center;
  border:1px solid var(--line-2);color:var(--purple);margin-bottom:20px;
  transition:border-color .3s var(--ease),background .3s,color .3s}
.fac:hover .ic{border-color:var(--purple);background:rgba(179,0,254,.10)}
.fac .ic svg{width:26px;height:26px;display:block}

/* ============================================================
   MOBILE POLISH — from mobile-readiness audit
   ============================================================ */
/* hero headline: never clip a long single word; scale down on small phones */
.hero h1,.pintro h1{overflow-wrap:break-word}
@media(max-width:430px){ .hero h1{font-size:clamp(38px,11vw,46px)} }
/* burger: guarantee a 44x44 tap target */
.burger{min-width:44px;min-height:44px;align-items:center;justify-content:center}
/* tap targets: contact-meta + footer action links >= ~44px tall */
.contact-meta a:not(.btn){padding:9px 0;margin-bottom:0}
.fcol a{padding:8px 0;margin-bottom:2px}
