/* ── TOKENS ────────────────────────────── */
:root {
  --bg:        #ffffff;
  --bg-subtle: #f4f8f5;
  --bg-blue:   #eef3fb;
  --surface:   #ffffff;
  --border:    rgba(0,0,0,0.08);
  --border2:   rgba(0,0,0,0.14);

  --green:     #0f7b40;
  --green-d:   #095c2f;
  --green-l:   #e6f4ec;
  --blue:      #1a3e8c;
  --blue-l:    #e8eef9;

  --text:      #0a1628;
  --text-2:    #2d3f35;
  --muted:     #748a7a;

  --open:      #16a34a;
  --soon:      #d97706;

  --font:      'Plus Jakarta Sans', sans-serif;
  --ease:      cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-out:  cubic-bezier(0.16, 1, 0.3, 1);
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.06);
  --shadow-md: 0 8px 32px rgba(0,0,0,0.09);
  --shadow-lg: 0 20px 56px rgba(0,0,0,0.11);
}

/* ── RESET ─────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  line-height: 1.65;
  overflow-x: hidden;
  cursor: none;
  -webkit-font-smoothing: antialiased;
}
/* body.is-loading — intro canvas is position:fixed, no overflow lock needed */
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
button { border: none; background: none; cursor: pointer; font-family: inherit; }
input, textarea, select { font-family: inherit; }

/* ── CURSOR ────────────────────────────── */
#cursor {
  position: fixed;
  width: 8px; height: 8px;
  background: var(--green);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%,-50%);
  transition: width 0.2s, height 0.2s;
}
#cursorRing {
  position: fixed;
  width: 32px; height: 32px;
  border: 1.5px solid rgba(15,123,64,0.35);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9998;
  transform: translate(-50%,-50%);
  transition: left 0.1s var(--ease), top 0.1s var(--ease), width 0.25s, height 0.25s, border-color 0.25s;
}
body:has(a:hover) #cursorRing,
body:has(button:hover) #cursorRing {
  width: 48px; height: 48px;
  border-color: var(--green);
}

/* ── INTRO ─────────────────────────────── */
#intro {
  position: fixed; inset: 0;
  z-index: 8000;
  pointer-events: none;
}
#introCanvas { position: absolute; inset: 0; width: 100%; height: 100%; }
.intro-half {
  position: absolute; left: 0; right: 0; height: 50%;
  background: #0a1628;
  will-change: transform;
}
.intro-half--top { top: 0; }
.intro-half--bot { bottom: 0; }
#intro.splitting .intro-half--top { transition: transform 0.75s var(--ease-out); transform: translateY(-100%); }
#intro.splitting .intro-half--bot { transition: transform 0.75s var(--ease-out); transform: translateY(100%); }
#intro.done { display: none; }

/* ── NAV ───────────────────────────────── */
#nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 900;
}
.nav-wrap {
  display: flex; align-items: center;
  padding: 22px 48px;
  transition: background 0.35s, backdrop-filter 0.35s, padding 0.35s, box-shadow 0.35s;
}
#nav.scrolled .nav-wrap {
  padding: 14px 48px;
  background: rgba(255,255,255,0.94);
  backdrop-filter: blur(20px) saturate(160%);
  box-shadow: 0 1px 0 var(--border), 0 4px 20px rgba(0,0,0,0.05);
}
.nav-logo { display: flex; flex-direction: column; line-height: 1; gap: 2px; }
.logo-primary {
  font-size: 22px; font-weight: 800; letter-spacing: 3px;
  color: var(--green);
}
.logo-secondary {
  font-size: 9px; font-weight: 500; letter-spacing: 2.5px;
  text-transform: uppercase; color: var(--muted);
}
.nav-links {
  display: flex; align-items: center; gap: 36px;
  margin-left: auto;
}
.nav-links a {
  font-size: 12px; font-weight: 500; letter-spacing: 1.5px;
  text-transform: uppercase; color: rgba(10,22,40,0.5);
  transition: color 0.2s;
}
.nav-links a:hover { color: var(--text); }
#nav.scrolled .nav-links a { color: rgba(10,22,40,0.82); }
.nav-pill {
  padding: 8px 22px;
  border: 1px solid var(--border2) !important;
  border-radius: 100px;
  color: var(--text) !important;
  transition: background 0.2s, border-color 0.2s !important;
}
.nav-pill:hover { background: var(--green-l) !important; border-color: var(--green) !important; color: var(--green) !important; }

