/* ============================================================
   TEAM CAROLINA LACROSSE — design system
   Black/white foundation · Pantone 299 (#C22134) accent
   ============================================================ */
:root{
  /* Type scale (fluid) */
  --text-xs:clamp(.75rem,.7rem + .25vw,.85rem);
  --text-sm:clamp(.8125rem,.78rem + .2vw,.9375rem);
  --text-base:clamp(1rem,.96rem + .2vw,1.0625rem);
  --text-lg:clamp(1.125rem,1rem + .55vw,1.375rem);
  --text-xl:clamp(1.5rem,1.2rem + 1.25vw,2.25rem);
  --text-2xl:clamp(2rem,1.3rem + 2.6vw,3.5rem);
  --text-3xl:clamp(2.6rem,1.2rem + 5vw,5.5rem);
  --text-hero:clamp(3.1rem,.4rem + 9vw,8.5rem);

  /* Spacing (4px) */
  --space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;
  --space-5:1.25rem;--space-6:1.5rem;--space-7:1.75rem;--space-8:2rem;--space-10:2.5rem;
  --space-12:3rem;--space-14:3.5rem;--space-16:4rem;--space-18:4.5rem;--space-20:5rem;--space-24:6rem;--space-32:8rem;

  /* Brand palette */
  --pantone-299:#C22134;          /* Team Carolina red */
  --accent:#E63B4F;               /* slightly brighter for dark-bg contrast */
  --accent-strong:#C22134;
  --accent-deep:#8E1726;

  --radius-sm:.375rem;--radius-md:.625rem;--radius-lg:1rem;--radius-xl:1.5rem;--radius-full:9999px;
  --t:200ms cubic-bezier(.16,1,.3,1);
  --content:1240px;--content-narrow:760px;

  --ease:cubic-bezier(.16,1,.3,1);
  --shadow-md:0 8px 30px rgba(0,0,0,.18);
  --shadow-lg:0 24px 60px rgba(0,0,0,.30);
}

/* ---- DARK (default brand theme) ---- */
:root,[data-theme='dark']{
  --color-bg:#070809;
  --color-bg-2:#0d0f12;
  --color-surface:#121519;
  --color-surface-2:#191d23;
  --color-border:rgba(255,255,255,.10);
  --color-border-strong:rgba(255,255,255,.18);
  --color-text:#f4f6f8;
  --color-text-muted:#a4adb8;
  --color-text-faint:#6b7480;
  --color-accent:var(--accent);
  --color-on-accent:#ffffff;
  --hero-overlay:linear-gradient(180deg,rgba(7,8,9,.55) 0%,rgba(7,8,9,.35) 35%,rgba(7,8,9,.82) 100%);
  --logo-plate:#0d0f12;
}
/* ---- LIGHT ---- */
[data-theme='light']{
  --color-bg:#ffffff;
  --color-bg-2:#f4f6f8;
  --color-surface:#ffffff;
  --color-surface-2:#f1f4f7;
  --color-border:rgba(0,0,0,.10);
  --color-border-strong:rgba(0,0,0,.16);
  --color-text:#0a0c0e;
  --color-text-muted:#525a64;
  --color-text-faint:#8b939d;
  --color-accent:var(--accent-strong);
  --color-on-accent:#ffffff;
  --hero-overlay:linear-gradient(180deg,rgba(5,7,9,.45) 0%,rgba(5,7,9,.30) 40%,rgba(5,7,9,.78) 100%);
  --logo-plate:#ffffff;
  --shadow-md:0 8px 30px rgba(10,14,20,.10);
  --shadow-lg:0 24px 60px rgba(10,14,20,.16);
}

/* ============ FONTS ============ */
:root{
  --font-display:'Anton','Arial Narrow',sans-serif;
  --font-body:'Archivo','Helvetica Neue',sans-serif;
}
html,body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
h1,h2,h3,h4,h5,h6,.injury-head,.policy-head,.roster-head,.tier-name,.tier-amount,.pay-name,.pay-amount,.plans-title,.calc-result-title{text-rendering:geometricPrecision;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-synthesis:none}

/* ============ LAYOUT PRIMITIVES ============ */
.wrap{width:100%;max-width:var(--content);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2.5rem)}
.section{padding-block:clamp(var(--space-16),9vw,var(--space-32))}
.section--tight{padding-block:clamp(var(--space-12),6vw,var(--space-20))}
.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--font-body);font-weight:700;
  font-size:var(--text-xs);letter-spacing:.22em;text-transform:uppercase;
  color:var(--color-accent);
}
.eyebrow::before{content:'';width:26px;height:2px;background:var(--color-accent)}
.eyebrow--center::after{content:'';width:26px;height:2px;background:var(--color-accent)}
.eyebrow--plain::before{display:none}

h1,h2,h3{font-family:var(--font-display);font-weight:400;letter-spacing:.005em;text-transform:uppercase;line-height:.98}
.h-section{font-size:var(--text-2xl);margin-bottom:var(--space-5)}
.lead{font-size:var(--text-lg);color:var(--color-text-muted);max-width:62ch;font-weight:400}
.muted{color:var(--color-text-muted)}
.center{text-align:center}
.mxauto{margin-inline:auto}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--font-body);font-weight:700;font-size:var(--text-sm);
  letter-spacing:.04em;text-transform:uppercase;
  padding:.95rem 1.7rem;border-radius:var(--radius-full);
  border:2px solid transparent;line-height:1;white-space:nowrap;
}
.btn svg{width:1.05em;height:1.05em}
.btn--primary{background:var(--color-accent);color:var(--color-on-accent);box-shadow:0 6px 24px rgba(194,33,52,.30)}
.btn--primary:hover{background:#fff;color:#000;transform:translateY(-2px);box-shadow:0 10px 30px rgba(194,33,52,.42)}
.btn--ghost{border-color:var(--color-border-strong);color:var(--color-text);background:transparent}
.btn--ghost:hover{border-color:var(--color-accent);color:var(--color-accent);transform:translateY(-2px)}
.btn--light{background:var(--color-text);color:var(--color-bg)}
.btn--light:hover{background:var(--color-accent);color:var(--color-on-accent);transform:translateY(-2px)}
.btn--sm{padding:.7rem 1.2rem;font-size:var(--text-xs)}
.btn-row{display:flex;flex-wrap:wrap;gap:var(--space-4)}

/* ============ HEADER / NAV ============ */
.header{position:sticky;top:0;z-index:60;
  background:color-mix(in srgb,var(--color-bg) 82%,transparent);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:border-color var(--t),background var(--t)}
.header.scrolled{border-bottom-color:var(--color-border);background:color-mix(in srgb,var(--color-bg) 94%,transparent)}
.nav{display:flex;align-items:center;justify-content:space-between;height:4.5rem;gap:var(--space-8)}
.brand{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-display);
  font-size:1.4rem;line-height:1;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap;flex:none}
.brand .mark{width:36px;height:36px;border-radius:var(--radius-full);flex:none;background:#000;display:grid;place-items:center;border:1.5px solid var(--color-accent)}
.brand .mark svg{width:22px;height:22px}
.brand b{font-weight:400}
.brand .accent{color:var(--color-accent)}
.nav-links{display:flex;align-items:center;gap:.15rem;list-style:none;margin-inline:auto}
.nav-links a{display:block;font-family:var(--font-body);font-weight:600;font-size:var(--text-sm);letter-spacing:.01em;
  white-space:nowrap;padding:.55rem .85rem;border-radius:var(--radius-sm);color:var(--color-text-muted);position:relative;transition:color var(--t)}
.nav-links a:hover{color:var(--color-text)}
.nav-links a.active{color:var(--color-text)}
.nav-links a.active::after{content:'';position:absolute;left:.85rem;right:.85rem;bottom:.05rem;height:2px;background:var(--color-accent);border-radius:2px}
.nav-actions{display:flex;align-items:center;gap:var(--space-4);flex:none}
.theme-toggle{width:34px;height:34px;border-radius:var(--radius-full);display:grid;place-items:center;
  color:var(--color-text-faint);border:0;background:transparent;transition:color var(--t)}
.theme-toggle:hover{color:var(--color-accent)}
.theme-toggle svg{width:18px;height:18px}
.nav-cta{display:inline-flex}
.burger{display:none;width:42px;height:42px;border-radius:var(--radius-sm);place-items:center;color:var(--color-text)}
.burger svg{width:26px;height:26px}

@media(max-width:1180px){
  .nav-links,.nav-cta{display:none}
  .burger{display:grid}
  .nav{gap:var(--space-4)}
}
@media(min-width:1181px) and (max-width:1500px){
  .nav{gap:var(--space-4)}
  .nav-links{gap:0}
  .nav-links a{padding:.5rem .55rem;font-size:.82rem}
  .nav-cta{font-size:.82rem;padding:.55rem .9rem}
}
/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:70;background:var(--color-bg);
  display:flex;flex-direction:column;padding:var(--space-6);
  transform:translateX(100%);transition:transform .35s var(--ease);visibility:hidden}
.drawer.open{transform:translateX(0);visibility:visible}
.drawer-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-8)}
.drawer-close{width:44px;height:44px;display:grid;place-items:center;color:var(--color-text)}
.drawer-close svg{width:28px;height:28px}
.drawer nav{display:flex;flex-direction:column}
.drawer a.dl{display:block;font-family:var(--font-display);font-size:1.7rem;text-transform:uppercase;padding:.7rem 0;
  border-bottom:1px solid var(--color-border);color:var(--color-text);line-height:1.1}
.drawer a.dl:hover,.drawer a.dl.active{color:var(--color-accent)}
.drawer .btn{margin-top:var(--space-8)}

