/* 905PUCK Hockey Development — light editorial system.
   White background, black + blue text. Clash Display / Khand / Satoshi / Zodiak.
   Hard edges, hairline rules, asymmetric layout, NO decorative index/ghost numerals.
   One stylesheet, every page. Class names consumed by app.js are preserved. */

/* ---------- tokens ---------- */
:root{
  --bg:#f6f3fc; --bg-2:#e9f5fb; --bg-3:#dce8f6;        /* Magnolia / Solitude */
  --ink:#020203; --ink-2:#171a2e; --dim:#565b73; --dimmer:#888da6;
  --blue:#1b2e9d; --blue-2:#2c41cf; --blue-deep:#111f74; /* Torea Bay */
  --line:rgba(2,2,3,.14); --line-2:rgba(2,2,3,.07);
  --font-disp:"Clash Display",sans-serif;
  --font-sub:"Khand",sans-serif;
  --font-body:"Satoshi",system-ui,sans-serif;
  --font-quote:"Zodiak",Georgia,serif;
  --ease-out-expo:cubic-bezier(0.16,1,0.3,1);
  --wrap:1320px; --pad:clamp(20px,5vw,80px);
  --r:3px;
}

/* ---------- reset / base ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
html,body{max-width:100vw;overflow-x:hidden}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);
  line-height:1.55;font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--blue);color:#fff}

h1,h2,h3,.disp{font-family:var(--font-disp);font-weight:600;line-height:.92;
  letter-spacing:-.02em;text-transform:uppercase;color:var(--ink)}
.kicker{font-family:var(--font-sub);font-weight:600;text-transform:uppercase;
  letter-spacing:.2em;font-size:13px;color:var(--blue)}
.lead{font-size:clamp(16px,1.5vw,19px);color:var(--dim);max-width:54ch;line-height:1.65}
.mono{font-family:var(--font-sub);text-transform:uppercase;letter-spacing:.18em;font-size:12px;color:var(--dimmer)}

/* ---------- atmosphere: faint rink lines on white ---------- */
.rink{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:1;
  background:
    linear-gradient(90deg,transparent calc(22% - 1px),rgba(27,46,157,.06) 22%,transparent calc(22% + 1px)),
    linear-gradient(90deg,transparent calc(78% - 1px),rgba(27,46,157,.06) 78%,transparent calc(78% + 1px)),
    radial-gradient(60vmax 50vmax at 88% -8%,rgba(27,46,157,.06),transparent 60%)}
.grain{display:none}
.halo{display:none}
.nav,main,.site-footer{position:relative;z-index:3}
.wrap{max-width:var(--wrap);margin:0 auto;padding-inline:var(--pad)}

/* ---------- buttons (squared, athletic) ---------- */
.btn,.btn-blue{position:relative;display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-sub);font-weight:600;text-transform:uppercase;letter-spacing:.12em;
  font-size:14px;padding:15px 26px;border-radius:var(--r);overflow:hidden;
  border:1.5px solid var(--blue);transition:color .35s var(--ease-out-expo),transform .3s var(--ease-out-expo)}