.hamburger {
  display: none; flex-direction: column; gap: 5px;
  padding: 4px; margin-left: auto;
}
.hamburger span {
  display: block; width: 22px; height: 1.5px;
  background: var(--text);
  transition: transform 0.3s var(--ease), opacity 0.3s;
}
.hamburger.open span:nth-child(1) { transform: rotate(45deg) translate(4.5px,4.5px); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: rotate(-45deg) translate(4.5px,-4.5px); }
.mobile-menu {
  max-height: 0; overflow: hidden;
  background: rgba(255,255,255,0.97);
  border-bottom: 1px solid var(--border);
  transition: max-height 0.45s var(--ease-out);
}
.mobile-menu.open { max-height: 360px; }
.mobile-menu ul { padding: 16px 48px 28px; display: flex; flex-direction: column; gap: 2px; }
.mobile-menu a {
  display: block; padding: 11px 0;
  font-size: 16px; font-weight: 500; letter-spacing: 1px; text-transform: uppercase;
  border-bottom: 1px solid var(--border);
  transition: color 0.2s;
}
.mobile-menu a:hover { color: var(--green); }

/* ── BUTTONS ───────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 14px 34px; border-radius: 4px;
  font-size: 13px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase;
  border: 1px solid transparent;
  transition: transform 0.2s var(--ease), background 0.2s, border-color 0.2s, box-shadow 0.2s;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }
.btn--primary { background: var(--green); color: #fff; }
.btn--primary:hover { background: var(--green-d); box-shadow: 0 8px 24px rgba(15,123,64,0.25); }
.btn--ghost {
  background: transparent; color: var(--text);
  border-color: rgba(10,22,40,0.25);
}
.btn--ghost:hover { border-color: var(--text); }
.btn--outline {
  background: transparent; color: var(--text);
  border-color: var(--border2);
}
.btn--outline:hover { border-color: var(--green); color: var(--green); background: var(--green-l); }
.btn--full { width: 100%; }

/* Text links */
.text-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase;
  color: var(--green);
  transition: gap 0.2s;
}
.text-link:hover { gap: 10px; }
.tl-arrow { transition: transform 0.2s; }
.text-link:hover .tl-arrow { transform: translateX(3px); }

/* ── HERO ──────────────────────────────── */
#hero {
  position: relative;
  height: 100vh; min-height: 680px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  background: #ffffff;
}
#heroCanvas {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
}
/* Gradient fade: white at top → transparent → court visible at bottom */
#hero::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to bottom,
    rgba(255,255,255,1)   0%,
    rgba(255,255,255,0.9) 18%,
    rgba(255,255,255,0.55) 36%,
    rgba(255,255,255,0)   54%
  );
  pointer-events: none;
  z-index: 4;
}
.hero-content {
  position: relative; z-index: 10;
  text-align: center; padding: 0 24px;
}
.hero-crest {
  height: 250px;
  width: auto;
  display: block;
  margin: 0 auto 28px;
  filter: drop-shadow(0 6px 28px rgba(201,168,76,0.18));
}
.hero-eyebrow {
  display: inline-block;
  font-size: 11px; font-weight: 600; letter-spacing: 4px; text-transform: uppercase;
  color: var(--green); margin-bottom: 32px;
}
.hero-heading {
  display: flex; flex-direction: column; align-items: center;
  margin-bottom: 28px; line-height: 0.92;
}
.hh-line {
  font-size: clamp(72px, 14vw, 164px);
  font-weight: 800; letter-spacing: -3px;
  color: var(--text);
}
.hh-alt {
  font-size: clamp(28px, 5.5vw, 64px);
  font-weight: 300; letter-spacing: 8px;
  color: rgba(10,22,40,0.4);
}
.hero-locations {
  font-size: 12px; font-weight: 500; letter-spacing: 3px; text-transform: uppercase;
  color: var(--muted); margin-bottom: 44px;
}
.loc-soon { color: rgba(10,22,40,0.3); }
.soon-tag {
  display: inline-block;
  font-size: 9px; letter-spacing: 1.5px;
  background: rgba(217,119,6,0.1); color: var(--soon);
  border: 1px solid rgba(217,119,6,0.2);
  padding: 2px 8px; border-radius: 100px;
  margin-left: 6px; vertical-align: middle;
}
.hero-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.hero-scroll {
  position: absolute; bottom: 36px; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  z-index: 10;
}
.hs-line { width: 1px; height: 52px; background: linear-gradient(to bottom, transparent, rgba(255,255,255,0.6)); }
.hero-scroll span { font-size: 9px; letter-spacing: 4px; text-transform: uppercase; color: rgba(255,255,255,0.7); }