/* ============ HERO (graphic — no photo) ============ */
.hero{position:relative;min-height:clamp(600px,94vh,960px);display:flex;align-items:center;overflow:hidden;
  background:
    radial-gradient(115% 90% at 85% -10%,rgba(230,59,79,.20),transparent 55%),
    radial-gradient(90% 80% at -5% 110%,rgba(0,119,168,.18),transparent 52%),
    linear-gradient(180deg,#0a0e12 0%,#070809 55%,#050607 100%)}
.hero-fx{position:absolute;inset:0;isolation:isolate;pointer-events:none;overflow:hidden}
.hero-glow{position:absolute;border-radius:50%;filter:blur(90px)}
.hero-glow--1{width:48vw;height:48vw;max-width:660px;max-height:660px;top:-16%;right:-6%;
  background:radial-gradient(circle,rgba(230,59,79,.55),transparent 70%)}
.hero-glow--2{width:42vw;height:42vw;max-width:540px;max-height:540px;bottom:-22%;left:-10%;
  background:radial-gradient(circle,rgba(0,119,168,.5),transparent 70%)}
/* field-line grid + lacrosse goal-fan geometry */
.hero-grid{position:absolute;inset:0;z-index:-1;opacity:.55;
  background-image:linear-gradient(rgba(194,33,52,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(194,33,52,.06) 1px,transparent 1px);
  background-size:64px 64px;mask-image:linear-gradient(180deg,transparent,#000 55%);
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 55%)}
.hero-lines{position:absolute;right:clamp(-60px,-2vw,0px);top:50%;transform:translateY(-50%);
  height:128%;width:auto;color:var(--accent);opacity:.5}
.hero-watermark{position:absolute;left:-1.5%;bottom:-9%;font-family:var(--font-display);
  font-size:clamp(9rem,27vw,27rem);line-height:.8;letter-spacing:-.01em;white-space:nowrap;user-select:none;
  color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.06)}
.hero-diag{position:absolute;top:-10%;bottom:-10%;left:58%;width:2px;transform:skewX(-12deg);
  background:linear-gradient(180deg,transparent,rgba(230,59,79,.45),transparent)}
.hero-inner{position:relative;z-index:1;padding-block:clamp(var(--space-24),14vw,8.5rem);color:#fff}
.hero .kicker{color:var(--accent)}
.hero h1{font-size:var(--text-hero);color:#fff;margin:var(--space-4) 0;max-width:9ch;line-height:.9;
  text-shadow:0 6px 60px rgba(0,0,0,.5);hyphens:none;overflow-wrap:normal}
@media(min-width:761px){
  .hero h1{font-size:clamp(3.4rem,7.2vw,6.2rem)}
  .hero-inner{max-width:min(56%,620px);margin-inline:0;padding-left:clamp(1.5rem,5vw,3rem)}
  .hero .lead{max-width:46ch}
  .hero-slogan{max-width:18ch}
}
.hero h1 .accent{color:var(--accent);text-shadow:0 0 44px rgba(230,59,79,.45)}
.hero-slogan{font-family:var(--font-display);text-transform:uppercase;line-height:1;
  font-size:clamp(1.25rem,3.4vw,1.9rem);letter-spacing:.04em;color:#fff;
  margin:0 0 var(--space-5)}
.hero-slogan .accent{color:var(--accent)}
.hero .lead{color:rgba(255,255,255,.85);max-width:54ch;margin-bottom:var(--space-8)}
.hero .btn--ghost{border-color:rgba(255,255,255,.4);color:#fff}
.hero .btn--ghost:hover{border-color:var(--accent);color:var(--accent)}
/* hero athlete feature — Grace Webb cutout, right side, behind geometry */
.hero-photo{position:absolute;top:0;bottom:0;right:0;width:min(52%,720px);overflow:hidden}
.hero-photo-glow{position:absolute;inset:0;
  background:radial-gradient(58% 54% at 70% 44%,rgba(230,59,79,.34),transparent 62%)}
.hero-photo img{position:absolute;top:4%;bottom:8%;right:4%;height:88%;width:auto;max-width:100%;object-fit:contain;
  opacity:.96;filter:contrast(1.06) saturate(1.06) brightness(.99) drop-shadow(0 18px 42px rgba(0,0,0,.55));
  -webkit-mask-image:linear-gradient(180deg,#000 95%,transparent 100%);mask-image:linear-gradient(180deg,#000 95%,transparent 100%)}
.hero-photo::after{content:"";position:absolute;inset:0;pointer-events:none}
.hero-credit{position:absolute;z-index:2;right:clamp(1rem,3vw,2.4rem);bottom:clamp(1rem,3vw,2rem);
  display:flex;align-items:center;gap:.7rem;padding:.7rem 1rem;max-width:min(92vw,360px);
  background:rgba(8,11,13,.6);border:1px solid rgba(255,255,255,.13);border-radius:14px;
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.hero-credit-star{display:inline-flex;flex:none;width:30px;height:30px;align-items:center;justify-content:center;
  color:var(--accent);background:rgba(230,59,79,.14);border-radius:50%}
.hero-credit-star svg{width:17px;height:17px}
.hero-credit-text{font-size:var(--text-sm);line-height:1.25;color:rgba(255,255,255,.9)}
.hero-credit-text b{color:#fff}
.hero-credit-commit{display:block;font-size:var(--text-xs);font-weight:600;letter-spacing:.01em;color:var(--accent)}
@media(max-width:760px){
  /* taller poster-like hero that fills the viewport */
  .hero{min-height:clamp(560px,86vh,780px)}
  /* generous bottom padding clears the stacked CTAs above the credit card */
  .hero-inner{padding-block:clamp(var(--space-16),16vw,var(--space-24)) clamp(var(--space-24),26vw,var(--space-32))}
  .hero .kicker{font-size:var(--text-xs)}
  /* clear vertical rhythm: eyebrow -> H1 -> slogan -> lead -> CTAs */
  .hero h1{font-size:clamp(2.8rem,16vw,3.6rem);line-height:.92;margin:var(--space-5) 0}
  .hero-slogan{font-size:clamp(1.15rem,5.6vw,1.55rem);margin-bottom:var(--space-6)}
  .hero .lead{font-size:var(--text-base);line-height:1.6;margin-bottom:var(--space-8)}
  .hero .btn-row{flex-direction:column;align-items:stretch;gap:var(--space-4)}
  .hero .btn-row .btn{width:100%;justify-content:center;padding-block:1.05rem}
  /* poster geometry: keep Grace as a strong right-side athlete behind the copy */
  .hero-lines{opacity:.3;height:80%;right:-26%}
  .hero-watermark{font-size:46vw;bottom:auto;top:auto;left:-4%}
  .hero-diag{display:none}
  .hero-photo{width:100%;left:auto;right:0}
  .hero-photo img{opacity:.4;top:6%;bottom:auto;right:-22%;height:78%;width:auto;
    -webkit-mask-image:linear-gradient(180deg,#000 86%,transparent 100%);mask-image:linear-gradient(180deg,#000 86%,transparent 100%)}
  .hero-photo-glow{background:radial-gradient(60% 46% at 78% 40%,rgba(230,59,79,.24),transparent 64%)}
  .hero-photo::after{background:
    linear-gradient(90deg,#070809 28%,rgba(7,8,9,.35) 60%,transparent 82%),
    linear-gradient(0deg,#070809 5%,transparent 42%)}
  /* Grace credit card visible at the bottom of the hero, with air above the proof strip */
  .hero-credit{left:clamp(1rem,4vw,1.5rem);right:clamp(1rem,4vw,1.5rem);max-width:none;bottom:clamp(1.25rem,4vw,1.75rem)}
}

/* ============ PROOF STRIP ============ */
.proof{background:var(--color-bg-2);border-block:1px solid var(--color-border)}
.proof-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--color-border)}
.proof-cell{background:var(--color-bg-2);padding:clamp(var(--space-6),3vw,var(--space-10)) var(--space-5);text-align:center}
.proof-cell .ic{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;
  margin:0 auto var(--space-4);border-radius:11px;background:rgba(230,59,79,.1);
  border:1px solid rgba(230,59,79,.22);color:var(--color-accent)}
.proof-cell .ic svg{width:21px;height:21px}
.proof-cell h3{font-family:var(--font-display);font-size:var(--text-lg);margin-bottom:.35rem}
.proof-cell p{font-size:var(--text-sm);color:var(--color-text-muted)}
@media(max-width:760px){.proof-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:1fr}
  .proof-cell{padding:var(--space-7) var(--space-4);display:flex;flex-direction:column;justify-content:center;min-height:170px}
  .proof-cell .ic{width:36px;height:36px;margin-bottom:var(--space-3)}
  .proof-cell .ic svg{width:19px;height:19px}
  .proof-cell h3{font-size:var(--text-base)}
  .proof-cell p{font-size:var(--text-xs);line-height:1.35}}

/* ============ GENERIC GRIDS / CARDS ============ */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(var(--space-8),5vw,var(--space-20));align-items:center}
.grid-2--even{align-items:stretch}
.grid-2--even > *{display:flex;flex-direction:column;justify-content:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}
@media(max-width:900px){.grid-2{grid-template-columns:1fr}.grid-3{grid-template-columns:1fr}}

.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);
  padding:clamp(var(--space-6),3vw,var(--space-8));transition:transform var(--t),border-color var(--t),box-shadow var(--t)}
.card:hover{transform:translateY(-4px);border-color:var(--color-border-strong);box-shadow:var(--shadow-md)}
.card .ic{color:var(--color-accent);width:34px;height:34px;margin-bottom:var(--space-5)}
.card h3{font-size:var(--text-lg);margin-bottom:var(--space-3)}
.card p{font-size:var(--text-sm);color:var(--color-text-muted)}
.card .num{font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-accent);display:block;margin-bottom:var(--space-2)}
@media(max-width:760px){
  .card{padding:var(--space-5) var(--space-5)}
  .card .ic{width:28px;height:28px;margin-bottom:var(--space-3)}
  .card h3{margin-bottom:var(--space-2)}
}

/* pathway cards */
.path-card{position:relative;overflow:hidden;background:var(--color-surface);border:1px solid var(--color-border);
  border-radius:var(--radius-lg);padding:clamp(var(--space-6),3vw,var(--space-8))}
.path-card.featured{border-color:var(--color-accent);background:linear-gradient(180deg,rgba(194,33,52,.08),transparent)}
.path-card .tier{font-family:var(--font-display);font-size:var(--text-xl);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.04em}
.path-card .tag{display:inline-block;font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--color-accent);border:1px solid var(--color-accent);border-radius:var(--radius-full);padding:.3rem .7rem;margin-bottom:var(--space-4);white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}
.path-card ul{list-style:none;margin-top:var(--space-5);display:grid;gap:var(--space-3)}
.path-card li{display:flex;gap:.6rem;font-size:var(--text-sm);color:var(--color-text-muted)}
.path-card li svg{flex:none;width:18px;height:18px;color:var(--color-accent);margin-top:.15rem}

/* media + text split */
.media{border-radius:var(--radius-lg);overflow:hidden;position:relative;box-shadow:var(--shadow-lg)}
.media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.media--wide img{aspect-ratio:3/2}
.media--fill{height:100%;min-height:100%}
.media--fill img{aspect-ratio:auto;height:100%;min-height:440px;object-position:center 22%}
.media .badge{position:absolute;left:var(--space-4);bottom:var(--space-4);background:rgba(7,8,9,.7);
  backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.15);color:#fff;border-radius:var(--radius-full);
  padding:.5rem 1rem;font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.media .badge .accent{color:var(--accent)}
.media .badge--commit{border-radius:14px;text-transform:none;letter-spacing:.02em;
  display:flex;flex-direction:column;gap:.12rem;line-height:1.25;padding:.6rem 1rem}
.media .badge--commit b{font-size:var(--text-sm);letter-spacing:.04em;color:#fff}
.media .badge--commit span{font-weight:600;font-size:var(--text-xs);color:rgba(255,255,255,.82)}

/* ============ STAT / NUMBER row ============ */
.statline{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:clamp(var(--space-6),5vw,var(--space-16));align-items:start}
.statline--center{justify-items:center;text-align:center}
.statline .s b{display:block;font-family:var(--font-display);font-size:var(--text-2xl);color:var(--color-text);line-height:1}
.statline .s span{display:block;font-size:var(--text-sm);color:var(--color-text-muted);margin-top:.35rem}
@media(max-width:760px){
  .statline{grid-auto-flow:row;grid-template-columns:repeat(2,1fr);gap:var(--space-6) var(--space-5)}
  .statline--3{grid-template-columns:repeat(3,1fr);gap:var(--space-5) var(--space-3)}
  .statline--3 .s b{font-size:var(--text-lg)}
  .statline .s b{font-size:var(--text-xl)}
}
@media(max-width:380px){
  .statline:not(.statline--3){grid-template-columns:1fr}
}

/* ============ EVALUATIONS ============ */
.eval{background:var(--color-bg-2);position:relative;overflow:hidden}
.eval-band{display:inline-flex;align-items:center;gap:.55rem;background:rgba(230,59,79,.08);
  color:var(--color-text);border:1px solid var(--color-border-strong);
  font-weight:800;font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;
  padding:.4rem .85rem;border-radius:var(--radius-full);margin-bottom:var(--space-5)}
.eval-band svg{width:1em;height:1em}
.eval-band-dot{flex:none;width:7px;height:7px;border-radius:50%;background:var(--color-accent);
  box-shadow:0 0 0 4px rgba(230,59,79,.18)}
.eval-cards{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);margin-top:var(--space-10)}
@media(max-width:760px){.eval-cards{grid-template-columns:1fr}}
.eval-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);
  padding:clamp(var(--space-6),3vw,var(--space-8));border-left:4px solid var(--color-accent)}
.eval-card .date{font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-text)}
.eval-card .when{color:var(--color-accent);font-weight:700;font-size:var(--text-sm);margin:.3rem 0 var(--space-4)}
.eval-card dl{display:grid;grid-template-columns:auto 1fr;gap:.55rem 1rem;font-size:var(--text-sm)}
.eval-card dt{color:var(--color-text-faint);font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:var(--text-xs);padding-top:.15rem}
.eval-card dd{color:var(--color-text)}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(var(--space-6),3vw,var(--space-10));counter-reset:s}
@media(max-width:760px){.steps{grid-template-columns:1fr;gap:var(--space-8)}}
.step{counter-increment:s;border-top:2px solid var(--color-border);padding-top:var(--space-5)}
.step::before{content:'0' counter(s);display:block;font-family:var(--font-display);font-size:var(--text-2xl);
  line-height:1;color:var(--color-accent);margin-bottom:var(--space-4)}
.step h3{font-size:var(--text-lg);margin:0 0 var(--space-2)}
.step p{font-size:var(--text-sm);color:var(--color-text-muted)}

/* ============ GALLERY ============ */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:var(--space-3)}
.gallery a{overflow:hidden;border-radius:var(--radius-md);position:relative;display:block}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.gallery a:hover img{transform:scale(1.06)}
.gallery .tall{grid-row:span 2}
.gallery .wide{grid-column:span 2}
@media(max-width:760px){.gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}.gallery .wide{grid-column:span 2}}