.btn{color:var(--ink);border-color:var(--ink);background:transparent}
.btn-blue{color:#fff;background:var(--blue);border-color:var(--blue)}
.btn::before,.btn-blue::before{content:"";position:absolute;inset:0;z-index:-1;
  transform:translateY(101%);transition:transform .42s var(--ease-out-expo)}
.btn::before{background:var(--blue)}.btn-blue::before{background:var(--ink)}
.btn:hover{color:#fff;border-color:var(--blue)}.btn-blue:hover{color:#fff}
.btn .arw,.btn-blue .arw{transition:transform .3s var(--ease-out-expo)}
.btn:hover .arw,.btn-blue:hover .arw{transform:translateX(5px)}

/* big typographic CTA */
.bigcta{display:flex;align-items:center;justify-content:space-between;gap:24px;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:clamp(28px,5vw,60px) 0;font-family:var(--font-disp);text-transform:uppercase;
  font-size:clamp(38px,8vw,116px);line-height:.9;letter-spacing:-.02em;color:var(--ink);
  transition:color .35s,padding-left .35s var(--ease-out-expo)}
.bigcta:hover{color:var(--blue);padding-left:18px}
.bigcta .arw{flex:none;font-size:.5em;color:var(--blue)}

/* ---------- nav (solid white, never transparent so it can't clash with hero) ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;
  justify-content:space-between;padding:16px var(--pad);background:rgba(246,243,252,.92);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line-2);
  transition:padding .4s var(--ease-out-expo),box-shadow .4s,border-color .4s}
.nav.stuck{padding:11px var(--pad);box-shadow:0 8px 30px -18px rgba(2,2,3,.35);border-color:var(--line)}
.nav-brand{font-family:var(--font-disp);font-size:25px;letter-spacing:.02em;color:var(--ink);
  display:flex;align-items:center;gap:1px;transition:font-size .4s var(--ease-out-expo)}
.nav.stuck .nav-brand{font-size:23px}
.nav-brand b{color:var(--blue)}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-family:var(--font-sub);font-weight:500;text-transform:uppercase;
  letter-spacing:.14em;font-size:13px;color:var(--dim);position:relative;padding:4px 0;transition:color .25s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--blue);
  transition:width .3s var(--ease-out-expo)}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--ink)}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{width:100%}
.nav-right{display:flex;align-items:center;gap:18px}
.nav-burger{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:var(--r);
  background:transparent;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.nav-burger span{width:18px;height:2px;background:var(--ink)}
.nav-mobile{position:fixed;inset:0;z-index:49;background:rgba(246,243,252,.98);backdrop-filter:blur(18px);
  display:flex;flex-direction:column;justify-content:flex-start;gap:0;
  padding:clamp(86px,13vh,116px) var(--pad) 44px;overflow-y:auto;-webkit-overflow-scrolling:touch;
  opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s}
.nav-mobile.is-open{opacity:1;visibility:visible}
.nav-mobile a{font-family:var(--font-disp);font-size:clamp(30px,8.5vw,50px);color:var(--ink);
  letter-spacing:-.01em;text-transform:uppercase;border-bottom:1px solid var(--line-2);padding:14px 0;flex:none}
.nav-mobile a:active{color:var(--blue)}
.nav-mobile .btn-blue{margin-top:18px;font-size:15px;align-self:flex-start;border-bottom:none}

/* ---------- section masthead (no index numerals) ---------- */
.section{padding-block:clamp(64px,9vw,140px)}
.masthead{border-top:2px solid var(--ink);padding-top:22px;margin-bottom:clamp(32px,5vw,64px)}
.masthead .kicker{display:block;margin-bottom:14px}
.masthead h2{font-size:clamp(38px,6.5vw,98px)}
.masthead h2 .accent{color:var(--blue)}
.masthead h2 .out{-webkit-text-stroke:1.4px var(--blue);color:transparent}
.masthead .lead{margin-top:16px}

/* ---------- hero (asymmetric, no ghost numeral, never under nav) ---------- */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  padding-top:clamp(120px,18vh,180px);padding-bottom:clamp(28px,5vh,56px);overflow:hidden}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(246,243,252,.35),rgba(246,243,252,.6) 55%,rgba(246,243,252,.94) 96%)}
.hero-video{width:100%;height:100%;object-fit:cover}
.hero-inner{position:relative;z-index:2;width:100%}
.hero-meta{display:flex;gap:16px;align-items:center;margin-bottom:18px}
.hero-meta .tick{width:34px;height:2px;background:var(--blue)}
.hero h1{font-size:clamp(46px,10vw,128px);font-weight:700;letter-spacing:-.03em;line-height:.88;color:var(--ink)}
.hero h1 .accent{color:var(--blue)}
.hero h1 .outline{-webkit-text-stroke:1.5px var(--blue);color:transparent}
.hero-sub{margin:24px 0 30px;max-width:48ch}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.puck-streak{position:absolute;top:36%;left:-20%;width:60%;height:2px;z-index:1;
  background:linear-gradient(90deg,transparent,var(--blue),transparent);filter:blur(.5px);opacity:0}