/* Reveal animations */
.reveal {
  opacity: 0; transform: translateY(20px);
  transition: opacity 0.9s var(--ease-out), transform 0.9s var(--ease-out);
}
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal:nth-child(2) { transition-delay: 0.08s; }
.reveal:nth-child(3) { transition-delay: 0.18s; }
.reveal:nth-child(4) { transition-delay: 0.28s; }

/* ── STATS ─────────────────────────────── */
#stats {
  background: var(--bg-subtle);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 52px 48px;
}
.stats-wrap {
  max-width: 900px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-around; flex-wrap: wrap; gap: 32px;
}
.stat { text-align: center; }
.stat-number {
  font-size: 52px; font-weight: 700; line-height: 1;
  color: var(--green); letter-spacing: -1px; margin-bottom: 6px;
}
.stat-number sup { font-size: 28px; vertical-align: super; line-height: 0; }
.stat-label { font-size: 11px; font-weight: 500; letter-spacing: 3px; text-transform: uppercase; color: var(--muted); }
.stat-sep { width: 1px; height: 52px; background: var(--border); }

/* ── SECTION COMMONS ───────────────────── */
.section-wrap { max-width: 1200px; margin: 0 auto; padding: 120px 48px; }
.section-header { margin-bottom: 72px; }
.section-label {
  display: block; font-size: 11px; font-weight: 600; letter-spacing: 4px; text-transform: uppercase;
  color: var(--green); margin-bottom: 14px;
}
.section-heading {
  font-size: clamp(36px, 5vw, 56px); font-weight: 700; letter-spacing: -1px; line-height: 1.05;
  color: var(--text);
}
.section-sub { color: var(--muted); max-width: 480px; font-size: 15px; margin-top: 14px; }

/* Scroll fade-in — starts visible so content never gets stuck hidden */
.fi {
  opacity: 1; transform: translateY(0);
}
/* When JS is running it adds .fi-js to body, enabling the animation */
body.fi-js .fi {
  opacity: 0; transform: translateY(22px);
  transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
  transition-delay: var(--fi-delay, 0ms);
}
body.fi-js .fi.visible { opacity: 1; transform: translateY(0); }

/* ── PROGRAMS ──────────────────────────── */
#programs { background: var(--bg); }
.programs-grid {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 1px; background: var(--border);
  border: 1px solid var(--border);
}
.programs-grid--two { grid-template-columns: repeat(2,1fr); }
.prog-card {
  background: var(--bg); padding: 48px 40px;
  display: flex; gap: 32px;
  transition: background 0.25s;
  border-top: 3px solid transparent;
}
.prog-card:hover { background: var(--bg-subtle); border-top-color: var(--green); }
.pc-number {
  font-size: 13px; font-weight: 700; letter-spacing: 2px; color: rgba(10,22,40,0.2);
  flex-shrink: 0; padding-top: 3px;
}
.pc-category {
  font-size: 11px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase;
  color: var(--green); margin-bottom: 10px;
}
.pc-body h3 {
  font-size: 22px; font-weight: 700; letter-spacing: -0.3px; line-height: 1.2;
  color: var(--text); margin-bottom: 14px;
}
.pc-body p { font-size: 14px; color: var(--muted); line-height: 1.7; margin-bottom: 24px; }

/* ── COURTS ────────────────────────────── */
#courts { background: var(--bg-blue); }
.courts-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.court-card {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 8px; padding: 36px;
  transition: box-shadow 0.25s var(--ease), transform 0.25s var(--ease);
}
.court-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.court-card--soon { opacity: 0.6; }
.court-card--soon:hover { opacity: 0.85; }
.cc-top { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 24px; gap: 12px; }
.cc-top h3 { font-size: 26px; font-weight: 700; letter-spacing: -0.5px; color: var(--text); }
.cc-badge {
  font-size: 10px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase;
  padding: 4px 12px; border-radius: 100px; flex-shrink: 0;
}
.cc-badge--open { background: rgba(22,163,74,0.1); color: var(--open); }
.cc-badge--soon { background: rgba(217,119,6,0.1); color: var(--soon); }
.court-card p { font-size: 14px; color: var(--muted); line-height: 1.7; margin: 20px 0 24px; }