/* clean uniform photo showcase */
.showcase{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}
.showcase figure{margin:0;position:relative;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--color-border);box-shadow:var(--shadow-md)}
.showcase img{display:block;width:100%;height:100%;aspect-ratio:4/5;object-fit:cover;
  transition:transform .6s var(--ease)}
.showcase figure:hover img{transform:scale(1.05)}
.showcase figure::after{content:'';position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 55%,rgba(7,8,9,.62));}
.showcase figcaption{position:absolute;left:var(--space-4);bottom:var(--space-4);z-index:1;
  color:#fff;font-family:var(--font-body);font-weight:700;font-size:var(--text-xs);
  letter-spacing:.12em;text-transform:uppercase}
.showcase figcaption .accent{color:var(--accent)}
@media(max-width:760px){.showcase{grid-template-columns:1fr 1fr;gap:var(--space-3)}
  .showcase figure:last-child{grid-column:span 2}.showcase figure:last-child img{aspect-ratio:16/10}}

/* ============ FAQ ============ */
.faq-list{display:grid;gap:var(--space-3)}
.faq-item{
  background:var(--color-surface);
  border:1px solid var(--color-border-strong);
  border-radius:var(--radius-lg);
  overflow:hidden;
  transition:border-color .2s var(--ease),background .2s var(--ease),transform .2s var(--ease);
}
.faq-item:hover{border-color:var(--color-accent);background:var(--color-surface-2)}
.faq-item[open]{border-color:var(--color-accent);background:var(--color-surface-2)}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:var(--space-5) var(--space-5);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-4);
  font-family:var(--font-body);
  font-weight:700;
  font-size:var(--text-base);
  line-height:1.35;
  color:var(--color-text);
  -webkit-tap-highlight-color:rgba(194,33,52,.15);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item .faq-q{flex:1;text-align:left}