.scroll-ind{font-family:var(--font-sub);font-size:11px;letter-spacing:.3em;color:var(--dimmer);
  text-transform:uppercase;margin-top:34px}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);margin-top:40px}
.hero-stats .hs{padding:18px 18px 0 0}
.hero-stats .hs .n{font-family:var(--font-disp);font-weight:700;font-size:clamp(30px,4vw,52px);color:var(--ink)}
.hero-stats .hs .l{font-family:var(--font-sub);text-transform:uppercase;letter-spacing:.16em;font-size:11px;color:var(--dim)}

/* ---------- ticker ---------- */
.ticker{border-block:1px solid var(--line);overflow:hidden;display:flex;white-space:nowrap;background:var(--bg-2)}
.ticker-track{display:flex;align-items:center;animation:tick 32s linear infinite;will-change:transform}
.ticker-track span{font-family:var(--font-sub);font-weight:600;text-transform:uppercase;letter-spacing:.16em;
  font-size:14px;color:var(--ink);padding:14px 26px;display:inline-flex;align-items:center;gap:26px}
.ticker-track span::after{content:"";width:6px;height:6px;background:var(--blue);border-radius:50%;display:inline-block}
.ticker-track .dim{color:var(--dimmer)}
@keyframes tick{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}

/* ---------- big statement ---------- */
.statement{font-family:var(--font-disp);text-transform:uppercase;font-weight:600;letter-spacing:-.02em;
  font-size:clamp(30px,5.2vw,76px);line-height:.98;max-width:18ch;color:var(--ink)}
.statement .accent{color:var(--blue)}
.statement .out{-webkit-text-stroke:1.4px var(--blue);color:transparent}

/* ---------- program index (rows, no numerals) ---------- */
.proglist{border-top:1px solid var(--line)}
.progrow{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;
  padding:clamp(24px,3.5vw,42px) 0;border-bottom:1px solid var(--line);transition:padding-left .35s var(--ease-out-expo)}
.progrow:hover{padding-left:14px}
.progrow .pt{font-family:var(--font-disp);text-transform:uppercase;font-size:clamp(26px,4vw,54px);line-height:.9;color:var(--ink)}
.progrow .pd{color:var(--dim);font-size:14px;margin-top:10px;max-width:52ch}
.progrow .pmeta{display:flex;flex-direction:column;align-items:flex-end;gap:6px;text-align:right}
.progrow .pmeta .from{font-family:var(--font-sub);text-transform:uppercase;letter-spacing:.14em;font-size:12px;color:var(--dimmer)}
.progrow .pmeta .pp{font-family:var(--font-disp);font-size:32px;color:var(--blue)}

/* ---------- spec / price table ---------- */
.spec{border-top:2px solid var(--blue)}
.specrow{display:grid;grid-template-columns:1.4fr 2fr auto auto;gap:24px;align-items:center;
  padding:24px 0;border-bottom:1px solid var(--line)}
.specrow .sname{font-family:var(--font-disp);text-transform:uppercase;font-size:clamp(20px,2.2vw,28px);color:var(--ink)}
.specrow .sinc{color:var(--dim);font-size:13.5px}
.specrow .sprice{font-family:var(--font-disp);font-size:34px;color:var(--blue);text-align:right}
.specrow .sprice small{font-family:var(--font-sub);font-size:13px;color:var(--dimmer);display:block;text-align:right}
.specrow .sbtn{justify-self:end}

/* ---------- editorial split ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,72px);align-items:center}
.split.rev{grid-template-columns:.95fr 1.05fr}
.split .big{font-size:clamp(38px,6.5vw,100px);line-height:.9;margin-bottom:8px}
.split .big .accent{color:var(--blue)}
.pull{font-family:var(--font-quote);font-style:italic;font-size:clamp(20px,2.4vw,30px);color:var(--ink);
  border-left:2px solid var(--blue);padding-left:22px;margin:22px 0;line-height:1.4}

/* ---------- oversized stat row ---------- */
.statband{display:grid;grid-template-columns:repeat(3,1fr)}
.statband .sb{padding:30px 24px 0 0;border-top:1px solid var(--line)}
.statband .sb .n{font-family:var(--font-disp);font-weight:700;font-size:clamp(54px,10vw,140px);line-height:.82;color:var(--blue)}
.statband .sb .l{font-family:var(--font-sub);text-transform:uppercase;letter-spacing:.16em;font-size:12px;color:var(--dim);margin-top:10px}