/* Mini court */
.cc-court { margin-bottom: 4px; }
.mc-boundary {
  position: relative; height: 80px;
  border: 1.5px solid rgba(15,123,64,0.2);
  border-radius: 4px; overflow: hidden;
  background: rgba(15,123,64,0.04);
}
.mc-boundary--dim { opacity: 0.4; }
.mc-net {
  position: absolute; top: 0; bottom: 0; left: 50%; width: 1.5px;
  background: rgba(26,62,140,0.25); transform: translateX(-50%);
}
.mc-line { position: absolute; background: rgba(15,123,64,0.15); }
.mc-line--v  { top: 0; bottom: 0; left: 50%; width: 1px; }
.mc-line--st { top: 27%; left: 0; right: 0; height: 1px; }
.mc-line--sb { bottom: 27%; left: 0; right: 0; height: 1px; }
/* Mini court players (inline SVG) */
.mc-player {
  position: absolute;
  top: 50%;
  overflow: visible;
}
.mc-player--a {
  left: 8%;
  width: 22px; height: 28px;
  animation: mcSwingA 3.4s ease-in-out infinite both;
}
.mc-player--b {
  right: 8%;
  width: 22px; height: 28px;
  animation: mcSwingB 3.4s ease-in-out infinite both;
}
.mc-rally-ball {
  position: absolute;
  left: 15%; top: 44%;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #e8ff44, #a0b800);
  box-shadow: 0 0 7px rgba(200,224,0,0.95);
  animation: mcRally 3.4s linear infinite both;
}
@keyframes mcSwingA {
  0%    { transform: translateY(calc(-50% + 0px))  translateX(0)   rotate(5deg);   }
  3%    { transform: translateY(calc(-50% + 3px))  translateX(3px) rotate(0deg);   }
  6%    { transform: translateY(calc(-50% - 5px))  translateX(5px) rotate(-22deg); }
  12%   { transform: translateY(calc(-50% + 2px))  translateX(3px) rotate(8deg);   }
  20%   { transform: translateY(calc(-50% + 0px))  translateX(0)   rotate(5deg);   }
  55%   { transform: translateY(calc(-50% - 3px))  translateX(0)   rotate(4deg);   }
  75%   { transform: translateY(calc(-50% + 2px))  translateX(0)   rotate(6deg);   }
  100%  { transform: translateY(calc(-50% + 0px))  translateX(0)   rotate(5deg);   }
}
@keyframes mcSwingB {
  0%    { transform: translateY(calc(-50% + 0px))  translateX(0)    rotate(-5deg);  }
  25%   { transform: translateY(calc(-50% - 3px))  translateX(0)    rotate(-4deg);  }
  45%   { transform: translateY(calc(-50% + 2px))  translateX(0)    rotate(-6deg);  }
  51%   { transform: translateY(calc(-50% + 0px))  translateX(0)    rotate(-5deg);  }
  53%   { transform: translateY(calc(-50% + 3px))  translateX(-3px) rotate(0deg);   }
  56%   { transform: translateY(calc(-50% - 5px))  translateX(-5px) rotate(22deg);  }
  62%   { transform: translateY(calc(-50% + 2px))  translateX(-3px) rotate(-8deg);  }
  70%   { transform: translateY(calc(-50% + 0px))  translateX(0)    rotate(-5deg);  }
  100%  { transform: translateY(calc(-50% + 0px))  translateX(0)    rotate(-5deg);  }
}
@keyframes mcRally {
  0%    { left: 15%; top: 44%; transform: scale(1.3);  }
  5%    { left: 15%; top: 44%; transform: scale(1.3);  }
  6%    { left: 16%; top: 43%; transform: scale(1.1);  }
  17%   { left: 32%; top: 26%; transform: scale(0.88); }
  28%   { left: 50%; top: 20%; transform: scale(0.78); }
  39%   { left: 67%; top: 26%; transform: scale(0.88); }
  50%   { left: 84%; top: 44%; transform: scale(1.3);  }
  55%   { left: 84%; top: 44%; transform: scale(1.3);  }
  56%   { left: 83%; top: 43%; transform: scale(1.1);  }
  67%   { left: 67%; top: 26%; transform: scale(0.88); }
  78%   { left: 50%; top: 20%; transform: scale(0.78); }
  89%   { left: 32%; top: 26%; transform: scale(0.88); }
  100%  { left: 15%; top: 44%; transform: scale(1.3);  }
}