.faq-item .faq-pm{
  flex:none;
  width:28px;
  height:28px;
  padding:4px;
  color:#fff;
  background:var(--color-accent);
  border-radius:var(--radius-full);
  transition:transform .25s var(--ease),background .2s var(--ease);
  box-shadow:0 2px 8px rgba(194,33,52,.35);
}
.faq-item[open] .faq-pm{transform:rotate(45deg)}
.faq-item:hover .faq-pm{background:var(--color-accent-strong,#a31a2a)}
.faq-item .faq-a{
  padding:0 var(--space-5) var(--space-5);
  color:var(--color-text-muted);
  font-size:var(--text-sm);
  line-height:1.6;
  border-top:1px solid var(--color-border);
  margin-top:0;
}
.faq-item[open] .faq-a{padding-top:var(--space-4)}
.faq-item .faq-a p{margin:0}
@media(min-width:640px){
  .faq-item summary{padding:var(--space-5) var(--space-6);font-size:var(--text-lg)}
  .faq-item .faq-a{padding:var(--space-4) var(--space-6) var(--space-6);font-size:var(--text-base)}
}

/* ============ CTA banner ============ */
.cta{background:linear-gradient(135deg,#C22134,#8E1726);color:#fff;border-radius:var(--radius-xl);
  padding:clamp(var(--space-10),6vw,var(--space-24));text-align:center;position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;inset:0;opacity:.18;
  background-image:radial-gradient(circle at 20% 20%,#fff 0,transparent 40%),radial-gradient(circle at 80% 80%,#fff 0,transparent 40%)}
.cta h2{font-size:var(--text-2xl);color:#fff;margin-bottom:var(--space-4);position:relative}
.cta p{color:rgba(255,255,255,.9);max-width:54ch;margin:0 auto var(--space-8);position:relative}
.cta .btn-row{justify-content:center;position:relative}
.cta .btn--primary{background:#fff;color:#8E1726}
.cta .btn--primary:hover{background:#1a0608;color:#fff;transform:translateY(-2px)}
.cta .btn--ghost{border-color:rgba(255,255,255,.6);color:#fff}
.cta .btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.12);color:#fff}

/* ============ PAGE HEADER (interior) ============ */
.pagehead{position:relative;padding-block:clamp(var(--space-14),9vw,var(--space-24)) clamp(var(--space-10),6vw,var(--space-16));
  border-bottom:1px solid var(--color-border);overflow:hidden;background:var(--color-bg-2);text-align:center}
.pagehead .wrap{max-width:60rem;margin-inline:auto}
.pagehead .hero-grid{opacity:.55;mask-image:radial-gradient(ellipse at center,#000 35%,transparent 75%)}
.pagehead .eyebrow{display:inline-block}
.pagehead .eyebrow::before{content:"";display:inline-block;width:32px;height:2px;background:var(--color-accent);vertical-align:middle;margin-right:.6rem;opacity:.9}
.pagehead .eyebrow::after{content:"";display:inline-block;width:32px;height:2px;background:var(--color-accent);vertical-align:middle;margin-left:.6rem;opacity:.9}
.pagehead h1{font-size:var(--text-3xl);max-width:22ch;margin-inline:auto;text-wrap:balance}
.pagehead h1 .accent{color:var(--color-accent)}
.pagehead .lead{margin:var(--space-5) auto 0;max-width:62ch}

/* prose */
.prose p{color:var(--color-text-muted);margin-bottom:var(--space-5);max-width:68ch}
.prose p:last-child{margin-bottom:0}

/* coaches */
.coach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5)}
@media(max-width:860px){.coach-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.coach-grid{grid-template-columns:1fr}}
.team-block{margin-bottom:var(--space-10);text-align:left}
.team-block:last-child{margin-bottom:0}
.team-title{font-family:var(--font-display);font-size:var(--text-xl);letter-spacing:.04em;text-transform:uppercase;color:var(--color-accent);margin-bottom:var(--space-5);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}
.coach{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);text-align:left}
.coach .avatar{width:54px;height:54px;border-radius:var(--radius-full);background:var(--color-surface-2);
  display:grid;place-items:center;font-family:var(--font-display);font-size:1.25rem;color:var(--color-accent);
  border:1.5px solid var(--color-accent);margin-bottom:var(--space-4)}
.coach h3{font-size:var(--text-lg);text-transform:none;font-family:var(--font-body);font-weight:800;letter-spacing:0}
.coach .role{color:var(--color-accent);font-size:var(--text-sm);font-weight:700;margin-top:.2rem}
.coach .aff{color:var(--color-text-muted);font-size:var(--text-sm);margin-top:.5rem}

/* table */
.tbl-wrap{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg)}
table.styled{font-size:var(--text-sm)}
table.styled th,table.styled td{text-align:left;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border)}
table.styled thead th{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.08em;font-size:var(--text-xs);color:var(--color-text-faint);background:var(--color-bg-2)}
table.styled tbody tr:last-child td{border-bottom:none}
table.styled tbody tr:hover{background:var(--color-surface)}
.tba{color:var(--color-accent);font-weight:700;font-size:var(--text-xs);letter-spacing:.06em;border:1px solid var(--color-border-strong);border-radius:var(--radius-full);padding:.15rem .6rem}
/* responsive tables: 4-col tables become stacked, labeled cards on small screens */
@media(max-width:640px){
  .tbl-wrap{overflow:visible;border:0;border-radius:0;background:transparent}
  table.styled{display:block;width:100%}
  table.styled thead{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
  table.styled tbody{display:block}
  table.styled tbody tr{display:block;background:var(--color-surface);border:1px solid var(--color-border);
    border-radius:var(--radius-lg);padding:var(--space-2) var(--space-5) var(--space-4);margin-bottom:var(--space-4)}
  table.styled tbody tr:last-child{margin-bottom:0}
  table.styled tbody tr:hover{background:var(--color-surface)}
  table.styled td{display:flex;gap:var(--space-4);justify-content:space-between;align-items:baseline;
    text-align:right;padding:var(--space-3) 0;border-bottom:1px solid var(--color-border)}
  table.styled td:last-child{border-bottom:none}
  /* first cell becomes the card heading */
  table.styled td:first-child{display:block;text-align:left;padding-top:var(--space-4);padding-bottom:var(--space-3);
    font-family:var(--font-display);font-size:var(--text-lg);letter-spacing:.01em}
  table.styled td:first-child b{font-weight:400}
  table.styled td[data-c]::before{content:attr(data-c);color:var(--color-accent);font-weight:700;
    text-align:left;flex:none;letter-spacing:.02em}
  table.styled.compare td:first-child{color:var(--color-text)}
}

/* contact */
.contact-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:clamp(var(--space-6),4vw,var(--space-10))}
.contact-row{display:flex;gap:var(--space-4);align-items:flex-start;padding-block:var(--space-5);border-bottom:1px solid var(--color-border)}
.contact-row:last-child{border-bottom:none}
.contact-row .ic{flex:none;color:var(--color-accent);width:26px;height:26px;margin-top:.15rem}
.contact-row b{display:block;font-family:var(--font-body);font-weight:800}
.contact-row a{color:var(--color-accent)}
.contact-row a:hover{text-decoration:underline}

/* ============ FOOTER ============ */
.footer{background:#050607;border-top:1px solid rgba(255,255,255,.08);color:#cfd6dd;padding-block:var(--space-16) var(--space-8)}
[data-theme='light'] .footer{background:#0a0c0e}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:var(--space-10);margin-bottom:var(--space-12)}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr;gap:var(--space-8)}}
.footer .brand{color:#fff;margin-bottom:var(--space-4)}
.footer p{color:#8b939d;font-size:var(--text-sm);max-width:42ch}
.footer h4{font-family:var(--font-body);font-weight:800;text-transform:uppercase;letter-spacing:.1em;font-size:var(--text-xs);color:#fff;margin-bottom:var(--space-4)}
.footer ul{list-style:none;display:grid;gap:var(--space-2)}
.footer ul a{color:#8b939d;font-size:var(--text-sm)}
.footer ul a:hover{color:var(--accent)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:var(--space-6);display:flex;flex-wrap:wrap;gap:var(--space-4);justify-content:space-between;align-items:center}
.footer-bottom p{color:#6b7480;font-size:var(--text-xs)}

/* reveal animation */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* helpers */
.mb-0{margin-bottom:0}
.mt-8{margin-top:var(--space-8)}
.mt-10{margin-top:var(--space-10)}
.maxw-narrow{max-width:var(--content-narrow)}
.divider{height:1px;background:var(--color-border);border:0;margin-block:var(--space-12)}
.pill-list{display:flex;flex-wrap:wrap;gap:var(--space-3)}
.pill{border:1px solid var(--color-border-strong);border-radius:var(--radius-full);padding:.5rem 1rem;font-size:var(--text-sm);color:var(--color-text-muted)}
.pill .accent{color:var(--color-accent)}
.proof-points{list-style:none;display:grid;gap:var(--space-4);max-width:32rem;text-align:left}
.proof-points li{display:flex;gap:.75rem;align-items:flex-start;font-size:var(--text-base);line-height:1.4;color:var(--color-text)}
.proof-points .pp-mark{flex:none;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;
  border-radius:50%;background:rgba(230,59,79,.12);color:var(--color-accent);margin-top:.05rem}
.proof-points .pp-mark svg{width:14px;height:14px}
.proof-points strong{font-weight:700;color:var(--color-text)}
.proof-points .accent{color:var(--color-accent)}

/* ============ COMMITMENTS ============ */
.commit-class{margin-bottom:var(--space-12)}
.commit-class:last-child{margin-bottom:0}
.commit-class-head{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap;padding-bottom:var(--space-4);margin-bottom:var(--space-6);border-bottom:1px solid var(--color-border)}
.commit-class-head h3{font-family:var(--font-display);font-size:var(--text-xl);letter-spacing:.01em}
.commit-class-head .cnt{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:700}
.commit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}
@media(max-width:900px){.commit-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.commit-grid{grid-template-columns:1fr}}
.commit{position:relative;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-5);transition:border-color .25s var(--ease),transform .25s var(--ease)}
.commit:hover{border-color:var(--color-border-strong);transform:translateY(-2px)}
.commit .nm{display:block;font-family:var(--font-body);font-weight:800;font-size:var(--text-base);line-height:1.2}
.commit .sch{display:block;color:var(--color-text-muted);font-size:var(--text-sm);margin-top:.3rem}
.dvb{display:inline-block;margin-top:var(--space-3);font-size:var(--text-xs);font-weight:800;letter-spacing:.07em;border-radius:var(--radius-full);padding:.18rem .6rem;border:1px solid currentColor}
.dvb--di{color:#C22134}
.dvb--dii{color:#5fc27e}
.dvb--diii{color:#d8a23a}
.dvb--naia{color:#c98bdb}

/* ============ LOGO MARQUEE ============ */
.logo-marquee{padding-block:var(--space-10)}
.logo-marquee .label{text-align:center;margin-bottom:var(--space-8)}
.logo-marquee .label .eyebrow{margin-bottom:var(--space-3)}
.logo-marquee .label-sub{color:var(--color-text-muted);font-size:var(--text-base);line-height:1.45;max-width:46ch;margin-inline:auto}
.logo-marquee .label-sub .accent{color:var(--color-accent);font-weight:700}
.marquee{position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;width:max-content;gap:var(--space-4);animation:marquee-rtl 60s linear infinite;will-change:transform}
.marquee:hover .marquee-track{animation-play-state:paused}
.logo-tile{flex:none;display:flex;align-items:center;justify-content:center;width:76px;height:76px;padding:8px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .25s var(--ease),transform .25s var(--ease)}
.logo-tile img{width:100%;height:100%;object-fit:contain;border-radius:8px;display:block}
.logo-tile:hover{border-color:var(--color-accent);transform:translateY(-2px)}
@keyframes marquee-rtl{from{transform:translateX(-50%)}to{transform:translateX(0)}}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none;flex-wrap:wrap;justify-content:center;width:auto}}

/* ============ FIT / WHO STYLE IS FOR ============ */
.fit-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}
@media(max-width:760px){.fit-grid{grid-template-columns:1fr}}
.fit-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:clamp(var(--space-6),3vw,var(--space-8))}
.fit-card h3{font-size:var(--text-lg);margin-bottom:var(--space-5);font-family:var(--font-body);font-weight:800;letter-spacing:0}
.fit-card--alt{background:var(--color-bg-2)}
.fit-list{list-style:none;display:grid;gap:var(--space-4)}
.fit-list li{display:flex;gap:var(--space-3);align-items:flex-start;color:var(--color-text);font-size:var(--text-base);line-height:1.5}
.fit-list li svg,.fit-list li .ic{flex:none;width:22px;height:22px;color:var(--color-accent);margin-top:.15rem}
.fit-list--alt li{color:var(--color-text-muted)}
.fit-list--alt li svg,.fit-list--alt li .ic{color:var(--color-text-faint)}

/* ============ SIX-STEP PROCESS ============ */
.steps--six{grid-template-columns:repeat(3,1fr)}
@media(max-width:980px){.steps--six{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.steps--six{grid-template-columns:1fr}}

/* ============ COMPARE TABLE ============ */
table.styled.compare th:first-child,table.styled.compare td:first-child{font-weight:800;color:var(--color-text);white-space:nowrap;background:var(--color-bg-2)}
table.styled.compare thead th{font-size:var(--text-sm);color:var(--color-accent);text-transform:none;letter-spacing:.01em;font-weight:800}
table.styled.compare td{vertical-align:top;color:var(--color-text-muted)}
table.styled.compare tbody tr:hover{background:transparent}

/* ============ YEAR-ROUND RHYTHM ============ */
.rhythm{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}
@media(max-width:860px){.rhythm{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.rhythm{grid-template-columns:1fr}}
.rhythm-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);border-top:2px solid var(--color-accent)}
.rhythm-card .szn{display:block;font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-accent);margin-bottom:var(--space-3)}
.rhythm-card p{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.55}

/* ============ STRUCTURED COACH META ============ */
.coach-meta{margin-top:var(--space-4);display:grid;gap:var(--space-3)}
.cm{display:grid;gap:.15rem}
.cm-k{font-size:var(--text-xs);font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-faint)}
.cm-v{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.45}

/* ============ NEXT-STEP NOTE ============ */
.nextstep{display:flex;gap:var(--space-3);align-items:flex-start;justify-content:center;max-width:74ch;font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.55;text-align:left}
.nextstep svg,.nextstep .ic{flex:none;width:22px;height:22px;color:var(--color-accent);margin-top:.1rem}

/* ============ FEATURED COMMITS + JUMP LINKS ============ */
.featured-commits{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5);margin-bottom:var(--space-10)}
@media(max-width:680px){.featured-commits{grid-template-columns:1fr}}
.fcommit{position:relative;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;background:var(--color-surface);display:flex;flex-direction:column}
.fcommit .fc-img{aspect-ratio:4/3;width:100%;object-fit:cover;object-position:top center;display:block}
.fcommit .fc-body{padding:var(--space-5)}
.fcommit .fc-nm{display:block;font-family:var(--font-display);font-size:var(--text-xl);line-height:1.1}
.fcommit .fc-sch{display:block;color:var(--color-accent);font-weight:800;font-size:var(--text-sm);margin-top:.35rem}
.fcommit .fc-meta{display:block;color:var(--color-text-muted);font-size:var(--text-sm);margin-top:.2rem}
.jump-links{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center;margin-bottom:var(--space-10)}
.jump-link{border:1px solid var(--color-border-strong);border-radius:var(--radius-full);padding:.45rem 1.1rem;font-size:var(--text-sm);font-weight:700;color:var(--color-text-muted);transition:border-color .25s var(--ease),color .25s var(--ease)}
.jump-link:hover{border-color:var(--color-accent);color:var(--color-accent)}
.commit-class{scroll-margin-top:90px}

/* ============================================================
   HOME PAGE — Prominent tryout schedule (sits under hero)
   ============================================================ */
.section--tts{background:var(--color-bg)}
.tts-head{display:grid;grid-template-columns:1.4fr auto;gap:var(--space-8);align-items:end;margin-bottom:var(--space-10);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border)}
.tts-head-left{max-width:680px}
.tts-head-right{display:flex;flex-direction:column;gap:.5rem;align-items:flex-end;white-space:nowrap}
@media(max-width:860px){.tts-head{grid-template-columns:1fr;align-items:start}.tts-head-right{align-items:flex-start}}
.tts-head--simple{display:block;border-bottom:none;padding-bottom:0;margin-bottom:var(--space-8);text-align:center}
.tts-head--simple .h-section{margin:0}
.tts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5)}
@media(max-width:1100px){.tts-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.tts-grid{grid-template-columns:1fr}}
.tts-card{position:relative;display:flex;flex-direction:column;gap:var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);transition:border-color .25s var(--ease),transform .25s var(--ease),box-shadow .25s var(--ease)}
.tts-card:hover{border-color:var(--color-accent);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.tts-date{display:flex;flex-direction:column;gap:.1rem;padding-bottom:var(--space-3);border-bottom:1px dashed var(--color-border)}
.tts-date-d{font-family:var(--font-display);font-size:var(--text-lg);letter-spacing:.01em;color:var(--color-text);line-height:1.1}
.tts-date-day{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--color-accent)}
.tts-body{display:flex;flex-direction:column;gap:.55rem;flex:1}
.tts-meta{display:flex;flex-direction:column;gap:.35rem;font-size:var(--text-sm);color:var(--color-text-muted)}
.tts-meta svg{width:14px;height:14px;flex-shrink:0;color:var(--color-accent)}
.tts-time,.tts-loc{display:inline-flex;align-items:center;gap:.4rem}
.tts-grads{display:flex;flex-direction:column;gap:.15rem;margin-top:.15rem;padding-top:.55rem;border-top:1px solid var(--color-border)}
.tts-grads-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-faint);font-weight:700}
.tts-grads-val{font-family:var(--font-display);font-size:1.05rem;color:var(--color-text);letter-spacing:.02em}
.tts-note{display:inline-block;align-self:flex-start;font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-accent);background:rgba(230,59,79,.10);border:1px solid rgba(230,59,79,.35);border-radius:var(--radius-full);padding:.18rem .6rem}
.tts-cta{margin-top:auto;justify-content:center}

