/* =============================================================================
   COACH JJ BASKETBALL
   Visual language ported from the Varna "Bold Modern Manufacturer" system:
   radius 0, no shadows, ruled grid, depth from rules + layering.
   Type: Montserrat ExtraBold display (uppercase) + Roboto text.
   Signal colour: red, kept under ~5% of any viewport.
   ============================================================================= */

:root{
  --ink:#0c0d11;          /* deep near-black ground */
  --ink-2:#13151b;        /* raised dark surface */
  --paper:#f6f6f3;        /* crisp off-white page */
  --paper-2:#ffffff;
  --tint:#d9d9d4;

  --red:#e0121b;          /* signal */
  --red-deep:#a60d16;     /* accent text on light (AA) */
  --red-press:#c10f17;

  --rule-dark:rgba(255,255,255,.14);
  --rule-light:rgba(18,20,26,.16);

  --on-ink:#f3f4f7;
  --on-ink-soft:rgba(243,244,247,.66);
  --text:#13151b;
  --text-soft:#54565f;

  --display:"Montserrat","Helvetica Neue",Arial,sans-serif;
  --body:"Roboto",system-ui,-apple-system,sans-serif;

  --maxw:1320px;
  --gutter:clamp(20px,5vw,72px);
  --section:clamp(4rem,2.5rem + 7vw,9rem);

  --ease:cubic-bezier(.2,.7,.2,1);
  --dur:260ms;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--text);font-family:var(--body);font-weight:400;font-size:clamp(1rem,.96rem + .2vw,1.0625rem);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}

h1,h2,h3,h4{font-family:var(--display);font-weight:800;line-height:.93;letter-spacing:-.03em;text-transform:uppercase;margin:0;text-wrap:balance}
p{margin:0}
a{color:inherit;text-decoration:none}
ol{margin:0;padding:0;list-style:none}

.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}

.mono{font-family:var(--body);font-weight:500;font-size:12px;letter-spacing:.16em;text-transform:uppercase}

.kicker{font-family:var(--body);font-weight:500;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);display:inline-flex;align-items:center;gap:.8em}
.kicker::before{content:"";width:2.4em;height:1px;background:currentColor;display:inline-block}

.sig{color:var(--red)}