/* ── COACHES ───────────────────────────── */
#coaches { background: var(--bg); }
.coaches-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
.coach-card {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 8px; padding: 32px 28px;
  display: flex; flex-direction: column; gap: 16px;
  transition: box-shadow 0.25s var(--ease), transform 0.25s var(--ease);
}
.coach-card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); }
.coach-avatar {
  width: 64px; height: 64px; border-radius: 50%;
  background: linear-gradient(135deg, var(--green-l), var(--blue-l));
  border: 1.5px solid rgba(15,123,64,0.2);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 700; letter-spacing: 1px; color: var(--green);
}
.coach-info h4 { font-size: 17px; font-weight: 700; letter-spacing: -0.2px; color: var(--text); margin-bottom: 4px; }
.coach-location { font-size: 13px; color: var(--muted); margin-bottom: 12px; }
.coach-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.coach-tags span {
  font-size: 10px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase;
  padding: 3px 10px; border-radius: 100px;
  border: 1px solid var(--border2); color: var(--muted);
}

/* ── BUILD WITH BAMA  (dark section) ───── */
#build { background: #081c10; }
#build .section-label   { color: #5ecf8a; }
#build .section-heading { color: #ffffff; }
#build .build-text > p  { color: rgba(255,255,255,0.6); }
.build-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 100px; align-items: center; }
.build-text .section-label { margin-bottom: 14px; }
.build-text .section-heading { margin-bottom: 20px; }
.build-text > p { font-size: 15px; line-height: 1.75; margin-bottom: 40px; }
.build-list {
  display: flex; flex-direction: column; gap: 16px; margin-bottom: 44px;
}
.build-list li {
  display: flex; align-items: center; gap: 16px;
  font-size: 15px; color: rgba(255,255,255,0.7);
  padding-bottom: 16px; border-bottom: 1px solid rgba(255,255,255,0.08);
}
.build-list li:last-child { border-bottom: none; }
.bl-num {
  font-size: 11px; font-weight: 700; letter-spacing: 1.5px; color: #5ecf8a;
  flex-shrink: 0; width: 22px;
}
#build .btn--primary { background: #5ecf8a; color: #081c10; }
#build .btn--primary:hover { background: #3dbd6e; box-shadow: 0 8px 24px rgba(94,207,138,0.3); }