/* ============================================================
   COMMITMENTS PAGE
   ============================================================ */
.commit-overview{display:flex;flex-direction:column;gap:var(--space-7);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8) var(--space-10)}
@media(max-width:780px){.commit-overview{padding:var(--space-7) var(--space-5);gap:var(--space-6)}}
.co-head{display:flex;justify-content:flex-start}
@media(max-width:780px){.co-head{justify-content:center}}
.co-total{display:flex;align-items:center;gap:var(--space-5)}
@media(max-width:780px){.co-total{flex-direction:column;text-align:center;gap:var(--space-3)}}
.co-num{font-family:var(--font-display);font-size:clamp(4rem,3rem + 4vw,6rem);line-height:.9;color:var(--color-accent)}
.co-label{display:flex;flex-direction:column;gap:.25rem;line-height:1.3}
.co-label b{font-family:var(--font-display);font-size:var(--text-xl);font-weight:400;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text)}
.co-label span{font-size:var(--text-sm);color:var(--color-text-muted);letter-spacing:.04em;text-transform:uppercase;font-weight:600}
.co-divs{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3);padding-top:var(--space-6);border-top:1px solid var(--color-border)}
@media(max-width:680px){.co-divs{grid-template-columns:repeat(2,1fr)}}
.dv-stat{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;padding:var(--space-4) var(--space-5);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);background:var(--color-surface-2);transition:border-color .25s var(--ease),transform .25s var(--ease)}
.dv-stat:hover{border-color:currentColor;transform:translateY(-2px)}
.dv-stat-num{font-family:var(--font-display);font-size:clamp(1.75rem,1.2rem + 1.5vw,2.4rem);line-height:1;font-weight:400;letter-spacing:.02em}
.dv-stat-label{font-size:var(--text-sm);font-weight:700;letter-spacing:.05em;color:var(--color-text);text-transform:uppercase}
.co-classes{display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap;padding-top:var(--space-6);border-top:1px solid var(--color-border)}
@media(max-width:780px){.co-classes{flex-direction:column;align-items:center;text-align:center}}
.co-classes-label{font-size:var(--text-xs);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);flex-shrink:0}
.co-classes .jump-links{margin:0;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-start}
@media(max-width:780px){.co-classes .jump-links{justify-content:center}}
.jl-yr{font-weight:700}
.jl-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;height:1.4rem;padding:0 .4rem;margin-left:.5rem;font-size:.7rem;color:var(--color-text);background:var(--color-bg);border-radius:var(--radius-full);font-weight:700;letter-spacing:0}
.jump-link:hover .jl-count{background:var(--color-accent);color:#fff}
.jump-link{scroll-margin-top:80px;display:inline-flex;align-items:center}

/* Class sections */
.commit-class{scroll-margin-top:80px;padding-block:var(--space-16)}
.class-head{display:flex;justify-content:space-between;align-items:flex-end;gap:var(--space-8);margin-bottom:var(--space-10);padding-bottom:var(--space-5);border-bottom:1px solid var(--color-border)}
@media(max-width:780px){.class-head{flex-direction:column;align-items:flex-start}}
.class-head-left .eyebrow{display:block;color:var(--color-text-muted);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.18em;margin-bottom:.4rem}
.class-head-left .eyebrow::before{content:"";display:inline-block;width:24px;height:1.2px;background:var(--color-accent);margin-right:.5rem;vertical-align:middle}
.class-year{font-family:var(--font-display);font-size:clamp(3rem,2rem + 4vw,5.5rem);line-height:.9;color:var(--color-text)}
.class-head-left .muted{margin-top:.2rem;font-size:var(--text-sm)}
.class-head-right{display:flex;flex-wrap:wrap;gap:.55rem;justify-content:flex-end}
@media(max-width:780px){.class-head-right{justify-content:flex-start}}

/* Division sub-section header inside class */
.class-division{margin-bottom:var(--space-12)}
.class-division:last-child{margin-bottom:0}
.cd-head{display:flex;align-items:center;gap:.8rem;margin-bottom:var(--space-5);padding-bottom:.6rem;border-bottom:1px dashed var(--color-border)}
.cd-mark{font-family:var(--font-display);font-size:1.5rem;letter-spacing:.02em;padding:.1rem .6rem;border:1.5px solid currentColor;border-radius:var(--radius-sm);line-height:1}
.cd-title{font-size:var(--text-lg);font-weight:700;text-transform:none;letter-spacing:0;color:var(--color-text);margin:0;flex:1}
.cd-count{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:600}

/* Commit grid: responsive cards */
.commit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}
@media(max-width:1100px){.commit-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.commit-grid{grid-template-columns:1fr}}