/* ---------- value rows (titled, no numerals) ---------- */
.vrows{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-2);border:1px solid var(--line-2)}
.vrow{background:var(--bg);padding:30px 28px}
.vrow h3{font-size:clamp(22px,2.4vw,30px);margin-bottom:10px;color:var(--ink)}
.vrow h3::before{content:"";display:inline-block;width:22px;height:3px;background:var(--blue);
  vertical-align:middle;margin-right:12px;transform:translateY(-4px)}
.vrow p{color:var(--dim);font-size:14px}

/* ---------- membership feature list (no trailing numbers) ---------- */
.featlist{list-style:none;display:flex;flex-direction:column}
.featlist li{display:flex;justify-content:space-between;gap:16px;align-items:baseline;
  padding:18px 0;border-bottom:1px solid var(--line);font-family:var(--font-disp);text-transform:uppercase;
  font-size:clamp(20px,2.6vw,34px);color:var(--ink)}
.featlist li span{font-family:var(--font-sub);text-transform:uppercase;letter-spacing:.14em;font-size:12px;color:var(--dimmer)}

/* ---------- testimonial rows (staggered) ---------- */
.quotes{display:flex;flex-direction:column}
.qrow{border-bottom:1px solid var(--line);padding:clamp(24px,4vw,46px) 0;max-width:760px}
.qrow:nth-child(even){margin-left:auto;text-align:right}
.qrow:nth-child(even) .pull{border-left:none;border-right:2px solid var(--blue);padding-left:0;padding-right:22px}
.qrow .who{font-family:var(--font-sub);text-transform:uppercase;letter-spacing:.16em;font-size:12px;color:var(--dimmer);margin-top:14px}

/* ---------- generic card / grid ---------- */
.card{display:block;border:1px solid var(--line);background:var(--bg);overflow:hidden;
  transition:transform .35s var(--ease-out-expo),border-color .35s,box-shadow .35s}
.card:hover{transform:translateY(-6px);border-color:var(--blue);box-shadow:0 24px 50px -30px rgba(27,46,157,.5)}
.card-body{padding:26px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-2)}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,3vw,40px)}

/* ---------- placeholders ---------- */
.placeholder{position:relative;display:flex;align-items:center;justify-content:center;text-align:center;
  padding:24px;border:1px solid var(--line);background:
    repeating-linear-gradient(45deg,rgba(27,46,157,.05) 0 10px,transparent 10px 20px),var(--bg-2);
  color:var(--dim);font-size:12.5px;letter-spacing:.02em}
.placeholder[data-ar="16:9"]{aspect-ratio:16/9}
.placeholder[data-ar="4:5"]{aspect-ratio:4/5}
.placeholder[data-ar="1:1"]{aspect-ratio:1/1}
.placeholder[data-ar="3:2"]{aspect-ratio:3/2}
.placeholder .ph-label{max-width:34ch;line-height:1.5}
.placeholder .ph-icon{font-size:20px;opacity:.6;display:block;margin-bottom:8px;color:var(--blue)}
.placeholder-video{position:absolute;inset:0;display:flex;align-items:flex-start;justify-content:flex-end;
  text-align:right;color:var(--dimmer);font-size:11px;background:linear-gradient(135deg,var(--bg-3),var(--bg-2))}
.placeholder-video .ph-label{max-width:28ch;line-height:1.5;padding:104px var(--pad) 0 0;opacity:.7}

/* ---------- form ---------- */
.form{display:flex;flex-direction:column;gap:20px}
.field label{display:block;font-family:var(--font-sub);text-transform:uppercase;letter-spacing:.16em;
  font-size:11px;color:var(--dimmer);margin-bottom:8px}