.skip{position:absolute;left:-999px;top:0;background:var(--red);color:#fff;padding:10px 16px;z-index:100}
.skip:focus{left:0}

:where(a,button):focus-visible{outline:2px solid var(--red);outline-offset:3px}

/* ---- Reveal motion ---- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .bball,.marquee__track,.arena-paths path,.arena-spot,.arena-beams span{animation:none !important}
}

/* ---- Brand logo ---- */
.brand__logo{width:38px;height:38px;border-radius:50%;object-fit:cover;display:block}

/* ---- Buttons (radius 0, 2px border) ---- */
.btn{display:inline-flex;align-items:center;gap:.65em;font-family:var(--body);font-weight:700;font-size:15px;letter-spacing:.02em;text-transform:uppercase;line-height:1;padding:1.05em 1.7em;background:var(--red);color:#fff;border:2px solid var(--red);cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease),transform var(--dur) var(--ease)}
.btn:hover{background:transparent;color:var(--red)}
.btn:active{transform:translateY(1px)}
.btn--lg{font-size:16px;padding:1.15em 2em}
.btn--ghost-ink{background:transparent;border-color:var(--rule-dark);color:#fff}
.btn--ghost-ink:hover{border-color:var(--red);color:#fff;background:transparent}
.btn--ghost{background:transparent;border-color:var(--rule-light);color:var(--text)}
.btn--ghost:hover{border-color:var(--red);color:var(--red-deep)}
.btn--sm{padding:.7em 1.2em;font-size:13px}

/* ---- Sticky header (appears after hero) ---- */
.site-header{position:fixed;inset:0 0 auto 0;z-index:60;background:rgba(12,13,17,.88);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--rule-dark);transform:translateY(-100%);transition:transform .42s var(--ease)}
.site-header.show{transform:none}
.site-header__in{display:flex;align-items:center;justify-content:space-between;gap:24px;height:64px}
.brand--sm{font-size:18px;color:#fff}
.brand--sm .brand__logo{width:32px;height:32px}
.site-header__nav{display:flex;gap:26px;color:var(--on-ink-soft)}
.site-header__nav a{transition:color var(--dur) var(--ease)}
.site-header__nav a:hover{color:#fff}

/* ---- Staggered reveal (rows, steps) ---- */
.reveal{transition-delay:calc(var(--i,0) * 60ms)}

/* ============================ HERO ============================ */
.hero{position:relative;background:var(--ink);color:#fff;min-height:94vh;display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,360px);grid-template-rows:auto 1fr auto;gap:0 48px;padding:28px var(--gutter) 0;overflow:hidden}
.hero__rules{position:absolute;inset:0;pointer-events:none;display:grid;grid-template-columns:repeat(4,1fr);z-index:1}
.hero__rules i{border-right:1px solid var(--rule-dark)}
.hero__rules i:first-child{border-left:1px solid var(--rule-dark)}
.hero__court{position:absolute;right:-8%;top:50%;transform:translateY(-44%);width:min(58vw,760px);color:#fff;opacity:.12;z-index:0;pointer-events:none}
.hero__ball{fill:var(--red)}

.hero__top{grid-column:1/-1;display:flex;justify-content:space-between;align-items:center;gap:24px;padding-bottom:clamp(28px,6vh,80px);position:relative;z-index:3}
.brand{font-family:var(--display);font-weight:800;font-size:22px;letter-spacing:-.01em;text-transform:uppercase;display:inline-flex;align-items:center;gap:10px}
.brand__sq{width:13px;height:13px;background:var(--red)}
.hero__nav{display:flex;gap:30px;color:var(--on-ink-soft)}
.hero__nav a{transition:color var(--dur) var(--ease)}
.hero__nav a:hover{color:#fff}
.nav-toggle{display:none;background:none;border:0;flex-direction:column;gap:6px;cursor:pointer;padding:8px}
.nav-toggle span{width:26px;height:2px;background:#fff;display:block;transition:transform var(--dur) var(--ease),opacity var(--dur) var(--ease)}

.hero__display{grid-column:1/-1;position:relative;z-index:2;align-self:center;color:#fff;font-size:clamp(54px,9.2vw,162px);line-height:.92}
.hero__display .ln{display:block}
.hero__display .ln + .ln{margin-left:clamp(24px,7vw,150px)}

.hero__deck{grid-column:1/2;position:relative;z-index:2;align-self:end;max-width:50ch;padding:30px 0 46px}
.hero__deck p{font-size:17px;line-height:1.7;color:var(--on-ink-soft);margin-bottom:26px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap}

.hero__spec{grid-column:2/3;grid-row:2/4;position:relative;z-index:2;align-self:end;border:1px solid var(--rule-dark);border-bottom:none;background:rgba(12,13,17,.5);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
.spec__row{display:flex;flex-direction:column;gap:7px;padding:18px 22px;border-bottom:1px solid var(--rule-dark)}
.spec__row .mono{color:var(--on-ink-soft)}
.spec__txt{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:-.01em;text-transform:none}
.spec__num{font-family:var(--display);font-weight:800;font-size:clamp(30px,2.6vw,42px);line-height:1;letter-spacing:-.02em}
.spec__num em{font-style:normal;color:var(--red)}
.spec__num small{font-size:15px;font-weight:600}

/* ---- Hero photo layer ---- */
.hero__media{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:70% 32%;opacity:.42;filter:grayscale(.35) contrast(1.06);transform:scale(1.12);will-change:transform}
.hero__media::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg,var(--ink) 6%,rgba(12,13,17,.72) 46%,rgba(12,13,17,.5) 100%),
  linear-gradient(0deg,var(--ink) 3%,rgba(12,13,17,0) 52%)}

/* ---- Spinning basketball ---- */
.bball{position:absolute;z-index:3;bottom:-42px;right:-34px;width:clamp(104px,9vw,150px);height:auto;aspect-ratio:1;animation:spin 16s linear infinite;will-change:transform;filter:drop-shadow(0 16px 34px rgba(0,0,0,.55))}
.bball circle.body{fill:url(#bballGrad)}
.bball .seam{fill:none;stroke:#14110c;stroke-width:5;stroke-linecap:round;opacity:.85}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---- Moving marquee strip ---- */
.marquee{background:var(--red);color:#fff;overflow:hidden;padding:15px 0;display:flex}
.marquee__track{display:flex;flex:0 0 auto;align-items:center;white-space:nowrap;animation:marq 30s linear infinite;will-change:transform}
.marquee__track span{font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:clamp(17px,2.2vw,28px);letter-spacing:.02em;line-height:1}
.marquee__track .dot{margin:0 26px;color:rgba(255,255,255,.55);font-weight:700}
@keyframes marq{to{transform:translateX(-50%)}}
.marquee:hover .marquee__track{animation-play-state:paused}

/* ---- On the court (full-bleed action band) ---- */
.oncourt{position:relative;min-height:clamp(360px,52vw,600px);display:flex;align-items:flex-end;overflow:hidden;background:var(--ink)}
.oncourt img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%;opacity:.62;filter:grayscale(.25) contrast(1.08)}
.oncourt::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,var(--ink) 5%,rgba(12,13,17,.28) 55%,rgba(12,13,17,.5) 100%)}
.oncourt__in{position:relative;z-index:2;padding-block:clamp(2.5rem,5vw,5rem);width:100%}
.oncourt h2{color:#fff;font-size:clamp(36px,6.5vw,92px);max-width:16ch}
.oncourt p{color:var(--on-ink-soft);max-width:42ch;margin-top:18px;font-size:16px}

/* ============================ STATEMENT ============================ */
.statement{padding-block:var(--section);border-bottom:1px solid var(--rule-light)}
.statement__grid{display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(28px,5vw,72px);align-items:start}
.statement h2{font-size:clamp(30px,4.4vw,62px);max-width:18ch}
.statement__body{color:var(--text-soft);font-size:17px;line-height:1.75}
.statement__body p + p{margin-top:18px}
.statement__sig{margin-top:28px;color:var(--red-deep);letter-spacing:.1em}

/* ============================ PROGRAMS (ink) ============================ */
.progs{background:var(--ink);color:#fff;padding-block:var(--section)}
.progs__head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:46px}
.progs__head h2{font-size:clamp(32px,5vw,80px);margin-top:18px}
.progs__head p{color:var(--on-ink-soft);max-width:36ch;font-size:15px;line-height:1.7}
.index{border-top:1px solid var(--rule-dark)}
.row{display:grid;grid-template-columns:80px 1fr 1.5fr auto;gap:24px;align-items:center;padding:28px 4px;border-bottom:1px solid var(--rule-dark);color:#fff;transition:padding-left var(--dur) var(--ease),background var(--dur) var(--ease)}
.row:hover,.row:focus-visible{padding-left:18px;background:rgba(224,18,27,.07);outline:none}
.row__no{font-family:var(--body);color:var(--on-ink-soft);font-size:13px;letter-spacing:.1em}
.row h3{font-size:clamp(22px,2.4vw,34px)}
.row__desc{color:var(--on-ink-soft);font-size:14px;line-height:1.6}
.row__go{color:var(--red);font-size:24px;opacity:0;transform:translateX(-8px);transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease)}
.row:hover .row__go,.row:focus-visible .row__go{opacity:1;transform:none}

/* ============================ METHOD (paper, ruled 4) ============================ */
.method{padding-block:var(--section)}
.method__head{margin-bottom:42px;max-width:60ch}
.method__head h2{font-size:clamp(30px,4.6vw,64px);margin-top:16px}
.steps{display:grid;grid-template-columns:repeat(4,1fr);border-left:1px solid var(--rule-light);border-top:1px solid var(--rule-light)}
.step{padding:30px 26px;border-right:1px solid var(--rule-light);border-bottom:1px solid var(--rule-light)}
.step__ph{color:var(--red-deep)}
.step h3{font-size:clamp(24px,2.4vw,32px);margin:18px 0 10px}
.step p{color:var(--text-soft);font-size:14px;line-height:1.62}

/* ============================ RESULTS (ink) ============================ */
.results{background:var(--ink-2);color:#fff;padding-block:var(--section)}
.results__head{margin-bottom:44px}
.results__head h2{font-size:clamp(28px,4vw,56px);margin-top:16px}
.quotes{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--rule-dark);border:1px solid var(--rule-dark)}
.quote{background:var(--ink-2);margin:0;padding:clamp(28px,3vw,44px)}
.quote p{font-family:var(--display);font-weight:700;text-transform:none;letter-spacing:-.01em;font-size:clamp(19px,1.8vw,26px);line-height:1.32}
.quote cite{display:block;margin-top:22px;font-style:normal;color:var(--on-ink-soft)}

/* ============================ CTA (red band) ============================ */
.cta{background:var(--red);color:#fff;padding-block:clamp(4rem,7vw,7.5rem)}
.cta__grid{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(28px,5vw,64px);align-items:center}
.cta h2{font-size:clamp(40px,6.5vw,110px);line-height:.9}
.cta__grid > div:first-child p{margin-top:20px;font-size:18px;max-width:40ch;color:rgba(255,255,255,.9)}
.cta__actions{display:flex;flex-direction:column;gap:14px;align-items:flex-start}
.cta .btn{background:#fff;border-color:#fff;color:var(--red)}
.cta .btn:hover{background:transparent;color:#fff}
.cta .btn--ghost{background:transparent;border-color:rgba(255,255,255,.5);color:#fff}
.cta .btn--ghost:hover{border-color:#fff;background:#fff;color:var(--red)}
.cta__note{margin-top:6px;color:rgba(255,255,255,.8);letter-spacing:.08em}

/* ============================ FOOTER ============================ */
.site-footer{background:var(--ink);color:var(--on-ink-soft);padding-block:40px}
.site-footer__grid{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;align-items:center;font-size:13px}
.site-footer__soc{display:flex;gap:20px}
.site-footer__soc a{letter-spacing:.1em;transition:color var(--dur) var(--ease)}
.site-footer__soc a:hover{color:#fff}

/* ============================ RESPONSIVE ============================ */
@media (max-width:880px){
  .hero{grid-template-columns:1fr;min-height:auto;padding-bottom:8px}
  .nav-toggle{display:flex}
  .hero__nav{position:absolute;top:72px;right:var(--gutter);left:var(--gutter);flex-direction:column;gap:0;background:var(--ink-2);border:1px solid var(--rule-dark);padding:8px 0;z-index:4;display:none}
  .hero__nav.open{display:flex}
  .hero__nav a{padding:14px 22px;border-bottom:1px solid var(--rule-dark)}
  .hero__nav a:last-child{border-bottom:none}
  .hero__display{padding-top:clamp(48px,16vh,120px)}
  .hero__display .ln + .ln{margin-left:0}
  .bball{display:none}
  .site-header__nav{display:none}
  .site-header__in{height:58px}
  .hero__media img{object-position:65% 30%;opacity:.3}
  .hero__deck,.hero__spec{grid-column:1/-1}
  .hero__spec{grid-row:auto;margin:8px 0 32px;border-bottom:1px solid var(--rule-dark)}
  .statement__grid{grid-template-columns:1fr}
  .progs__head{align-items:flex-start}
  .row{grid-template-columns:46px 1fr;gap:8px 16px;padding-block:22px}
  .row__desc,.row__go{display:none}
  .steps{grid-template-columns:1fr 1fr}
  .quotes{grid-template-columns:1fr}
  .cta__grid{grid-template-columns:1fr}
}
@media (max-width:520px){
  .steps{grid-template-columns:1fr}
}

/* ============================ ARENA HERO (revamp) ============================ */
.hero--arena{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:100svh;padding:100px var(--gutter) 70px;background:#08090d;position:relative;overflow:hidden}
.hero--arena .hero__top{position:absolute;top:0;left:0;right:0;width:auto;padding:22px var(--gutter);z-index:4}

.arena-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.arena-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 32%;opacity:.20;filter:grayscale(.45) contrast(1.12)}
.arena-bg::after{content:"";position:absolute;inset:0;background:
  radial-gradient(62% 56% at 50% 40%, rgba(224,18,27,.13), transparent 68%),
  linear-gradient(180deg, rgba(8,9,13,.55) 0%, rgba(8,9,13,.82) 60%, #08090d 100%)}
.arena-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:62px 62px;-webkit-mask-image:radial-gradient(circle at 50% 38%, #000 26%, transparent 72%);mask-image:radial-gradient(circle at 50% 38%, #000 26%, transparent 72%)}
.arena-paths{position:absolute;inset:0;width:100%;height:100%;opacity:.55}
.arena-paths path{fill:none;stroke:rgba(255,255,255,.16);stroke-width:1.2;stroke-dasharray:5 12;animation:dash 16s linear infinite}
.arena-paths path:nth-child(2){stroke:rgba(224,18,27,.42);animation-duration:22s}
.arena-paths path:nth-child(3){animation-duration:19s;animation-direction:reverse}
@keyframes dash{to{stroke-dashoffset:-340}}
.arena-spot{position:absolute;left:50%;top:36%;width:120vmax;height:120vmax;transform:translate(-50%,-50%);background:radial-gradient(circle, rgba(255,255,255,.10), rgba(255,255,255,.03) 28%, transparent 58%);animation:spotPulse 7.5s ease-in-out infinite;pointer-events:none}
@keyframes spotPulse{0%,100%{opacity:.62;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.05)}}
.arena-beams{position:absolute;inset:-25% 0 0;pointer-events:none}
.arena-beams span{position:absolute;top:-8%;width:12vmax;height:150%;filter:blur(26px);transform-origin:top center;opacity:.7;background:linear-gradient(180deg,rgba(224,18,27,0),rgba(224,18,27,.16) 45%,rgba(224,18,27,0))}
.arena-beams span:nth-child(1){left:26%;transform:rotate(15deg);animation:beam 9s ease-in-out infinite}
.arena-beams span:nth-child(2){left:50%;transform:translateX(-50%);background:linear-gradient(180deg,rgba(255,255,255,0),rgba(255,255,255,.10) 45%,rgba(255,255,255,0));animation:beam 11s ease-in-out .6s infinite}
.arena-beams span:nth-child(3){right:26%;transform:rotate(-15deg);animation:beam 10s ease-in-out .3s infinite}
@keyframes beam{0%,100%{opacity:.32}50%{opacity:.85}}

.hero__content{position:relative;z-index:3;max-width:1080px;display:flex;flex-direction:column;align-items:center}
.bball--hero{position:static;bottom:auto;right:auto;display:block;width:clamp(82px,8.5vw,120px);height:auto;margin:0 auto 28px;filter:drop-shadow(0 0 34px rgba(224,18,27,.55))}
.kicker--center{justify-content:center}
.arena-title{font-family:var(--display);font-weight:800;text-transform:uppercase;letter-spacing:-.03em;line-height:.9;font-size:clamp(54px,10vw,166px);margin:22px 0 0;color:#fff;text-shadow:0 0 70px rgba(224,18,27,.28)}
.arena-sub{color:var(--on-ink-soft);font-size:clamp(16px,1.55vw,20px);max-width:56ch;margin:26px auto 0;line-height:1.6}
.hero__cta--center{justify-content:center;margin-top:34px}
.arena-creds{margin-top:36px;color:var(--on-ink-soft);letter-spacing:.14em;display:flex;gap:14px;align-items:center;flex-wrap:wrap;justify-content:center}
.arena-creds i{color:var(--red);font-style:normal}
@media (max-width:880px){
  .hero--arena{padding-top:86px}
  .arena-creds{font-size:11px;gap:9px}
}

/* ============================ CINEMATIC SECTIONS (full revamp) ============================ */
body{background:#0a0b0f;color:var(--on-ink)}

/* Statement / about -> dark with red glow */
.statement{background:#0a0b0f;border-top:1px solid var(--rule-dark);border-bottom:1px solid var(--rule-dark);position:relative;overflow:hidden}
.statement::before{content:"";position:absolute;left:-8%;top:-30%;width:52vmax;height:52vmax;background:radial-gradient(circle,rgba(224,18,27,.12),transparent 60%);pointer-events:none;z-index:0}
.statement .wrap{position:relative;z-index:1}
.statement h2{color:#fff}
.statement__body{color:var(--on-ink-soft)}
.statement__sig{color:var(--red)}

/* On the court band */
.oncourt{background:#0a0b0f;border-bottom:1px solid var(--rule-dark)}

/* Programs -> unified dark, centered glow, glow on hover */
.progs{background:#0a0b0f;position:relative;overflow:hidden}
.progs::before{content:"";position:absolute;left:50%;top:-12%;width:64vmax;height:42vmax;transform:translateX(-50%);background:radial-gradient(circle,rgba(224,18,27,.09),transparent 65%);pointer-events:none}
.progs .wrap{position:relative;z-index:1}
.row{position:relative}
.row:hover,.row:focus-visible{background:rgba(224,18,27,.08)}
.row:hover h3,.row:focus-visible h3{color:#fff}

/* Method -> dark ruled grid with hover glow */
.method{background:#0a0b0f;border-top:1px solid var(--rule-dark);position:relative;overflow:hidden}
.method::before{content:"";position:absolute;right:-10%;bottom:-30%;width:50vmax;height:50vmax;background:radial-gradient(circle,rgba(224,18,27,.09),transparent 60%);pointer-events:none}
.method .wrap{position:relative;z-index:1}
.method__head h2{color:#fff}
.steps{border-left:1px solid var(--rule-dark);border-top:1px solid var(--rule-dark)}
.step{border-right:1px solid var(--rule-dark);border-bottom:1px solid var(--rule-dark);background:rgba(255,255,255,.015);transition:background var(--dur) var(--ease)}
.step:hover{background:rgba(224,18,27,.07)}
.step h3{color:#fff}
.step p{color:var(--on-ink-soft)}
.step__ph{color:var(--red)}

/* Results -> unified dark */
.results{background:#0b0c11;border-top:1px solid var(--rule-dark)}
.quote{background:#0b0c11}

/* CTA red band -> add spotlight depth + glow */
.cta{position:relative;overflow:hidden;background:var(--red)}
.cta::before{content:"";position:absolute;left:50%;top:-40%;width:80vmax;height:80vmax;transform:translateX(-50%);background:radial-gradient(circle,rgba(255,255,255,.16),transparent 55%);pointer-events:none}
.cta .wrap{position:relative;z-index:1}

/* Footer */
.site-footer{background:#08090d;border-top:1px solid var(--rule-dark)}

/* ============================ GALLERY (real photos) ============================ */
.gallery{padding-block:var(--section);background:#0a0b0f;border-top:1px solid var(--rule-dark);position:relative;overflow:hidden}
.gallery::before{content:"";position:absolute;right:-10%;top:-20%;width:50vmax;height:50vmax;background:radial-gradient(circle,rgba(224,18,27,.08),transparent 60%);pointer-events:none}
.gallery .wrap{position:relative;z-index:1}
.gallery__head{margin-bottom:34px}
.gallery__head h2{font-size:clamp(32px,5vw,68px);color:#fff;margin-top:14px}
.gallery__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));grid-auto-rows:200px;gap:10px}
.gallery__grid figure{margin:0;overflow:hidden;position:relative}
.gallery__grid img{width:100%;height:100%;object-fit:cover;filter:grayscale(.35) contrast(1.06);transition:transform .6s var(--ease),filter .6s var(--ease);display:block}
.gallery__grid figure:hover img{transform:scale(1.06);filter:grayscale(0) contrast(1.05)}
.gallery__grid figure::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(10,11,15,.5));pointer-events:none}
.gallery__grid .span2{grid-column:span 2}
.gallery__grid .row2{grid-row:span 2}
@media(max-width:640px){.gallery__grid{grid-auto-rows:160px}.gallery__grid .span2{grid-column:span 1}.gallery__grid .row2{grid-row:span 1}}

/* ============================ KINETIC OVERDRIVE ============================ */
/* Hero Ken Burns drift */
@media (prefers-reduced-motion:no-preference){
  .arena-photo{animation:kenburns 28s ease-in-out infinite alternate}
}
@keyframes kenburns{from{transform:scale(1.06)}to{transform:scale(1.22) translate(-2.5%,-2%)}}

/* About: coach portrait beside the story */
.statement__grid{align-items:stretch}
.statement__media{position:relative;overflow:hidden;border:1px solid var(--rule-dark);min-height:340px}
.statement__media img{width:100%;height:100%;object-fit:cover;filter:grayscale(.3) contrast(1.06);transition:transform .7s var(--ease)}
.statement__media:hover img{transform:scale(1.05)}
.statement__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(10,11,15,.5))}
@media(max-width:880px){.statement__media{min-height:260px}}

/* Programs: horizontal photo carousel */
.progs__carousel{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;padding:4px 0 18px;scrollbar-width:thin;scrollbar-color:var(--rule-dark) transparent}
.progs__carousel::-webkit-scrollbar{height:6px}
.progs__carousel::-webkit-scrollbar-thumb{background:var(--rule-dark)}
.prog-card{position:relative;flex:0 0 min(80vw,350px);height:clamp(380px,46vw,470px);scroll-snap-align:start;overflow:hidden;border:1px solid var(--rule-dark);display:flex;flex-direction:column;justify-content:flex-end;padding:26px;color:#fff;text-decoration:none}
.prog-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(.4) contrast(1.06);transition:transform .7s var(--ease);z-index:0}
.prog-card:hover img,.prog-card:focus-visible img{transform:scale(1.07)}
.prog-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,11,15,.05) 30%,rgba(10,11,15,.9));z-index:1}
.prog-card > *{position:relative;z-index:2}
.prog-card .pc-no{font-family:var(--body);font-size:12px;letter-spacing:.16em;color:var(--red);margin-bottom:auto}
.prog-card h3{font-size:clamp(22px,2.6vw,32px);color:#fff}
.prog-card p{color:rgba(255,255,255,.82);font-size:14px;line-height:1.55;margin-top:10px}
.progs__hint{margin-top:10px;color:var(--on-ink-soft);font-size:12px;letter-spacing:.14em;text-transform:uppercase}

/* Highlight reel (kinetic photo marquees) */
.reel{padding-block:clamp(3.5rem,6vw,6.5rem);background:#0a0b0f;border-top:1px solid var(--rule-dark);overflow:hidden;position:relative}
.reel .reel__head{margin-bottom:30px}
.reel__head h2{font-size:clamp(32px,5vw,66px);color:#fff;margin-top:14px}
.reel__track{display:flex;gap:14px;width:max-content}
.reel__track + .reel__track{margin-top:14px}
.reel__track img{height:clamp(170px,21vw,290px);width:auto;display:block;object-fit:cover;filter:grayscale(.45) contrast(1.05);cursor:zoom-in;transition:filter .5s var(--ease),transform .5s var(--ease)}
.reel__track img:hover{filter:grayscale(0) contrast(1.05);transform:scale(1.03)}
@media (prefers-reduced-motion:no-preference){
  .reel__track{animation:reelL 52s linear infinite}
  .reel__track--rev{animation:reelR 60s linear infinite}
}
@keyframes reelL{to{transform:translateX(-50%)}}
@keyframes reelR{from{transform:translateX(-50%)}to{transform:translateX(0)}}
.reel:hover .reel__track{animation-play-state:paused}

/* Lightbox */
.lightbox{border:0;padding:0;width:100vw;height:100vh;max-width:100vw;max-height:100vh;background:transparent;overflow:hidden}
.lightbox::backdrop{background:rgba(6,7,10,.94)}
.lightbox img{width:auto;height:auto;max-width:92vw;max-height:86vh;display:block;margin:auto;position:absolute;inset:0}
.lightbox__close{position:absolute;top:20px;right:24px;width:46px;height:46px;border:1px solid var(--rule-dark);background:rgba(12,13,17,.6);color:#fff;font-size:22px;cursor:pointer;z-index:2}
.lightbox__close:hover{border-color:var(--red)}

/* Results: faint photo band behind testimonials */
.results{position:relative;overflow:hidden}
.results__bg{position:absolute;inset:0;z-index:0}
.results__bg img{width:100%;height:100%;object-fit:cover;opacity:.13;filter:grayscale(.55) contrast(1.1)}
.results .wrap{position:relative;z-index:1}