.commit-card{position:relative;display:flex;align-items:center;gap:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:.85rem 1rem;transition:border-color .25s var(--ease),transform .25s var(--ease),box-shadow .25s var(--ease)}
.commit-card:hover{border-color:var(--color-accent);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.cc-logo{position:relative;width:48px;height:48px;flex-shrink:0;background:#fff;border-radius:var(--radius-md);padding:4px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.cc-logo img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.cc-logo-fallback{display:none;position:absolute;inset:0;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.6rem;color:#333;background:linear-gradient(135deg,#e6e8eb,#bcc1c7)}
.cc-info{display:flex;flex-direction:column;gap:.1rem;min-width:0;flex:1}
.cc-name{font-weight:700;font-size:var(--text-base);color:var(--color-text);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cc-school{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.25}
.cc-div{font-family:var(--font-display);font-size:.85rem;letter-spacing:.05em;border:1.5px solid currentColor;border-radius:var(--radius-sm);padding:.1rem .45rem;line-height:1.2;flex-shrink:0;align-self:flex-start;margin-top:.15rem}

/* ============ Tryout sessions card grid (evaluations page) ============ */
.tc-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:1rem;
  max-width:1100px;
  margin-inline:auto;
}
.tc-card{
  background:var(--color-bg-2);
  border:1px solid var(--color-border);
  border-radius:14px;
  padding:1.25rem 1.25rem 1.1rem;
  display:flex;
  flex-direction:column;
  gap:.85rem;
  transition:border-color .2s ease, transform .2s ease;
}
.tc-card:hover{ border-color:var(--color-accent,#C22134); transform:translateY(-2px); }
.tc-card__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.5rem;
  padding-bottom:.65rem;
  border-bottom:1px solid var(--color-border);
}
.tc-year{
  font-family:var(--font-display,inherit);
  font-weight:800;
  font-size:1.65rem;
  line-height:1;
  letter-spacing:.02em;
}
.tc-note{
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--color-accent,#C22134);
  background:rgba(194,33,52,.12);
  padding:.3rem .55rem;
  border-radius:999px;
  font-weight:700;
  white-space:nowrap;
}
.tc-sessions{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:.5rem;
  flex:1;
}
.tc-sessions li{
  font-size:.92rem;
  line-height:1.45;
  color:var(--color-text,inherit);
  padding-left:.85rem;
  position:relative;
}
.tc-sessions li::before{
  content:"";
  position:absolute;
  left:0; top:.55rem;
  width:4px; height:4px;
  border-radius:50%;
  background:var(--color-accent,#C22134);
}
.tc-card__cta{
  align-self:flex-start;
  margin-top:.2rem;
}
@media (max-width:540px){
  .tc-grid{ grid-template-columns:1fr; }
}

/* ============ Pricing tiers ============ */
.tier-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1rem;
  max-width:1100px;
  margin-inline:auto;
}
.tier-card{
  background:var(--color-bg);
  border:1px solid var(--color-border);
  border-radius:14px;
  padding:1.5rem 1.4rem;
  display:flex;
  flex-direction:column;
  gap:.6rem;
  transition:border-color .2s ease, transform .2s ease;
}
.tier-card:hover{ border-color:var(--color-accent,#C22134); transform:translateY(-2px); }
.tier-eyebrow{
  font-size:.7rem;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--color-accent,#C22134);
  font-weight:700;
}
.tier-name{
  font-family:var(--font-display,inherit);
  font-size:2rem;
  font-weight:400;
  letter-spacing:.02em;
  margin:0;
  line-height:1;
}
.tier-price{ display:flex; align-items:baseline; gap:.4rem; margin-top:.25rem; }
.tier-amount{
  font-family:var(--font-display,inherit);
  font-size:2.4rem;
  font-weight:400;
  line-height:1;
  color:var(--color-text,inherit);
}
.tier-unit{ font-size:.95rem; color:var(--color-muted,#9ca3af); font-weight:500; }
.tier-sub{ font-size:.85rem; margin:0; }

/* ============ Payment plan cards ============ */
.pay-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1rem;
  max-width:1100px;
  margin-inline:auto;
  align-items:stretch;
}
.pay-card{
  background:var(--color-bg);
  border:1px solid var(--color-border);
  border-radius:14px;
  padding:1.4rem 1.3rem 1.5rem;
  display:flex;
  flex-direction:column;
  gap:.7rem;
  position:relative;
  transition:border-color .2s ease, transform .2s ease;
}
.pay-card:hover{ transform:translateY(-2px); }
.pay-card--featured{
  border-color:var(--color-accent,#C22134);
  background:linear-gradient(180deg,rgba(194,33,52,.08),var(--color-bg) 70%);
}
.pay-tag{
  align-self:flex-start;
  font-size:.65rem;
  text-transform:uppercase;
  letter-spacing:.1em;
  font-weight:700;
  color:var(--color-muted,#9ca3af);
  background:rgba(255,255,255,.04);
  padding:.3rem .55rem;
  border-radius:999px;
  border:1px solid var(--color-border);
}
.pay-tag--primary{
  color:#fff;
  background:var(--color-accent,#C22134);
  border-color:var(--color-accent,#C22134);
}
.pay-name{
  font-family:var(--font-display,inherit);
  font-size:1.4rem;
  font-weight:400;
  letter-spacing:.02em;
  margin:0;
  line-height:1.1;
}
.pay-amount{
  font-family:var(--font-display,inherit);
  font-size:1.9rem;
  font-weight:400;
  line-height:1.15;
  color:var(--color-text,inherit);
}
.pay-amount-sub{
  display:inline-block;
  font-size:.9rem;
  font-weight:500;
  color:var(--color-muted,#9ca3af);
  font-family:inherit;
  margin-top:.15rem;
}
.pay-detail{
  font-size:.92rem;
  line-height:1.5;
  color:var(--color-muted,#9ca3af);
  margin:0;
}
.pay-list{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:.4rem;
  flex:1;
}
.pay-list li{
  font-size:.88rem;
  padding-left:1.1rem;
  position:relative;
  line-height:1.45;
}
.pay-list li::before{
  content:"✓";
  position:absolute;
  left:0;
  color:var(--color-accent,#C22134);
  font-weight:700;
}

/* ============ Breakdown bars ============ */
.breakdown{
  max-width:820px;
  margin-inline:auto;
  display:flex;
  flex-direction:column;
  gap:.65rem;
}
.bd-row{
  display:grid;
  grid-template-columns:minmax(180px,260px) 1fr 50px;
  align-items:center;
  gap:1rem;
  padding:.65rem .85rem;
  background:var(--color-bg);
  border:1px solid var(--color-border);
  border-radius:10px;
}
.bd-label{ display:flex; flex-direction:column; gap:.15rem; }
.bd-label b{ font-size:.95rem; }
.bd-label span{ font-size:.78rem; color:var(--color-muted,#9ca3af); }
.bd-bar{
  position:relative;
  height:10px;
  background:rgba(255,255,255,.05);
  border-radius:999px;
  overflow:hidden;
}
.bd-fill{
  display:block;
  height:100%;
  background:linear-gradient(90deg,var(--color-accent,#C22134),#e85a6c);
  border-radius:999px;
}
.bd-pct{
  font-family:var(--font-display,inherit);
  font-weight:800;
  font-size:1.05rem;
  text-align:right;
  color:var(--color-text,inherit);
}
@media (max-width:640px){
  .bd-row{ grid-template-columns:1fr; gap:.4rem; }
  .bd-pct{ text-align:left; }
}

/* ============ Tuition policy card ============ */
.policy-card{
  max-width:880px;
  margin-inline:auto;
  background:var(--color-bg);
  border:1px solid var(--color-border);
  border-left:4px solid var(--color-accent,#C22134);
  border-radius:12px;
  padding:1.5rem 1.6rem 1.4rem;
}
.policy-eyebrow{
  display:inline-block;
  font-size:.7rem;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--color-accent,#C22134);
  font-weight:700;
  margin-bottom:.4rem;
}
.policy-head{
  font-family:var(--font-display,inherit);
  font-size:1.75rem;
  font-weight:400;
  margin:0 0 .75rem;
  line-height:1.05;
  letter-spacing:.025em;
  text-transform:uppercase;
}
.policy-card p{
  font-size:.95rem;
  line-height:1.55;
  color:var(--color-text,inherit);
  margin:0 0 .8rem;
}
.policy-list{
  list-style:none;
  padding:0;
  margin:.5rem 0 .9rem;
  display:flex;
  flex-direction:column;
  gap:.55rem;
}
.policy-list li{
  position:relative;
  padding-left:1.4rem;
  font-size:.92rem;
  line-height:1.5;
}
.policy-list li::before{
  content:"";
  position:absolute;
  left:0; top:.55rem;
  width:6px; height:6px;
  border-radius:50%;
  background:var(--color-accent,#C22134);
}
.policy-foot{
  font-size:.82rem;
  color:var(--color-muted,#9ca3af);
  margin-top:.6rem;
  padding-top:.85rem;
  border-top:1px solid var(--color-border);
}

/* ============ Injury credit callout ============ */
.injury-card{
  max-width:880px;
  margin-inline:auto;
  background:linear-gradient(135deg, rgba(194,33,52,.08), rgba(194,33,52,.03));
  border:1px solid var(--color-accent,#C22134);
  border-radius:14px;
  padding:1.4rem 1.6rem;
  text-align:center;
}
.injury-eyebrow{
  display:inline-block;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--color-accent,#C22134);
  font-weight:800;
  margin-bottom:.45rem;
}
.injury-head{
  font-family:var(--font-display,inherit);
  font-size:1.85rem;
  font-weight:400;
  margin:0 0 .6rem;
  line-height:1.05;
  letter-spacing:.025em;
  text-transform:uppercase;
}
.injury-card p{
  font-size:.98rem;
  line-height:1.55;
  margin:0;
  max-width:640px;
  margin-inline:auto;
}

/* ============ All-in budget card ============ */
.allin-card{
  max-width:880px;
  margin-inline:auto;
  background:var(--color-bg);
  border:1px solid var(--color-border);
  border-radius:14px;
  padding:1.5rem 1.6rem 1.3rem;
}
.allin-eyebrow{
  display:inline-block;
  font-size:.7rem;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--color-accent,#C22134);
  font-weight:700;
  margin-bottom:.35rem;
}
.allin-head{
  font-family:var(--font-display,inherit);
  font-size:1.45rem;
  font-weight:800;
  margin:0 0 1rem;
  line-height:1.2;
}
.allin-rows{
  display:flex;
  flex-direction:column;
  border-top:1px solid var(--color-border);
}
.allin-row{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:1rem;
  padding:.85rem 0;
  border-bottom:1px solid var(--color-border);
  font-size:.98rem;
}
.allin-row small{ color:var(--color-muted,#9ca3af); font-size:.82rem; }
.allin-row--total{
  background:rgba(194,33,52,.05);
  padding:1rem .9rem;
  border-radius:8px;
  border-bottom:none;
  font-size:1.1rem;
  margin-top:.4rem;
}
.allin-val{ font-variant-numeric:tabular-nums; white-space:nowrap; }
.allin-foot{
  font-size:.88rem;
  color:var(--color-text,inherit);
  line-height:1.55;
  margin:1rem 0 0;
  padding-top:.9rem;
  border-top:1px solid var(--color-border);
}

/* ============ Outcome closer (commits CTA) ============ */
.outcome-closer{
  max-width:780px;
  margin-inline:auto;
  text-align:center;
  background:var(--color-bg);
  border:1px solid var(--color-border);
  border-radius:14px;
  padding:2rem 1.6rem 1.8rem;
}
.outcome-eyebrow{
  display:inline-block;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--color-accent,#C22134);
  font-weight:800;
  margin-bottom:.5rem;
}
.outcome-head{
  font-family:var(--font-display,inherit);
  font-size:1.8rem;
  font-weight:800;
  margin:0 0 .7rem;
  line-height:1.2;
}
.outcome-body{
  font-size:1rem;
  line-height:1.55;
  margin:0 0 1.2rem;
  color:var(--color-text,inherit);
  max-width:560px;
  margin-inline:auto;
}
.outcome-cta{ display:inline-block; }

@media (max-width:640px){
  .allin-row{ flex-direction:column; align-items:flex-start; gap:.2rem; }
  .allin-row--total{ flex-direction:row; align-items:baseline; }
  .outcome-head{ font-size:1.45rem; }
}

/* ============ Interactive tier picker ============ */
.tier-card--btn{
  cursor:pointer;
  text-align:left;
  width:100%;
  font:inherit;
  color:inherit;
  appearance:none;
  position:relative;
}
.tier-card--btn:focus-visible{
  outline:2px solid var(--color-accent,#C22134);
  outline-offset:3px;
}
.tier-card--btn.is-active{
  border-color:var(--color-accent,#C22134);
  box-shadow:0 0 0 1px var(--color-accent,#C22134), 0 10px 28px -16px rgba(194,33,52,.45);
  background:linear-gradient(180deg, rgba(194,33,52,.05), transparent 70%);
}
.tier-card--btn.is-active .tier-cta-arrow{
  transform:translateY(2px);
  color:var(--color-accent,#C22134);
}
.tier-approx{
  font-family:var(--font-display,inherit);
  font-size:1.6rem;
  font-weight:800;
  line-height:1;
  color:var(--color-muted,#9ca3af);
  margin-right:-.15rem;
}
.tier-cta{
  margin-top:auto;
  padding-top:.9rem;
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.1em;
  font-weight:700;
  color:var(--color-muted,#9ca3af);
}
.tier-card--btn.is-active .tier-cta{ color:var(--color-accent,#C22134); }
.tier-cta-arrow{ display:inline-block; transition:transform .25s ease, color .25s ease; }

/* Plans panel */
.plans-panel{
  display:none;
  margin-top:1.5rem;
  padding-top:1.5rem;
  border-top:1px solid var(--color-border);
  animation:planFade .35s ease both;
}
.plans-panel.is-open{ display:block; }
@keyframes planFade{
  from{ opacity:0; transform:translateY(6px); }
  to  { opacity:1; transform:translateY(0); }
}
.plans-head{
  max-width:780px;
  margin:0 auto 1.25rem;
  text-align:center;
}
.plans-eyebrow{
  display:inline-block;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--color-accent,#C22134);
  font-weight:800;
  margin-bottom:.35rem;
}
.plans-title{
  font-family:var(--font-display,inherit);
  font-size:1.6rem;
  font-weight:400;
  margin:0;
  line-height:1.2;
}
.plans-panel .pay-name{ font-size:1.1rem; }

@media (max-width:760px){
  .plans-panel{ margin-top:1rem; padding-top:1rem; }
  .plans-title{ font-size:1.3rem; }
}

/* ============ Grad-year card (replaces tables) ============ */
.yr-card{
  max-width:880px;
  margin-inline:auto;
  background:var(--color-bg);
  border:1px solid var(--color-border);
  border-radius:14px;
  padding:1.4rem 1.4rem 1.2rem;
}
.yr-card-head{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:1rem;
  flex-wrap:wrap;
  margin-bottom:1rem;
  padding-bottom:.9rem;
  border-bottom:1px solid var(--color-border);
}
.yr-card-eyebrow{
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--color-accent,#C22134);
  font-weight:800;
}
.yr-card-meta{
  font-size:.82rem;
  color:var(--color-muted,#9ca3af);
}
.yr-chips{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  margin-bottom:1rem;
}
.yr-chip{
  display:inline-block;
  padding:.45rem .8rem;
  border:1px solid var(--color-border);
  border-radius:999px;
  background:var(--color-bg-2, rgba(255,255,255,.02));
  font-size:.82rem;
  font-weight:600;
  letter-spacing:.01em;
  color:var(--color-text,inherit);
  white-space:nowrap;
}
.yr-card-foot{
  display:flex;
  flex-direction:column;
  gap:.4rem;
  padding-top:.85rem;
  border-top:1px solid var(--color-border);
  font-size:.88rem;
  color:var(--color-text,inherit);
}
.yr-card-foot b{ color:var(--color-accent,#C22134); }

@media (max-width:520px){
  .yr-card{ padding:1.1rem 1rem; }
  .yr-card-head{ flex-direction:column; gap:.3rem; margin-bottom:.8rem; padding-bottom:.7rem; }
  .yr-chip{ font-size:.78rem; padding:.4rem .7rem; }
}

/* ============ Roster movement card ============ */
.roster-card{
  max-width:880px;
  margin-inline:auto;
  background:var(--color-bg);
  border:1px solid var(--color-border);
  border-left:4px solid var(--color-accent,#C22134);
  border-radius:12px;
  padding:1.5rem 1.6rem 1.4rem;
}
.roster-eyebrow{
  display:inline-block;
  font-size:.7rem;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--color-accent,#C22134);
  font-weight:700;
  margin-bottom:.4rem;
}
.roster-head{
  font-family:var(--font-display,inherit);
  font-size:1.75rem;
  font-weight:400;
  margin:0 0 .75rem;
  line-height:1.05;
  letter-spacing:.025em;
  text-transform:uppercase;
}
.roster-card p{
  font-size:.95rem;
  line-height:1.55;
  margin:0 0 .8rem;
}
.roster-list{
  list-style:none;
  padding:0;
  margin:.5rem 0 .9rem;
  display:flex;
  flex-direction:column;
  gap:.55rem;
}
.roster-list li{
  position:relative;
  padding-left:1.4rem;
  font-size:.92rem;
  line-height:1.5;
}
.roster-list li::before{
  content:"";
  position:absolute;
  left:0; top:.55rem;
  width:6px; height:6px;
  border-radius:50%;
  background:var(--color-accent,#C22134);
}
.roster-foot{
  font-size:.82rem;
  color:var(--color-muted,#9ca3af);
  margin-top:.6rem;
  padding-top:.85rem;
  border-top:1px solid var(--color-border);
}

/* ===== Tuition calculator (interactive plan picker) ===== */
.plans-sub { margin-top: 8px; max-width: 60ch; font-size: 0.95rem; }

/* Pay-card buttons (override default <button> styling) */
.pay-card--btn {
  width: 100%;
  text-align: left;
  cursor: pointer;
  font: inherit;
  color: inherit;
  /* preserve .pay-card flex layout */
  display: flex;
  flex-direction: column;
  gap: .7rem;
  transition: border-color .18s ease, box-shadow .18s ease, transform .12s ease;
}
.pay-card--btn .pay-list { padding-left: 0; list-style: none; margin: 0; }
.pay-card--btn .pay-detail { margin: 0; }
.pay-card--btn:hover {
  border-color: var(--color-accent, #C22134);
  transform: translateY(-1px);
}
.pay-card--btn:focus-visible {
  outline: 2px solid var(--color-accent, #C22134);
  outline-offset: 3px;
}
/* Featured card: when not the active selection, keep gradient bg but neutralize the ring */
.pay-card--btn.pay-card--featured:not(.is-selected) {
  border-color: var(--color-border);
}
.pay-card--btn.is-selected {
  border-color: var(--color-accent, #C22134);
  box-shadow: 0 0 0 2px var(--color-accent, #C22134) inset,
              0 8px 24px -10px rgba(194, 33, 52, 0.45);
}
.pay-name-sub {
  font-weight: 400;
  font-size: 0.85em;
  color: var(--color-muted, #9ca3af);
  margin-left: 4px;
}

/* Result panel */
.calc-result {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-accent, #C22134);
  border-radius: 10px;
  padding: 24px 28px;
}
.calc-result-head { margin-bottom: 16px; }
.calc-result-eyebrow {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-accent, #C22134);
  margin-bottom: 6px;
}
.calc-result-title {
  font-size: 1.35rem;
  margin: 0;
  font-weight: 700;
}
.calc-result-body { margin-bottom: 12px; }
.calc-result-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 10px 0;
  border-bottom: 1px solid var(--color-border);
  gap: 16px;
}
.calc-result-row:last-child { border-bottom: 0; }
.calc-result-row--total {
  margin-top: 6px;
  padding-top: 14px;
  border-top: 2px solid var(--color-border);
  border-bottom: 0;
  font-weight: 700;
  font-size: 1.05rem;
}
.calc-result-label {
  color: var(--color-muted, #9ca3af);
  font-size: 0.95rem;
}
.calc-result-row--total .calc-result-label {
  color: inherit;
}
.calc-result-value {
  font-size: 1.15rem;
  font-weight: 600;
  text-align: right;
  white-space: nowrap;
}
.calc-result-row--total .calc-result-value {
  font-size: 1.35rem;
}
.calc-result-unit {
  font-size: 0.85rem;
  font-weight: 400;
  color: var(--color-muted, #9ca3af);
}
.calc-result-foot {
  font-size: 0.85rem;
  margin-top: 12px;
}

@media (max-width: 640px) {
  .calc-result { padding: 18px 20px; }
  .calc-result-title { font-size: 1.15rem; }
  .calc-result-row { gap: 10px; }
  .calc-result-value { font-size: 1.05rem; }
  .calc-result-row--total .calc-result-value { font-size: 1.2rem; }
}

/* ============ TOURNAMENTS PAGE ============ */
.tourn-overview{ margin-bottom: var(--space-6); }
.tourn-group-head{
  max-width: 760px;
  margin: 0 auto var(--space-8);
  text-align: center;
}
.tourn-group-desc{
  font-size: 0.98rem;
  margin-top: 0.5rem;
}
.team-tourn-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  max-width: 1200px;
  margin-inline: auto;
}
.team-tourn-grid--2col{ grid-template-columns: repeat(2, 1fr); max-width: 980px; }
.team-tourn-card--wide{ grid-column: 1 / -1; }
@media (max-width: 980px){
  .team-tourn-grid{ grid-template-columns: repeat(2, 1fr); }
  .team-tourn-grid--2col{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px){
  .team-tourn-card--wide{ grid-column: auto; }
}
.team-tourn-card{
  background: var(--color-bg-2, #0e1012);
  border: 1px solid var(--color-border, #1f2226);
  border-radius: var(--radius-lg, 16px);
  padding: 1.4rem 1.4rem 1.2rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: border-color .25s ease, transform .25s ease;
}
.team-tourn-card:hover{
  border-color: var(--color-accent, #C22134);
  transform: translateY(-2px);
}
.team-tourn-head{
  display: flex;
  flex-direction: column;
  gap: .25rem;
  padding-bottom: .9rem;
  border-bottom: 1px solid var(--color-border, #1f2226);
}
.team-tourn-band{
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--color-accent, #C22134);
}
.team-tourn-name{
  font-family: var(--font-display, inherit);
  font-size: 1.7rem;
  font-weight: 400;
  letter-spacing: .02em;
  margin: 0;
  line-height: 1;
  text-transform: uppercase;
}
.tourn-list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: .85rem;
}
.tourn-row{
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: .9rem;
  align-items: start;
}
.tourn-row--inline{
  grid-template-columns: 110px 1fr auto;
  align-items: center;
  gap: 1rem;
  padding: .35rem 0;
}
.tourn-info--inline{
  flex-direction: row;
  flex-wrap: wrap;
  align-items: baseline;
  gap: .15rem .5rem;
}
.tourn-info--inline .tourn-name{
  display: inline;
}
.tourn-info--inline .tourn-role{
  font-size: .85rem;
  font-style: italic;
}
.tourn-links--inline{
  margin-top: 0;
  flex-shrink: 0;
}
@media (max-width: 640px){
  .tourn-row--inline{
    grid-template-columns: 90px 1fr;
    gap: .7rem .9rem;
    align-items: start;
  }
  .tourn-links--inline{
    grid-column: 2 / 3;
    margin-top: .35rem;
  }
}
.tourn-date{
  display: flex;
  flex-direction: column;
  gap: .15rem;
  padding-top: .15rem;
}
.tourn-weekend{
  font-family: var(--font-display, inherit);
  font-size: 1.05rem;
  font-weight: 400;
  letter-spacing: .03em;
  color: var(--color-text, #fff);
  text-transform: uppercase;
  line-height: 1.1;
}
.tourn-loc{
  font-size: .75rem;
  color: var(--color-text-muted, #9ca3af);
  letter-spacing: .04em;
  text-transform: uppercase;
}
.tourn-info{
  display: flex;
  flex-direction: column;
  gap: .35rem;
}
.tourn-name{
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text, #fff);
  text-decoration: none;
  line-height: 1.25;
  transition: color .2s ease;
}
.tourn-name:hover{
  color: var(--color-accent, #C22134);
}
.tourn-ext{
  font-size: .8em;
  opacity: .7;
  margin-left: .15rem;
}
.tourn-role{
  font-size: .82rem;
  color: var(--color-text-muted, #9ca3af);
  font-style: italic;
}
.tourn-links{
  margin-top: .25rem;
}
.tourn-hotel{
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-size: .8rem;
  font-weight: 600;
  color: var(--color-text-muted, #9ca3af);
  text-decoration: none;
  padding: .3rem .65rem;
  border: 1px solid var(--color-border, #1f2226);
  border-radius: var(--radius-full, 999px);
  transition: color .2s ease, border-color .2s ease;
}
.tourn-hotel:hover{
  color: var(--color-accent, #C22134);
  border-color: var(--color-accent, #C22134);
}
.tourn-hotel svg{
  width: .9rem;
  height: .9rem;
  flex-shrink: 0;
}
.tourn-hotel--none{
  color: var(--color-text-faint, #6b7280);
  border-style: dashed;
  cursor: default;
}
.tourn-hotel--none:hover{
  color: var(--color-text-faint, #6b7280);
  border-color: var(--color-border, #1f2226);
}
@media (max-width: 480px){
  .team-tourn-grid{
    grid-template-columns: 1fr;
  }
  .tourn-row{
    grid-template-columns: 80px 1fr;
    gap: .7rem;
  }
  .team-tourn-name{
    font-size: 1.5rem;
  }
}

/* ===== Consolidated page sub-nav (Program / About / Recruiting) ===== */
.subnav{
  position: sticky;
  top: 0;
  z-index: 40;
  background: color-mix(in srgb, var(--color-bg) 92%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--color-border);
}
.subnav-wrap{
  display: flex;
  gap: 1.5rem;
  padding: .9rem 0;
  overflow-x: auto;
  scrollbar-width: none;
}
.subnav-wrap::-webkit-scrollbar{ display: none; }
.subnav-link{
  flex: 0 0 auto;
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  text-decoration: none;
  padding: .35rem .85rem;
  border-radius: 999px;
  border: 1px solid var(--color-border);
  background: color-mix(in srgb, var(--color-surface) 60%, transparent);
  transition: color .15s ease, background .15s ease, border-color .15s ease;
}
.subnav-link:hover{
  color: var(--color-text);
  background: color-mix(in srgb, var(--color-accent) 12%, var(--color-surface));
  border-color: color-mix(in srgb, var(--color-accent) 35%, var(--color-border));
}
.program-section{
  scroll-margin-top: 96px; /* offset for sticky header + subnav */
}
.program-section + .program-section{
  border-top: 1px solid var(--color-border);
}

/* ===== Tournaments page top-level sections (High School / Youth) ===== */
.tourn-pagesection{
  position: relative;
}
.tourn-pagesection + .tourn-pagesection{
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-16, 4rem);
}
.tourn-pagesection-head{
  text-align: center;
  margin-bottom: var(--space-12, 3rem);
}
.tourn-pagesection-title{
  margin-bottom: .5rem;
}
.tourn-pagesection .tourn-group-head{
  margin-top: var(--space-10, 2.5rem);
}
.tourn-pagesection .tourn-group-head:first-of-type{
  margin-top: 0;
}

/* ============================================================
   College commits marquee (homepage) — auto-scrolling logos
   ============================================================ */
.college-marquee{
  background: var(--color-bg-2);
  border-block: 1px solid var(--color-border);
  padding-block: var(--space-16, 4rem);
  overflow: hidden;
}
.college-marquee .center{ margin-bottom: var(--space-10, 2.5rem); }
.college-marquee-strip{
  position: relative;
  width: 100%;
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
}
.college-marquee-track{
  display: flex;
  align-items: center;
  gap: 1.25rem;
  width: max-content;
  animation: cm-scroll 60s linear infinite;
}
.college-marquee:hover .college-marquee-track{ animation-play-state: paused; }
.college-logo-tile{
  flex: 0 0 auto;
  width: 84px; height: 84px;
  background: #15171c;
  border: 1px solid var(--color-border);
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  padding: 12px;
  transition: transform .25s ease, border-color .25s ease;
}
.college-logo-tile:hover{ transform: translateY(-3px); border-color: var(--color-accent); }
.college-logo-tile img{
  max-width: 100%; max-height: 100%;
  object-fit: contain;
  display: block;
}
@keyframes cm-scroll{
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@media (max-width: 720px){
  .college-logo-tile{ width: 64px; height: 64px; padding: 9px; border-radius: 12px; }
  .college-marquee-track{ gap: .9rem; animation-duration: 45s; }
}
@media (prefers-reduced-motion: reduce){
  .college-marquee-track{ animation: none; }
  .college-marquee-strip{ overflow-x: auto; }
}

/* ---- Grad-year picker (per-grad-year tuition cards) -------------------- */
.gradyear-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
  max-width:1200px;
  margin-inline:auto;
}
@media (max-width:1100px){ .gradyear-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:820px){  .gradyear-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px){  .gradyear-grid{ grid-template-columns:1fr; } }

.gradyear-card{
  appearance:none;
  -webkit-appearance:none;
  text-align:left;
  cursor:pointer;
  background:var(--color-bg);
  border:1px solid var(--color-border);
  border-radius:14px;
  padding:1.1rem 1.1rem 1rem;
  color:inherit;
  font:inherit;
  display:flex;
  flex-direction:column;
  gap:.55rem;
  transition:border-color .18s ease, transform .18s ease, box-shadow .18s ease;
  position:relative;
}
.gradyear-card:hover{
  border-color:var(--color-accent,#C22134);
  transform:translateY(-2px);
}
.gradyear-card:focus-visible{
  outline:2px solid var(--color-accent,#C22134);
  outline-offset:3px;
}
.gradyear-card.is-active{
  border-color:var(--color-accent,#C22134);
  box-shadow:0 0 0 2px color-mix(in srgb, var(--color-accent,#C22134) 28%, transparent);
  background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent,#C22134) 6%, transparent), transparent);
}

.gy-eyebrow{
  font-size:.66rem;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--color-accent,#C22134);
  font-weight:700;
}
.gy-name{
  font-family:var(--font-display,inherit);
  font-size:1.15rem;
  margin:0;
  letter-spacing:.02em;
}
.gy-variant-row{
  display:inline-flex;
  gap:.3rem;
  padding:.2rem;
  background:color-mix(in srgb, var(--color-text,#fff) 6%, transparent);
  border-radius:999px;
  align-self:flex-start;
}
.gy-variant{
  font:inherit;
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  border:none;
  background:transparent;
  color:var(--color-text-muted,#a1a3a6);
  padding:.32rem .65rem;
  border-radius:999px;
  cursor:pointer;
  transition:background .15s ease, color .15s ease;
  display:inline-block;
}
.gy-variant:hover{ color:var(--color-text,#fff); }
.gy-variant.is-on{
  background:var(--color-accent,#C22134);
  color:#fff;
}
.gy-price{
  display:flex;
  align-items:baseline;
  gap:.15rem;
  flex-wrap:wrap;
}
.gy-approx{
  font-size:.95rem;
  color:var(--color-text-muted,#a1a3a6);
  margin-right:.1rem;
}
.gy-amount{
  font-family:var(--font-display,inherit);
  font-size:1.7rem;
  font-weight:700;
  letter-spacing:.01em;
  color:var(--color-text,#fff);
}
.gy-unit{
  font-size:.78rem;
  color:var(--color-text-muted,#a1a3a6);
  letter-spacing:.02em;
}
.gy-sub{
  font-size:.75rem;
  margin:0;
  line-height:1.35;
}