.field input,.field textarea,.field select{width:100%;background:transparent;border:none;
  border-bottom:1.5px solid var(--line);color:var(--ink);font-family:var(--font-body);font-size:16px;
  padding:10px 2px;transition:border-color .3s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--blue)}
.field textarea{resize:vertical;min-height:110px}

/* ---------- contrast band (light grey, blue stripe) ---------- */
.darkband{background:var(--bg-2);border-block:1px solid var(--line);position:relative;overflow:hidden}
.darkband::before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--blue)}

/* ---------- footer ---------- */
.site-footer{border-top:1px solid var(--line);padding-block:clamp(40px,6vw,70px) 36px;background:var(--bg-2)}
.footer-mark{font-family:var(--font-disp);font-weight:700;font-size:clamp(54px,18vw,230px);line-height:.82;
  color:transparent;-webkit-text-stroke:1.4px rgba(2,2,3,.16);margin-bottom:40px;letter-spacing:-.03em}
.footer-cols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:30px;margin-bottom:40px}
.footer-cols h4{font-family:var(--font-sub);text-transform:uppercase;letter-spacing:.18em;font-size:12px;
  color:var(--blue);margin-bottom:14px}
.footer-cols a,.footer-cols p{display:block;color:var(--dim);font-size:14px;margin-bottom:8px;transition:color .25s}
.footer-cols a:hover{color:var(--ink)}
.footer-base{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;border-top:1px solid var(--line-2);
  padding-top:22px;color:var(--dimmer);font-size:12px;font-family:var(--font-sub);letter-spacing:.08em;text-transform:uppercase}

/* ---------- reveals (fail-open) ---------- */
.reveal-ready [data-reveal]{opacity:0;transform:translateY(24px);
  transition:opacity .8s var(--ease-out-expo),transform .8s var(--ease-out-expo)}
.reveal-ready [data-reveal].in{opacity:1;transform:none}
.reveal-ready [data-stagger]>*{opacity:0;transform:translateY(18px);
  transition:opacity .6s var(--ease-out-expo),transform .6s var(--ease-out-expo)}
.reveal-ready [data-stagger].in>*{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media (max-width:1024px){
  .split,.split.rev{grid-template-columns:1fr;gap:30px}
  .vrows{grid-template-columns:1fr 1fr}
  .grid-3{grid-template-columns:1fr 1fr}
  .footer-cols{grid-template-columns:1fr 1fr}
  .specrow{grid-template-columns:1fr auto;gap:10px 18px}
  .specrow .sinc{grid-column:1 / -1;order:3}
  .specrow .sbtn{grid-column:1 / -1;order:4;justify-self:start}
}
@media (max-width:768px){
  .nav-links,.nav-right .btn-blue{display:none}
  .nav-burger{display:flex}
  .hero{min-height:auto;padding-top:120px}
  .hero-stats,.statband,.grid-3,.vrows{grid-template-columns:1fr}
  .statband .sb{padding-bottom:18px}
  .progrow{grid-template-columns:1fr;gap:14px}
  .progrow .pmeta{align-items:flex-start;text-align:left;flex-direction:row;gap:16px}
  .ticker-track span{font-size:13px;padding:12px 18px;gap:18px}
  .btn,.btn-blue{width:100%;justify-content:center}
  .hero-cta{flex-direction:column}
  .qrow:nth-child(even){margin-left:0;text-align:left}
  .qrow:nth-child(even) .pull{border-right:none;border-left:2px solid var(--blue);padding-left:22px;padding-right:0}
  .footer-base{flex-direction:column}
}
@media (max-width:420px){
  .vrows,.footer-cols{grid-template-columns:1fr}
}
@media (hover:none){
  [data-magnetic]{transform:none !important}
  .card:hover,.progrow:hover,.bigcta:hover{transform:none;padding-left:0;box-shadow:none}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto !important}
  .reveal-ready [data-reveal],.reveal-ready [data-stagger]>*{opacity:1 !important;transform:none !important}
  .puck-streak{display:none}
}