/* Build court visual */
.build-visual { display: flex; align-items: center; justify-content: center; }
.bv-court {
  position: relative; width: 100%; max-width: 340px; height: 220px;
  border: 1px solid rgba(255,255,255,0.12); border-radius: 4px;
  background: rgba(5,40,20,0.6); overflow: hidden;
}
.bv-net {
  position: absolute; top: 0; bottom: 0; left: 50%; width: 1.5px;
  background: rgba(255,255,255,0.2); transform: translateX(-50%);
}
.bv-line { position: absolute; background: rgba(255,255,255,0.08); }
.bv-line--v  { top: 0; bottom: 0; left: 50%; width: 1px; }
.bv-line--st { top: 27%; left: 0; right: 0; height: 1px; }
.bv-line--sb { bottom: 27%; left: 0; right: 0; height: 1px; }
/* Build court players (inline SVG) */
.bv-player {
  position: absolute;
  top: 50%;
  overflow: visible;
}
.bv-player--a {
  left: 8%;
  width: 34px; height: 44px;
  animation: bvSwingA 3.4s ease-in-out infinite both;
}
.bv-player--b {
  right: 8%;
  width: 34px; height: 44px;
  animation: bvSwingB 3.4s ease-in-out infinite both;
}
.bv-rally-ball {
  position: absolute;
  left: 17%; top: 43%;
  width: 13px; height: 13px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #eeff55, #9ab300);
  box-shadow: 0 0 10px rgba(200,224,0,0.9), 0 0 22px rgba(200,224,0,0.4);
  animation: bvRally 3.4s linear infinite both;
}
@keyframes bvSwingA {
  0%    { transform: translateY(calc(-50% + 0px))  translateX(0)   rotate(5deg);   }
  3%    { transform: translateY(calc(-50% + 4px))  translateX(5px) rotate(0deg);   }
  6%    { transform: translateY(calc(-50% - 7px))  translateX(8px) rotate(-22deg); }
  12%   { transform: translateY(calc(-50% + 3px))  translateX(4px) rotate(10deg);  }
  20%   { transform: translateY(calc(-50% + 0px))  translateX(0)   rotate(5deg);   }
  55%   { transform: translateY(calc(-50% - 4px))  translateX(0)   rotate(4deg);   }
  75%   { transform: translateY(calc(-50% + 3px))  translateX(0)   rotate(6deg);   }
  100%  { transform: translateY(calc(-50% + 0px))  translateX(0)   rotate(5deg);   }
}
@keyframes bvSwingB {
  0%    { transform: translateY(calc(-50% + 0px))  translateX(0)    rotate(-5deg);  }
  25%   { transform: translateY(calc(-50% - 4px))  translateX(0)    rotate(-4deg);  }
  45%   { transform: translateY(calc(-50% + 3px))  translateX(0)    rotate(-6deg);  }
  51%   { transform: translateY(calc(-50% + 0px))  translateX(0)    rotate(-5deg);  }
  53%   { transform: translateY(calc(-50% + 4px))  translateX(-5px) rotate(0deg);   }
  56%   { transform: translateY(calc(-50% - 7px))  translateX(-8px) rotate(22deg);  }
  62%   { transform: translateY(calc(-50% + 3px))  translateX(-4px) rotate(-10deg); }
  70%   { transform: translateY(calc(-50% + 0px))  translateX(0)    rotate(-5deg);  }
  100%  { transform: translateY(calc(-50% + 0px))  translateX(0)    rotate(-5deg);  }
}
@keyframes bvRally {
  0%    { left: 17%; top: 43%; transform: scale(1.3);  }
  5%    { left: 17%; top: 43%; transform: scale(1.3);  }
  6%    { left: 18%; top: 42%; transform: scale(1.1);  }
  17%   { left: 34%; top: 24%; transform: scale(0.88); }
  28%   { left: 50%; top: 17%; transform: scale(0.78); }
  39%   { left: 67%; top: 24%; transform: scale(0.88); }
  50%   { left: 83%; top: 43%; transform: scale(1.3);  }
  55%   { left: 83%; top: 43%; transform: scale(1.3);  }
  56%   { left: 82%; top: 42%; transform: scale(1.1);  }
  67%   { left: 67%; top: 24%; transform: scale(0.88); }
  78%   { left: 50%; top: 17%; transform: scale(0.78); }
  89%   { left: 34%; top: 24%; transform: scale(0.88); }
  100%  { left: 17%; top: 43%; transform: scale(1.3);  }
}

/* ── SPONSOR ───────────────────────────── */
#sponsor { background: var(--bg-subtle); }
.tiers-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.tier-card {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 8px; padding: 40px 36px;
  display: flex; flex-direction: column;
  transition: box-shadow 0.25s var(--ease), transform 0.25s var(--ease), border-color 0.25s, background 0.25s;
}
.tier-card p { flex: 1; }
.tier-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px) scale(1.015);
  border-color: rgba(15,123,64,0.35);
  background: linear-gradient(to bottom, rgba(230,244,236,0.45), var(--bg));
}
.tier-card:hover .btn--outline {
  background: var(--green-l);
  border-color: var(--green);
  color: var(--green);
}
.tier-card--featured {
  border-color: rgba(15,123,64,0.15);
}
.tier-level {
  display: inline-block;
  font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase;
  padding: 4px 14px; border-radius: 100px; margin-bottom: 20px;
}
.tier-level--bronze { background: rgba(180,100,30,0.1); color: #a0622a; border: 1px solid rgba(180,100,30,0.15); }
.tier-level--gold   { background: var(--green-l); color: var(--green); border: 1px solid rgba(15,123,64,0.2); }
.tier-level--plat   { background: var(--bg-blue); color: var(--blue); border: 1px solid rgba(26,62,140,0.2); }
.tier-card h3 { font-size: 24px; font-weight: 700; letter-spacing: -0.3px; margin-bottom: 12px; color: var(--text); }
.tier-card p { font-size: 14px; color: var(--muted); line-height: 1.7; margin-bottom: 32px; }

/* ── CONTACT ───────────────────────────── */
#contact { background: var(--bg-blue); }
.contact-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 100px; align-items: start; }
.contact-intro .section-heading { margin-bottom: 16px; }
.contact-intro > p { font-size: 15px; color: var(--muted); line-height: 1.75; margin-bottom: 40px; }
.contact-locs { display: flex; flex-direction: column; }
.cl-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 0; border-bottom: 1px solid var(--border);
}
.cl-city { font-size: 15px; font-weight: 500; color: var(--text); }
.cl-status {
  font-size: 10px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase;
  padding: 3px 10px; border-radius: 100px;
}
.cl-status--open { background: rgba(22,163,74,0.1); color: var(--open); }
.cl-status--soon { background: rgba(217,119,6,0.1); color: var(--soon); }

.contact-form { display: flex; flex-direction: column; gap: 18px; }
.cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.cf-field { position: relative; }
.cf-field input,
.cf-field textarea,
.cf-field select {
  width: 100%; background: var(--bg); border: 1px solid var(--border2);
  border-radius: 6px; padding: 18px 16px 8px; color: var(--text);
  font-size: 15px; outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
  appearance: none;
}
.cf-field select { padding: 14px 16px; }
.cf-field input:focus,
.cf-field textarea:focus,
.cf-field select:focus {
  border-color: var(--green);
  box-shadow: 0 0 0 3px rgba(15,123,64,0.1);
}
.cf-field label {
  position: absolute; top: 14px; left: 16px;
  font-size: 13px; color: var(--muted); pointer-events: none;
  transition: top 0.2s var(--ease), font-size 0.2s, color 0.2s, letter-spacing 0.2s;
}
.cf-field input:not(:placeholder-shown) ~ label,
.cf-field input:focus ~ label,
.cf-field textarea:not(:placeholder-shown) ~ label,
.cf-field textarea:focus ~ label {
  top: 6px; font-size: 10px; color: var(--green); letter-spacing: 1.5px; text-transform: uppercase;
}
.cf-field textarea { resize: vertical; min-height: 110px; }
.btn-sent { display: none; }
.contact-form.sent .btn-label { display: none; }
.contact-form.sent .btn-sent { display: block; }
.contact-form.sent button { background: var(--open); pointer-events: none; }

/* ── FOOTER (dark) ─────────────────────── */
#footer { background: #0a1628; border-top: none; }
.footer-wrap {
  max-width: 1200px; margin: 0 auto;
  padding: 72px 48px 48px;
  display: flex; gap: 80px; flex-wrap: wrap;
}
.footer-brand { flex: 1; min-width: 180px; }
.footer-logo { display: flex; flex-direction: column; gap: 2px; line-height: 1; margin-bottom: 18px; }
.footer-logo .logo-primary { color: #5ecf8a; }
.footer-logo .logo-secondary { color: rgba(255,255,255,0.3); }
.footer-brand p { font-size: 13px; color: rgba(255,255,255,0.4); line-height: 1.8; }
.footer-nav { display: flex; gap: 64px; margin-left: auto; }
.fn-col { display: flex; flex-direction: column; gap: 10px; }
.fn-col h5 {
  font-size: 10px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase;
  color: rgba(255,255,255,0.3); margin-bottom: 6px;
}
.fn-col a { font-size: 14px; color: rgba(255,255,255,0.45); transition: color 0.2s; }
.fn-col a:hover { color: #fff; }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.07);
  padding: 20px 48px;
  font-size: 12px; color: rgba(255,255,255,0.3);
}

/* ── RESPONSIVE ────────────────────────── */
@media (max-width: 1100px) {
  .build-wrap { grid-template-columns: 1fr; gap: 56px; }
  .build-visual { display: none; }
  .coaches-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 900px) {
  .programs-grid { grid-template-columns: 1fr; }
  .courts-grid { grid-template-columns: 1fr; }
  .tiers-grid { grid-template-columns: 1fr; }
  .contact-wrap { grid-template-columns: 1fr; gap: 56px; }
  .cf-row { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .nav-links { display: none; }
  .hamburger { display: flex; }
  .nav-wrap { padding: 20px 24px; }
  #nav.scrolled .nav-wrap { padding: 14px 24px; }
  .section-wrap { padding: 80px 24px; }
  #stats { padding: 40px 24px; }
  .stat-sep { display: none; }
  .footer-wrap { flex-direction: column; gap: 40px; padding: 48px 24px 32px; }
  .footer-nav { margin-left: 0; gap: 40px; }
  .footer-bottom { padding: 16px 24px; }
  .hero-actions { flex-direction: column; align-items: center; }
}
@media (max-width: 520px) {
  .coaches-grid { grid-template-columns: 1fr; }
  .hh-line { letter-spacing: -1px; }
  .hh-alt { letter-spacing: 4px; }
}
