/* =========================================================
   10TH PLANET BASTROP — Design System
   Per official Brand Guideline Sheet:
   Dark. Technical. No-Gi. Built for Bastrop.
   Void Black foundation · Planet Mint accent (used selectively)
   Oxanium (display) + Inter (body)
   ========================================================= */

:root {
  /* Brand color tokens */
  --void-black:   #000100;
  --mat-charcoal: #0B110B;
  --deep-ring:    #224221;
  --orbit-green:  #6E8A6D;
  --planet-mint:  #C5FAC1;
  --soft-mint:    #E7FFE3;
  --texas-canvas: #D8CBA7;
  --bone-white:   #F7FBF7;
  --fog-gray:     #B6C2B6;

  /* Semantic */
  --bg:        var(--void-black);
  --bg-2:      #0E140E;          /* charcoal panel for alt sections */
  --bg-3:      #0B110B;
  --surface:   var(--mat-charcoal);
  --line:      rgba(197,250,193,.18);
  --line-2:    rgba(197,250,193,.09);
  --text:      var(--bone-white);
  --text-dim:  var(--fog-gray);
  --text-mute: var(--orbit-green);
  --accent:    var(--planet-mint);
  --accent-2:  var(--soft-mint);
  --accent-ink:var(--void-black);
  /* CTA button color (distinct from the mint brand accent) */
  --cta:       #F7FBF7;
  --cta-hover: #FFFFFF;
  --cta-ink:   #08090A;

  --maxw:      1240px;
  --radius:    10px;        /* cards 8-12px */
  --radius-btn:7px;         /* buttons 6-8px */
  --ease:      cubic-bezier(.16,.84,.44,1);
  --header-h:  96px;
  --font-display: "Oxanium", system-ui, sans-serif;
  --font-body: "Inter", system-ui, sans-serif;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }

/* Subtle mat-grid atmosphere — low opacity per brand (5-12%) */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(197,250,193,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(197,250,193,.025) 1px, transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse 120% 90% at 50% 0%, #000 25%, transparent 78%);
}

/* ---------- Layout helpers ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:24px; }
.section{ position:relative; z-index:1; padding:clamp(56px,8vw,118px) 0; }
.section--tight{ padding:clamp(48px,6vw,84px) 0; }
.center{ text-align:center; }
.mx-auto{ margin-inline:auto; }

/* Charcoal panel + photo band — lift the page out of flat black */
.section--charcoal{ background:var(--mat-charcoal);
  background-image:linear-gradient(180deg, rgba(197,250,193,.03), transparent 40%); }
.section--photo{ position:relative; background-color:var(--void-black);
  background-size:cover; background-position:center; }
.section--photo::before{ content:""; position:absolute; inset:0; z-index:0;
  background:linear-gradient(180deg, rgba(6,9,6,.80) 0%, rgba(6,9,6,.88) 60%, rgba(6,9,6,.94) 100%); }
.section--photo > .container{ position:relative; z-index:1; }
@media (min-width:881px) and (prefers-reduced-motion:no-preference){
  .section--photo{ background-attachment:fixed; }
}

/* Orbital ring motif — subtle, top-right (approved graphic motif) */
.orbital{ position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden; }
.orbital::after{
  content:""; position:absolute; top:-30%; right:-12%; width:780px; height:780px;
  border-radius:50%;
  background:repeating-radial-gradient(circle at center, transparent 0 58px, rgba(197,250,193,.05) 58px 59px);
  mask-image:radial-gradient(circle at center, #000 60%, transparent 72%);
}

/* ---------- Typography ---------- */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:700; line-height:1.05;
  text-transform:uppercase; letter-spacing:.005em; }
.display{ font-size:clamp(2.6rem,7vw,5rem); }
h1{ font-size:clamp(2.5rem,6vw,5rem); }          /* 40-80px */
h2{ font-size:clamp(2rem,4.4vw,3.25rem); }       /* 32-52px */
h3{ font-size:clamp(1.375rem,2.2vw,1.875rem); }  /* 22-30px */
h4{ font-size:1.1rem; letter-spacing:.04em; font-weight:700; }
p{ color:var(--text-dim); }
.lead{ font-size:clamp(1.06rem,1.5vw,1.25rem); color:var(--text-dim); line-height:1.65; }
strong,b{ color:var(--text); font-weight:600; }
.accent{ color:var(--accent); }

.eyebrow{
  display:inline-flex; align-items:center; gap:11px;
  font-family:var(--font-display); font-weight:700;
  text-transform:uppercase; letter-spacing:.16em; font-size:.78rem;
  color:var(--accent);
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--accent); }
.eyebrow.center{ justify-content:center; }
.section-head{ max-width:760px; margin-bottom:clamp(34px,5vw,58px); }
.section-head.center{ margin-inline:auto; }
.section-head p{ margin-top:18px; }

/* ---------- Buttons (squared, technical) ---------- */
.btn{
  --b:var(--accent);
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-display); font-weight:700; font-size:.84rem;
  text-transform:uppercase; letter-spacing:.1em;
  padding:14px 26px; border-radius:var(--radius-btn); cursor:pointer;
  border:1.5px solid var(--b); background:transparent; color:var(--text);
  transition:.32s var(--ease); position:relative; white-space:nowrap;
}
.btn .arr{ transition:transform .32s var(--ease); }
.btn:hover .arr{ transform:translateX(4px); }
.btn-primary{ background:var(--cta); color:var(--cta-ink); border-color:var(--cta); }
.btn-primary:hover{ background:var(--cta-hover); border-color:var(--cta-hover); transform:translateY(-2px); }
.btn-outline{ border-color:var(--cta); }
.btn-outline:hover{ background:rgba(247,251,247,.12); transform:translateY(-2px); }
.btn-ghost{ border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--cta); color:var(--cta); }
.btn-lg{ padding:17px 34px; font-size:.9rem; }
.btn-block{ width:100%; justify-content:center; }

/* ---------- Header / Nav ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:100; height:var(--header-h);
  display:flex; align-items:center;
  transition:background .4s var(--ease), border-color .4s var(--ease), height .4s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  height:78px;
  background:rgba(0,1,0,.86); backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; width:100%;
  max-width:var(--maxw); margin-inline:auto; padding-inline:24px; gap:20px; }
.brand{ display:flex; align-items:center; gap:12px; flex-shrink:0; z-index:2; }
.brand img{ height:50px; width:auto; }
.brand-txt{ display:flex; flex-direction:column; line-height:1.05; }
.brand-txt b{ font-family:var(--font-display); font-weight:800; font-size:1.05rem; letter-spacing:.04em; }
.brand-txt span{ font-size:.58rem; letter-spacing:.34em; color:var(--text-mute); text-transform:uppercase; }

.nav-links{ display:flex; align-items:center; gap:4px; }
.nav-links > li > a, .nav-links > li > .nav-top{
  display:flex; align-items:center; gap:6px; cursor:pointer;
  font-family:var(--font-display); font-weight:600; font-size:.86rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--text); opacity:.82; padding:10px 14px; border-radius:6px; transition:.25s var(--ease);
}
.nav-links > li > a:hover, .nav-links > li:hover > .nav-top{ opacity:1; color:var(--accent); }
.nav-links > li > a.active{ opacity:1; color:var(--accent); }
.has-drop{ position:relative; }
.has-drop > .nav-top::after{ content:"›"; transform:rotate(90deg); display:inline-block; font-size:1rem; color:var(--accent); transition:.25s; }
.dropdown{
  position:absolute; top:calc(100% + 10px); left:0; min-width:240px;
  background:rgba(11,17,11,.98); backdrop-filter:blur(14px);
  border:1px solid var(--line); border-radius:10px; padding:8px;
  opacity:0; visibility:hidden; transform:translateY(8px); transition:.3s var(--ease);
  box-shadow:0 24px 60px rgba(0,0,0,.6);
}
.has-drop:hover .dropdown{ opacity:1; visibility:visible; transform:translateY(0); }
.dropdown a{ display:block; padding:11px 14px; border-radius:6px; font-size:.9rem;
  color:var(--text-dim); transition:.2s; letter-spacing:.02em; }
.dropdown a:hover{ background:rgba(197,250,193,.10); color:var(--accent); padding-left:20px; }
.nav-cta{ display:flex; align-items:center; gap:14px; flex-shrink:0; }

.burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; z-index:120; }
.burger span{ width:26px; height:2px; background:var(--text); transition:.3s var(--ease); }
.burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* Mobile menu */
.mobile-menu{
  position:fixed; inset:0; z-index:95; background:rgba(0,1,0,.99);
  backdrop-filter:blur(10px); transform:translateX(100%); transition:transform .5s var(--ease);
  display:flex; flex-direction:column; padding:calc(var(--header-h) + 16px) 28px 40px; overflow-y:auto;
}
.mobile-menu.open{ transform:translateX(0); }
/* Direct-child links only — so the CTA buttons in .m-cta keep their own styling */
.mobile-menu > a{ font-family:var(--font-display); font-weight:600; font-size:1.3rem; text-transform:uppercase; letter-spacing:.08em;
  padding:19px 0; border-bottom:1px solid var(--line-2); color:var(--text); }
.mobile-menu > a:active{ color:var(--accent); }
.mobile-menu .m-cta{ margin-top:auto; padding-top:26px; display:flex; flex-direction:column; gap:14px; }
/* Mobile accordion groups (About / Programs) */
.m-group{ border-bottom:1px solid var(--line-2); }
.m-acc{ width:100%; display:flex; align-items:center; justify-content:space-between; background:none; border:0;
  cursor:pointer; color:var(--text); font-family:var(--font-display); font-weight:600; font-size:1.3rem;
  text-transform:uppercase; letter-spacing:.08em; padding:19px 0; }
.m-arrow{ color:var(--accent); font-size:1.5rem; line-height:1; transition:transform .3s var(--ease); }
.m-group.open .m-arrow{ transform:rotate(90deg); }
.m-sub{ max-height:0; overflow:hidden; transition:max-height .35s var(--ease); }
.m-group.open .m-sub{ max-height:260px; }
.m-sub a{ display:block; font-family:var(--font-body); font-weight:500; font-size:1.05rem; text-transform:none; letter-spacing:.02em;
  color:var(--text-dim); border-bottom:0; padding:11px 0 11px 16px; }

/* ---------- Hero ---------- */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center;
  padding-top:calc(var(--header-h) + 24px); padding-bottom:clamp(56px,9vh,96px); overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.35) contrast(1.04); }

/* ===== Homepage hero: headline left, featured photo right ===== */
.home-hero{ position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden;
  padding-top:calc(var(--header-h) + clamp(18px,4vh,44px)); padding-bottom:clamp(48px,8vh,92px);
  background:
    radial-gradient(70% 65% at 18% 30%, rgba(34,66,33,.55), transparent 64%),
    radial-gradient(56% 70% at 93% 24%, rgba(197,250,193,.10), transparent 56%),
    var(--void-black); }
.home-hero > .container{ position:relative; z-index:2; width:100%; }
.home-hero-inner{ display:grid; grid-template-columns:minmax(0,1.04fr) minmax(0,.96fr);
  align-items:center; gap:clamp(30px,5vw,72px); }
.home-hero-copy, .home-hero-media{ min-width:0; }

/* Left column — copy (reuses the shared .hero-* type + motion classes) */
.home-hero-copy{ max-width:620px; }
.home-hero-copy h1{ margin:18px 0 0; line-height:1.0; }
.home-hero-copy h1 .line{ display:block; overflow:hidden; }
.home-hero-copy h1 .line > span{ display:block; transform:translateY(110%);
  animation:riseIn .9s var(--ease) forwards; }
.home-hero-copy h1 .line:nth-child(2) > span{ animation-delay:.12s; }
.home-hero-copy .lead{ max-width:560px; opacity:0; animation:fadeUp .8s var(--ease) .5s forwards; }

/* Right column — featured photo with the 10th Planet orbit motif */
.home-hero-media{ position:relative; opacity:0; animation:fadeUp 1s var(--ease) .34s forwards; }
.hhm-frame{ position:relative; width:100%; max-width:512px; margin-inline:auto; aspect-ratio:4/5; }
.hhm-frame img{ position:relative; z-index:2; width:100%; height:100%; display:block;
  object-fit:cover; object-position:54% 46%; border-radius:20px;
  filter:contrast(1.05) saturate(1.03) brightness(.98);
  box-shadow:0 46px 100px -34px rgba(0,0,0,.85), 0 0 0 1px rgba(197,250,193,.16); }
/* orbit ring sweeping behind the photo, with a planet node on its path */
.hhm-orbit{ position:absolute; z-index:1; inset:-15% -13%; border-radius:50%;
  border:1.5px solid rgba(197,250,193,.26); transform:rotate(-16deg); pointer-events:none; }
.hhm-orbit::after{ content:""; position:absolute; top:3%; left:80%; width:13px; height:13px;
  border-radius:50%; background:var(--accent);
  box-shadow:0 0 0 5px rgba(197,250,193,.14), 0 0 26px 5px rgba(197,250,193,.55); }
/* floating credential chip */
.hhm-badge{ position:absolute; z-index:3; left:-6px; bottom:26px;
  display:inline-flex; align-items:center; gap:10px; padding:11px 16px 11px 14px;
  border-radius:13px; background:rgba(11,17,11,.92); border:1px solid rgba(197,250,193,.22);
  box-shadow:0 22px 46px -18px rgba(0,0,0,.85);
  font-family:var(--font-display); font-weight:600; font-size:.82rem;
  letter-spacing:.02em; color:var(--bone-white); }
.hhm-badge::before{ content:""; width:9px; height:9px; border-radius:50%;
  background:var(--accent); box-shadow:0 0 12px 2px rgba(197,250,193,.6); }

@media (max-width:880px){
  .home-hero{ min-height:auto; padding-top:calc(var(--header-h) + 30px); }
  .home-hero-inner{ grid-template-columns:minmax(0,1fr); gap:clamp(36px,8vw,52px); }
  .home-hero-copy{ max-width:none; }
  .hhm-frame{ aspect-ratio:4/3; max-width:560px; }
  .hhm-orbit{ inset:-10% -9%; }
}
@media (prefers-reduced-motion:reduce){
  .home-hero-copy h1 .line > span,
  .home-hero-copy .lead,
  .home-hero-copy .hero-eyebrow,
  .home-hero-copy .hero-sub,
  .home-hero-copy .hero-actions,
  .home-hero-copy .hero-meta,
  .home-hero-media{ animation:none; opacity:1; transform:none; }
}
/* black overlay 55-75% + subtle mint radial wash per brand */
.hero-bg::after{ content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(0,1,0,.6) 0%, rgba(0,1,0,.5) 35%, rgba(0,1,0,.95) 100%),
    radial-gradient(120% 80% at 82% 18%, rgba(197,250,193,.12), transparent 55%); }
.hero-inner{ position:relative; z-index:2; max-width:880px; }
.hero h1{ margin:18px 0 0; line-height:1.0; }
.hero h1 .line{ display:block; overflow:hidden; }
.hero h1 .line > span{ display:block; transform:translateY(110%); animation:riseIn .9s var(--ease) forwards; }
.hero h1 .line:nth-child(2) > span{ animation-delay:.12s; }
.hero h1 .line:nth-child(3) > span{ animation-delay:.24s; }
.hero-sub{ font-size:clamp(1rem,1.7vw,1.4rem); line-height:1.25; letter-spacing:.04em; color:var(--text-dim);
  margin:24px 0 22px; max-width:620px; opacity:0; animation:fadeUp .8s var(--ease) .36s forwards; }
.hero .lead{ max-width:580px; opacity:0; animation:fadeUp .8s var(--ease) .5s forwards; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; opacity:0; animation:fadeUp .8s var(--ease) .65s forwards; }
.hero-eyebrow{ opacity:0; animation:fadeUp .8s var(--ease) .15s forwards; }
.hero-meta{ display:flex; flex-wrap:wrap; gap:14px 40px; align-items:center;
  margin-top:clamp(44px,7vh,76px); padding-top:24px; border-top:1px solid var(--line);
  opacity:0; animation:fadeUp .8s var(--ease) .8s forwards; }
.hero-stat{ display:flex; align-items:baseline; gap:10px; }
.hero-stat b{ font-family:var(--font-display); font-weight:800; font-size:1.7rem; color:var(--accent); }
.hero-stat span{ font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-dim); }
.scroll-cue{ position:absolute; bottom:30px; right:24px; z-index:3; writing-mode:vertical-rl;
  font-family:var(--font-display); font-size:.7rem; letter-spacing:.28em; text-transform:uppercase; color:var(--text-mute);
  display:flex; align-items:center; gap:14px; }
.scroll-cue::after{ content:""; width:1px; height:46px; background:linear-gradient(var(--accent),transparent); animation:cue 1.8s infinite; }

@keyframes riseIn{ to{ transform:translateY(0); } }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(24px);} to{ opacity:1; transform:translateY(0);} }
@keyframes cue{ 0%,100%{ transform:scaleY(.4); opacity:.4; transform-origin:top;} 50%{ transform:scaleY(1); opacity:1;} }

/* Trust bar */
.trustbar{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--mat-charcoal); }
.trustbar .container{ display:flex; flex-wrap:wrap; gap:14px 34px; align-items:center; justify-content:center;
  padding-top:20px; padding-bottom:20px; }
.trustbar span{ font-family:var(--font-display); font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  font-size:.78rem; color:var(--text-dim); display:inline-flex; align-items:center; gap:10px; }
.trustbar span svg{ width:16px; height:16px; color:var(--accent); }
.trustbar .dot{ width:5px; height:5px; border-radius:50%; background:var(--orbit-green); }

/* Page banner (interior pages) */
.page-hero{ position:relative; padding:calc(var(--header-h) + 80px) 0 66px; overflow:hidden; }
.page-hero .hero-bg img{ filter:grayscale(.5) contrast(1.04) brightness(.55); }
.page-hero .hero-bg::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,1,0,.72), rgba(0,1,0,.96)),
  radial-gradient(100% 80% at 85% 0%, rgba(197,250,193,.13), transparent 60%); }
/* About page: drop the group photo lower in frame + lighter fade */
.page-hero--about .hero-bg img{ filter:grayscale(.42) contrast(1.04) brightness(.74); object-position:center 30%; }
.page-hero--about .hero-bg::after{
  background:linear-gradient(180deg, rgba(0,1,0,.46), rgba(0,1,0,.62) 55%, rgba(0,1,0,.84)),
  radial-gradient(100% 80% at 85% 0%, rgba(197,250,193,.12), transparent 60%); }
.page-hero-inner{ position:relative; z-index:2; max-width:820px; }
.page-hero h1{ margin:16px 0 18px; }
.breadcrumbs{ display:flex; gap:8px; font-family:var(--font-display); font-size:.76rem; letter-spacing:.08em; text-transform:uppercase;
  color:var(--text-mute); margin-top:18px; }
.breadcrumbs a:hover{ color:var(--accent); }
.breadcrumbs span{ color:var(--text-dim); }

/* ===== Kids program: cosmic orbit hero (no photo) ===== */
.kids-hero{ display:flex; align-items:center; min-height:clamp(440px,64vh,600px);
  background:
    radial-gradient(82% 92% at 80% 40%, rgba(34,66,33,.42), transparent 60%),
    radial-gradient(70% 80% at 45% 128%, rgba(197,250,193,.06), transparent 60%),
    var(--void-black); }
.kids-hero .page-hero-inner{ max-width:640px; }
.kh-sky{ position:absolute; inset:0; z-index:0; overflow:hidden; }

/* starfield — three drifting, twinkling layers */
.kh-stars{ position:absolute; inset:-20%; background-repeat:repeat; }
.kh-stars-1{ background-image:
    radial-gradient(1.5px 1.5px at 25px 35px, #fff, transparent),
    radial-gradient(1px 1px at 130px 90px, rgba(255,255,255,.8), transparent),
    radial-gradient(1px 1px at 205px 50px, rgba(255,255,255,.7), transparent),
    radial-gradient(1.5px 1.5px at 80px 150px, rgba(197,250,193,.9), transparent),
    radial-gradient(1px 1px at 170px 175px, rgba(255,255,255,.75), transparent),
    radial-gradient(2px 2px at 40px 110px, rgba(255,255,255,.85), transparent);
  background-size:250px 200px;
  animation:kh-twinkle 5s ease-in-out infinite, kh-drift 140s linear infinite; }
.kh-stars-2{ background-image:
    radial-gradient(1.5px 1.5px at 60px 50px, #fff, transparent),
    radial-gradient(2px 2px at 250px 120px, rgba(197,250,193,.9), transparent),
    radial-gradient(1px 1px at 150px 225px, rgba(255,255,255,.8), transparent),
    radial-gradient(1.5px 1.5px at 300px 200px, rgba(255,255,255,.7), transparent),
    radial-gradient(1px 1px at 30px 245px, rgba(255,255,255,.7), transparent);
  background-size:330px 290px;
  animation:kh-twinkle 7s ease-in-out .8s infinite, kh-drift 200s linear infinite reverse; }
.kh-stars-3{ background-image:
    radial-gradient(2px 2px at 120px 80px, #fff, transparent),
    radial-gradient(2.5px 2.5px at 400px 300px, rgba(197,250,193,.95), transparent),
    radial-gradient(1.5px 1.5px at 250px 390px, rgba(255,255,255,.85), transparent);
  background-size:480px 430px;
  animation:kh-twinkle 9s ease-in-out .4s infinite; }

/* the 10th Planet */
.kh-planet{ position:absolute; top:50%; right:9%; transform:translateY(-50%);
  width:clamp(170px,23vw,300px); aspect-ratio:1; }
.kh-glow{ position:absolute; inset:-30%; border-radius:50%;
  background:radial-gradient(circle, rgba(197,250,193,.16), transparent 62%); }
.kh-body{ position:absolute; inset:13%; border-radius:50%;
  background:radial-gradient(circle at 34% 28%, #3a5e38 0%, #1c2f1b 46%, #0a120a 100%);
  box-shadow:inset -22px -26px 56px rgba(0,0,0,.75),
    inset 16px 14px 38px rgba(197,250,193,.18), 0 0 50px rgba(197,250,193,.14); }
.kh-orbit{ position:absolute; inset:0; border-radius:50%;
  border:1.5px solid rgba(197,250,193,.32); transform:rotate(-20deg) scaleY(.46); }
.kh-track{ position:absolute; inset:0; transform:rotate(-20deg) scaleY(.46);
  animation:kh-spin 17s linear infinite; }
.kh-moon{ position:absolute; top:-7px; left:calc(50% - 7px); width:14px; height:14px;
  border-radius:50%; background:var(--accent);
  box-shadow:0 0 16px 3px rgba(197,250,193,.6); transform:scaleY(2.17); }

@keyframes kh-twinkle{ 0%,100%{ opacity:.5; } 50%{ opacity:1; } }
@keyframes kh-drift{ from{ background-position:0 0; } to{ background-position:250px 180px; } }
@keyframes kh-spin{ to{ transform:rotate(-20deg) scaleY(.46) rotate(360deg); } }

@media (max-width:880px){
  .kids-hero{ min-height:auto; }
  .kh-planet{ right:-6%; top:22%; width:clamp(150px,42vw,230px); opacity:.8; }
}
@media (prefers-reduced-motion:reduce){
  .kh-stars, .kh-track{ animation:none; }
}

/* ===== Adult program: cosmic eclipse hero (no photo) ===== */
.adult-hero{ display:flex; align-items:center; min-height:clamp(440px,64vh,600px);
  background:
    radial-gradient(70% 95% at 82% 50%, rgba(34,66,33,.5), transparent 58%),
    radial-gradient(60% 70% at 30% 110%, rgba(197,250,193,.05), transparent 60%),
    var(--void-black); }
.adult-hero .page-hero-inner{ max-width:660px; }
.ah-sky{ position:absolute; inset:0; z-index:0; overflow:hidden; }
.ah-neb{ position:absolute; inset:0;
  background:radial-gradient(38% 70% at 66% 38%, rgba(110,138,109,.16), transparent 60%); }

/* dense deep-space starfield */
.ah-stars{ position:absolute; inset:-20%; background-repeat:repeat; }
.ah-stars-1{ background-image:
    radial-gradient(1px 1px at 18px 24px, #fff, transparent),
    radial-gradient(1px 1px at 95px 60px, rgba(255,255,255,.75), transparent),
    radial-gradient(1px 1px at 150px 30px, rgba(255,255,255,.7), transparent),
    radial-gradient(1.5px 1.5px at 60px 120px, rgba(197,250,193,.85), transparent),
    radial-gradient(1px 1px at 130px 150px, rgba(255,255,255,.7), transparent),
    radial-gradient(1px 1px at 185px 95px, rgba(255,255,255,.8), transparent),
    radial-gradient(1.5px 1.5px at 30px 80px, rgba(255,255,255,.85), transparent);
  background-size:200px 170px;
  animation:ah-twinkle 6s ease-in-out infinite, ah-drift 170s linear infinite; }
.ah-stars-2{ background-image:
    radial-gradient(1px 1px at 50px 40px, #fff, transparent),
    radial-gradient(1.5px 1.5px at 220px 110px, rgba(197,250,193,.8), transparent),
    radial-gradient(1px 1px at 140px 200px, rgba(255,255,255,.75), transparent),
    radial-gradient(1px 1px at 280px 180px, rgba(255,255,255,.65), transparent),
    radial-gradient(1px 1px at 25px 220px, rgba(255,255,255,.7), transparent);
  background-size:300px 260px;
  animation:ah-twinkle 8s ease-in-out 1s infinite, ah-drift 240s linear infinite reverse; }
.ah-stars-3{ background-image:
    radial-gradient(2px 2px at 110px 70px, #fff, transparent),
    radial-gradient(1.5px 1.5px at 360px 280px, rgba(255,255,255,.8), transparent),
    radial-gradient(2px 2px at 240px 360px, rgba(197,250,193,.9), transparent);
  background-size:460px 400px;
  animation:ah-twinkle 11s ease-in-out .5s infinite; }

/* eclipse planet — dark body, bright mint rim, orbital arcs */
.ah-planet{ position:absolute; top:50%; right:-3%; transform:translateY(-50%);
  width:clamp(240px,32vw,440px); aspect-ratio:1; }
.ah-body{ position:absolute; inset:16%; border-radius:50%; z-index:2;
  background:
    radial-gradient(115% 115% at 120% 46%, rgba(197,250,193,.9) 0%, rgba(197,250,193,.16) 15%, rgba(20,32,19,0) 35%),
    radial-gradient(circle at 42% 40%, #162415 0%, #0a120a 64%, #05090a 100%);
  box-shadow:0 0 90px rgba(197,250,193,.18),
    inset -26px 0 76px -30px rgba(197,250,193,.6), inset 34px 26px 80px rgba(0,0,0,.7); }
.ah-arc{ position:absolute; border-radius:50%; border:1px solid rgba(197,250,193,.22); z-index:1; }
.ah-arc-1{ inset:2%; transform:rotate(-18deg) scaleY(.4); }
.ah-arc-2{ inset:-9%; border-color:rgba(197,250,193,.14); transform:rotate(13deg) scaleY(.62); }
.ah-track{ position:absolute; inset:-9%; z-index:3; transform:rotate(13deg) scaleY(.62);
  animation:ah-spin 30s linear infinite; }
.ah-sat{ position:absolute; top:-5px; left:calc(50% - 5px); width:10px; height:10px;
  border-radius:50%; background:var(--accent);
  box-shadow:0 0 12px 2px rgba(197,250,193,.55); transform:scaleY(1.61); }

@keyframes ah-twinkle{ 0%,100%{ opacity:.4; } 50%{ opacity:.92; } }
@keyframes ah-drift{ from{ background-position:0 0; } to{ background-position:200px 150px; } }
@keyframes ah-spin{ to{ transform:rotate(13deg) scaleY(.62) rotate(360deg); } }

@media (max-width:880px){
  .adult-hero{ min-height:auto; }
  .ah-planet{ right:-20%; top:20%; width:clamp(200px,56vw,320px); opacity:.82; }
}
@media (prefers-reduced-motion:reduce){
  .ah-stars, .ah-track{ animation:none; }
}

/* ===== Schedule page: planner / notebook hero (no photo) ===== */
.sched-hero{ display:flex; align-items:center; min-height:clamp(420px,56vh,560px);
  background:
    radial-gradient(72% 95% at 26% 44%, rgba(34,66,33,.32), transparent 62%),
    var(--void-black); }
.sched-hero .page-hero-inner{ position:relative; max-width:720px; }
.sh-paper{ position:absolute; inset:0; z-index:0; overflow:hidden; }
/* faint ruled lines, faded at top + bottom edges */
.sh-rules{ position:absolute; inset:0;
  background-image:repeating-linear-gradient(rgba(197,250,193,.07) 0 1px, transparent 1px 39px);
  background-position:0 20px;
  -webkit-mask-image:linear-gradient(transparent, #000 12%, #000 86%, transparent);
          mask-image:linear-gradient(transparent, #000 12%, #000 86%, transparent); }
/* spiral binding holes, sitting just below the header */
.sh-spiral{ position:absolute; top:calc(var(--header-h) + 16px); left:0; right:0; height:16px;
  background-image:radial-gradient(circle, transparent 0 4px, rgba(197,250,193,.42) 4px 5.4px, transparent 5.6px);
  background-size:37px 16px; background-repeat:repeat-x; }
/* notebook margin line, tracking the content's left edge */
.sched-hero .page-hero-inner::before{ content:""; position:absolute; left:-30px;
  top:-600px; bottom:-600px; width:2px; background:rgba(197,250,193,.2); z-index:0; }
/* marked-up headline word + hand-drawn underline */
.sh-mark{ position:relative; display:inline-block; white-space:nowrap; }
.sh-underline{ position:absolute; left:-2%; bottom:-.2em; width:104%; height:.4em; overflow:visible; }
.sh-underline path{ fill:none; stroke:var(--accent); stroke-width:3.2; stroke-linecap:round;
  stroke-dasharray:260; stroke-dashoffset:260; animation:sh-draw 1s var(--ease) .55s forwards; }
@keyframes sh-draw{ to{ stroke-dashoffset:0; } }

@media (max-width:880px){
  .sched-hero{ min-height:auto; }
  .sched-hero .page-hero-inner::before{ left:-16px; }
}
@media (prefers-reduced-motion:reduce){
  .sh-underline path{ animation:none; stroke-dashoffset:0; }
}

/* ===== Coach page: "the 10th Planet" portrait hero ===== */
.coach-hero{ display:flex; align-items:center; min-height:clamp(440px,64vh,600px);
  background:
    radial-gradient(58% 92% at 80% 50%, rgba(34,66,33,.44), transparent 58%),
    radial-gradient(60% 70% at 24% 116%, rgba(197,250,193,.05), transparent 60%),
    var(--void-black); }
.coach-hero .page-hero-inner{ max-width:560px; }
.ch-sky{ position:absolute; inset:0; z-index:0; overflow:hidden; }

/* Coach Gabe as the planet: circular portrait, orbital ring + satellite */
.ch-orb{ position:absolute; z-index:1; top:50%; right:7%; transform:translateY(-50%);
  width:clamp(220px,27vw,358px); aspect-ratio:1; }
.ch-orb-inner{ position:absolute; inset:0; border-radius:50%; overflow:hidden; z-index:2;
  box-shadow:0 0 0 1px rgba(197,250,193,.4),
    inset -22px -26px 64px rgba(0,0,0,.7), inset 16px 14px 40px rgba(197,250,193,.12),
    0 0 70px rgba(197,250,193,.2); }
.ch-orb-inner img{ width:100%; height:100%; object-fit:cover; object-position:center top;
  transform:scale(1.16); transform-origin:60% 0%; filter:grayscale(.18) contrast(1.05); }
.ch-orb-inner::after{ content:""; position:absolute; inset:0; border-radius:50%; pointer-events:none;
  background:radial-gradient(125% 125% at 50% -10%, rgba(197,250,193,.4) 0%, transparent 22%);
  mix-blend-mode:screen; }
.ch-ring{ position:absolute; inset:-16%; border-radius:50%; z-index:1;
  border:1.5px solid rgba(197,250,193,.3); transform:rotate(-18deg) scaleY(.5); }
.ch-track{ position:absolute; inset:-16%; z-index:3; transform:rotate(-18deg) scaleY(.5);
  animation:ch-spin 21s linear infinite; }
.ch-node{ position:absolute; top:-6px; left:calc(50% - 6px); width:12px; height:12px;
  border-radius:50%; background:var(--accent); box-shadow:0 0 14px 3px rgba(197,250,193,.6);
  transform:scaleY(2); }
.ch-badge{ position:absolute; z-index:4; left:50%; bottom:-14px; transform:translateX(-50%);
  display:inline-flex; align-items:center; gap:8px; white-space:nowrap; padding:9px 17px;
  border-radius:30px; background:rgba(11,17,11,.94); border:1px solid rgba(197,250,193,.3);
  box-shadow:0 16px 38px -14px rgba(0,0,0,.85);
  font-family:var(--font-display); font-weight:700; font-size:.78rem; letter-spacing:.08em;
  text-transform:uppercase; color:var(--bone-white); }
.ch-badge::before{ content:""; width:8px; height:8px; border-radius:50%;
  background:var(--accent); box-shadow:0 0 10px 2px rgba(197,250,193,.6); }

@keyframes ch-spin{ to{ transform:rotate(-18deg) scaleY(.5) rotate(360deg); } }

@media (max-width:980px){
  .coach-hero{ min-height:auto; flex-direction:column; align-items:stretch; }
  .ch-orb{ position:relative; right:auto; top:auto; transform:none;
    width:clamp(210px,58vw,290px); margin:38px auto 10px; }
}
@media (prefers-reduced-motion:reduce){
  .ch-track{ animation:none; }
}

/* ===== Contact page: signal-beacon hero (no photo, no form) ===== */
.contact-hero{ display:flex; align-items:center; text-align:center;
  min-height:clamp(420px,56vh,560px);
  background:
    radial-gradient(48% 60% at 50% 44%, rgba(34,66,33,.4), transparent 62%),
    var(--void-black); }
.contact-hero .page-hero-inner{ max-width:720px; margin-inline:auto; }
.contact-hero .hero-actions, .contact-hero .breadcrumbs{ justify-content:center; }
.ch2-sky{ position:absolute; inset:0; z-index:0; overflow:hidden; }
/* signal beacon — pinging transmission rings emanating from a bright core */
.ch2-beacon{ position:absolute; top:48%; left:15%; transform:translate(-50%,-50%);
  width:clamp(320px,46vw,600px); aspect-ratio:1; }
.ch2-core{ position:absolute; top:50%; left:50%; width:11px; height:11px; margin:-5.5px 0 0 -5.5px;
  border-radius:50%; background:var(--accent); box-shadow:0 0 22px 5px rgba(197,250,193,.7); }
.ch2-ping{ position:absolute; inset:0; border-radius:50%; border:1.5px solid rgba(197,250,193,.5);
  opacity:0; transform:scale(.06); animation:ch2-ping 4.2s ease-out infinite; }
.ch2-ping:nth-child(2){ animation-delay:1.4s; }
.ch2-ping:nth-child(3){ animation-delay:2.8s; }
@keyframes ch2-ping{ 0%{ transform:scale(.06); opacity:0; } 14%{ opacity:.5; } 100%{ transform:scale(1); opacity:0; } }

@media (prefers-reduced-motion:reduce){
  .ch2-ping{ animation:none; opacity:.16; }
  .ch2-ping:nth-child(1){ transform:scale(.42); }
  .ch2-ping:nth-child(2){ transform:scale(.7); }
  .ch2-ping:nth-child(3){ transform:scale(1); }
}

/* ---------- Grid + cards ---------- */
.grid{ display:grid; gap:24px; }
.g-2{ grid-template-columns:repeat(2,1fr); }
.g-3{ grid-template-columns:repeat(3,1fr); }
.g-4{ grid-template-columns:repeat(4,1fr); }

.card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:32px; transition:.35s var(--ease); position:relative; overflow:hidden; }
.card:hover{ transform:translateY(-5px); border-color:rgba(197,250,193,.4); }
.card:hover::after{ content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  box-shadow:0 26px 54px rgba(0,0,0,.5); }
.card .ic{ width:52px; height:52px; display:grid; place-items:center; border-radius:10px;
  background:rgba(197,250,193,.10); color:var(--accent); margin-bottom:20px; }
.card .ic svg{ width:26px; height:26px; }
.card h3{ margin-bottom:12px; }
.card p{ font-size:.96rem; }

/* Program / feature card with image */
.feature-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; transition:.35s var(--ease); display:flex; flex-direction:column; }
.feature-card:hover{ transform:translateY(-5px); border-color:rgba(197,250,193,.4); box-shadow:0 26px 54px rgba(0,0,0,.5); }
.feature-card .img{ position:relative; aspect-ratio:4/3; overflow:hidden; }
.feature-card .img img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.3) contrast(1.03); transition:.6s var(--ease); }
.feature-card:hover .img img{ transform:scale(1.05); filter:grayscale(0); }
.feature-card .img::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 50%,rgba(0,1,0,.55)); }
.feature-card .img .tag{ position:absolute; top:14px; left:14px; z-index:1; background:var(--accent); color:var(--accent-ink);
  font-family:var(--font-display); font-weight:700; font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; padding:6px 12px; border-radius:999px; }
.feature-card .body{ padding:28px; display:flex; flex-direction:column; flex:1; }
.feature-card .body h3{ margin-bottom:10px; }
.feature-card .body p{ font-size:.95rem; flex:1; }
.feature-card .body .link{ margin-top:18px; font-family:var(--font-display); font-weight:700; font-size:.8rem; letter-spacing:.1em;
  text-transform:uppercase; color:var(--accent); display:inline-flex; gap:8px; align-items:center; }
.feature-card:hover .body .link .arr{ transform:translateX(5px); }
.feature-card .body .link .arr{ transition:.35s var(--ease); }

/* ---------- Split section ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,72px); align-items:center; }
.split.rev .split-media{ order:2; }
.split-media{ position:relative; }
.split-media img{ border-radius:var(--radius); width:100%; object-fit:cover; filter:contrast(1.03); }
.split-media .frame{ position:absolute; inset:-12px -12px auto auto; width:110px; height:110px;
  border-top:2px solid var(--accent); border-right:2px solid var(--accent); border-radius:0 10px 0 0;
  opacity:.55; pointer-events:none; }
.split-media .badge{ position:absolute; bottom:-20px; left:-20px; background:var(--accent); color:var(--accent-ink);
  padding:18px 22px; border-radius:10px; max-width:210px; }
.split-media .badge b{ font-family:var(--font-display); font-weight:800; font-size:1.8rem; display:block; line-height:1; color:var(--accent-ink); }
.split-media .badge span{ font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; font-weight:600; }
.prose{ max-width:720px; }
.prose p + p{ margin-top:18px; }
.prose .lead{ margin-bottom:20px; }

/* Checklist */
.checklist{ display:grid; gap:14px; margin:24px 0; }
.checklist li{ display:flex; gap:14px; align-items:flex-start; color:var(--text-dim); }
.checklist li svg{ flex-shrink:0; width:22px; height:22px; color:var(--accent); margin-top:3px; }
.checklist li b{ display:block; color:var(--text); }

/* ---------- Reviews ---------- */
.reviews{ position:relative; }
.reviews-track-wrap{ 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); }
.reviews-track{ display:flex; gap:22px; width:max-content; animation:marquee 64s linear infinite; }
.reviews-track:hover{ animation-play-state:paused; }
@keyframes marquee{ to{ transform:translateX(-50%); } }
.review-card{ width:380px; flex-shrink:0; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius); padding:28px; display:flex; flex-direction:column; gap:14px; }
.review-card .stars{ color:var(--accent); letter-spacing:3px; font-size:1rem; }
.review-card p{ font-size:.95rem; color:var(--text-dim); flex:1; line-height:1.6; }
.review-card .who{ display:flex; align-items:center; gap:12px; margin-top:4px; }
.review-card .who .av{ width:42px; height:42px; border-radius:50%; background:var(--deep-ring);
  color:var(--planet-mint); display:grid; place-items:center; font-weight:800; font-family:var(--font-display); font-size:1rem;
  border:1px solid rgba(197,250,193,.3); }
.review-card .who b{ font-size:.92rem; display:block; color:var(--texas-canvas); font-weight:600; }
.review-card .who span{ font-size:.74rem; color:var(--text-mute); }
.review-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.review-grid .review-card{ width:auto; }

/* Big featured quote */
.quote-feature{ position:relative; text-align:center; max-width:920px; margin-inline:auto; padding:0 20px; }
.quote-feature .mark{ font-family:var(--font-display); font-weight:800; font-size:6rem; line-height:.6; color:var(--accent); opacity:.7; }
.quote-feature blockquote{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; line-height:1.1;
  font-size:clamp(1.4rem,3.2vw,2.4rem); margin:14px 0 22px; }
.quote-feature cite{ font-style:normal; font-family:var(--font-display); font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  font-size:.82rem; color:var(--texas-canvas); }

/* ---------- Schedule ---------- */
.sched{ display:grid; grid-template-columns:repeat(6,1fr); gap:14px; }
.sched-day{ background:var(--surface); border:1px solid var(--line); border-radius:10px; overflow:hidden; transition:.3s var(--ease); }
.sched-day:hover{ border-color:rgba(197,250,193,.4); transform:translateY(-4px); }
.sched-day h4{ font-family:var(--font-display); font-weight:700; background:rgba(197,250,193,.06); padding:15px;
  text-align:center; letter-spacing:.06em; color:var(--accent); border-bottom:1px solid var(--line); }
.sched-day .slots{ padding:14px; display:flex; flex-direction:column; gap:16px; min-height:120px; }
.slot .t{ font-family:var(--font-display); font-weight:700; font-size:1.05rem; color:var(--text); letter-spacing:.01em; margin-bottom:6px; }
/* class-type badges per brand schedule label system */
.cls{ display:inline-block; font-family:var(--font-display); font-weight:600; font-size:.68rem; letter-spacing:.08em;
  text-transform:uppercase; padding:4px 10px; border-radius:999px; border:1px solid transparent; }
.cls-nogi{ color:var(--planet-mint); border-color:rgba(197,250,193,.5); background:rgba(197,250,193,.06); }
.cls-kids{ color:var(--texas-canvas); border-color:rgba(216,203,167,.5); background:rgba(216,203,167,.07); }
.cls-open{ color:var(--orbit-green); border-color:rgba(110,138,109,.6); background:rgba(110,138,109,.08); }
.cls-fund{ color:var(--soft-mint); border-color:rgba(231,255,227,.45); background:rgba(231,255,227,.05); }
.slot.empty{ color:var(--text-mute); font-size:.82rem; font-style:italic; }
.legend{ display:flex; flex-wrap:wrap; gap:18px; margin-top:26px; justify-content:center; }
.legend span{ display:inline-flex; align-items:center; gap:8px; font-size:.84rem; color:var(--text-dim); }
.legend span svg{ width:18px; height:18px; color:var(--accent); }
.legend .chip{ display:inline-flex; align-items:center; gap:8px; }

/* ---------- Membership ---------- */
.price-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:28px; max-width:900px; margin-inline:auto; }
.price-card{ position:relative; background:var(--surface); border:1px solid var(--line); border-radius:14px;
  padding:40px; transition:.35s var(--ease); overflow:hidden; }
.price-card:hover{ transform:translateY(-5px); border-color:rgba(197,250,193,.45); }
.price-card.featured{ border-color:var(--accent); box-shadow:0 0 0 1px rgba(197,250,193,.35); }
.price-card.featured::before{ content:"BEST VALUE"; position:absolute; top:20px; right:-40px; transform:rotate(45deg);
  background:var(--accent); color:var(--accent-ink); font-family:var(--font-display); font-weight:700; font-size:.64rem; letter-spacing:.1em;
  padding:6px 46px; }
.price-card .plan{ font-family:var(--font-display); font-weight:700; letter-spacing:.1em; text-transform:uppercase; font-size:.82rem; color:var(--accent); }
.price-card .price{ font-family:var(--font-display); font-weight:800; font-size:3.4rem; line-height:1; margin:16px 0 6px; }
.price-card .price small{ font-family:var(--font-body); font-size:1rem; color:var(--text-mute); font-weight:500; }
.price-card .sub{ font-size:.9rem; color:var(--text-dim); margin-bottom:22px; }
.price-card .checklist{ margin:22px 0 28px; }
.founding-note{ max-width:760px; margin:34px auto 0; text-align:center; font-size:.92rem; color:var(--text-dim);
  border:1px solid var(--line); background:rgba(216,203,167,.04); border-radius:10px; padding:18px 22px; }
.founding-note b{ color:var(--accent); }

/* ---------- CTA band ---------- */
.cta-band{ position:relative; overflow:hidden; }
.cta-band .container{ position:relative; z-index:2; text-align:center; }
.cta-band::before{ content:""; position:absolute; inset:0; background:
  radial-gradient(60% 120% at 50% 0%, rgba(197,250,193,.13), transparent 60%); }
.cta-band h2{ margin-bottom:18px; }
.cta-band .hero-actions{ justify-content:center; animation:none; opacity:1; }

/* ---------- Contact / form ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:stretch; }
.field{ margin-bottom:18px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:0 14px; }
@media (max-width:480px){ .field-row{ grid-template-columns:1fr; } }
.field label{ display:block; font-family:var(--font-display); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--text-dim); margin-bottom:8px; font-weight:600; }
.field input, .field select, .field textarea{
  width:100%; background:var(--mat-charcoal); border:1px solid var(--line); border-radius:8px;
  padding:14px 16px; color:var(--text); font-family:var(--font-body); font-size:.96rem; transition:.25s; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--accent); background:rgba(197,250,193,.05); }
.field textarea{ resize:vertical; min-height:120px; }
.info-row{ display:flex; gap:16px; align-items:flex-start; padding:20px 0; border-bottom:1px solid var(--line-2); }
.info-row svg{ flex-shrink:0; width:24px; height:24px; color:var(--accent); margin-top:2px; }
.info-row b{ display:block; font-family:var(--font-display); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-mute); margin-bottom:4px; font-weight:600; }
.info-row a, .info-row p{ color:var(--text); font-size:1.02rem; }
.info-row a:hover{ color:var(--accent); }
.form-note{ font-size:.82rem; color:var(--text-mute); margin-top:6px; }
.form-success{ display:none; background:rgba(197,250,193,.1); border:1px solid var(--accent); color:var(--accent);
  border-radius:8px; padding:16px; margin-bottom:18px; font-size:.9rem; }
.form-success.show{ display:block; }

/* ---------- Map ---------- */
.map-wrap{ position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); }
.map-wrap iframe{ display:block; width:100%; height:420px; border:0; filter:grayscale(.6) invert(.92) contrast(.85) hue-rotate(150deg); }
.map-wrap.tall iframe{ height:100%; min-height:480px; }

/* ---------- Footer ---------- */
.site-footer{ position:relative; z-index:1; background:var(--mat-charcoal); border-top:1px solid var(--line); padding:70px 0 30px; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:40px; }
.footer-grid h4{ font-family:var(--font-display); font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  font-size:.78rem; color:var(--text-mute); margin-bottom:18px; }
.footer-grid a{ display:block; color:var(--text-dim); padding:6px 0; font-size:.92rem; transition:.2s; }
.footer-grid a:hover{ color:var(--accent); }
.footer-brand img{ height:62px; margin-bottom:18px; }
.footer-brand p{ font-size:.92rem; max-width:300px; }
.socials{ display:flex; gap:12px; margin-top:20px; }
.socials a{ width:42px; height:42px; display:grid; place-items:center; border:1px solid var(--line);
  border-radius:8px; color:var(--text-dim); transition:.3s var(--ease); }
.socials a:hover{ border-color:var(--accent); color:var(--accent); transform:translateY(-3px); }
.socials svg{ width:20px; height:20px; }
.footer-bottom{ display:flex; flex-wrap:wrap; gap:12px; justify-content:space-between; align-items:center;
  margin-top:54px; padding-top:24px; border-top:1px solid var(--line-2); font-size:.8rem; color:var(--text-mute); }
.footer-bottom a:hover{ color:var(--accent); }

/* ---------- Schedule (timetable v2) ---------- */
.sched-filters{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-bottom:34px; }
.sched-filter{ display:inline-flex; align-items:center; gap:8px; font-family:var(--font-display); font-weight:600;
  font-size:.76rem; letter-spacing:.08em; text-transform:uppercase; color:var(--text-dim);
  background:transparent; border:1px solid var(--line); border-radius:999px; padding:9px 16px; cursor:pointer;
  transition:.25s var(--ease); }
.sched-filter:hover{ color:var(--text); border-color:var(--accent); }
.sched-filter.active{ color:var(--accent-ink); background:var(--accent); border-color:var(--accent); }
.sched-filter .dot{ width:9px; height:9px; border-radius:50%; flex-shrink:0; }
.dot-nogi{ background:var(--planet-mint); } .dot-fund{ background:var(--soft-mint); }
.dot-kids{ background:var(--texas-canvas); } .dot-open{ background:var(--orbit-green); }

.sched2{ display:grid; grid-template-columns:repeat(6,1fr); gap:14px; align-items:start; }
.sched2-day{ background:var(--surface); border:1px solid var(--line); border-radius:12px; overflow:hidden;
  display:flex; flex-direction:column; transition:border-color .3s var(--ease), transform .3s var(--ease), box-shadow .3s; }
.sched2-day:hover{ border-color:rgba(197,250,193,.35); transform:translateY(-4px); }
.sched2-day.is-today{ border-color:var(--accent); box-shadow:0 0 0 1px rgba(197,250,193,.4), 0 20px 50px rgba(0,0,0,.4); }
.sday-head{ position:relative; padding:14px; text-align:center; border-bottom:1px solid var(--line); background:rgba(197,250,193,.05); }
.sday-name{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:.05em; font-size:.92rem; color:var(--text); }
.sched2-day.is-today .sday-head{ background:rgba(197,250,193,.12); }
.sched2-day.is-today .sday-name{ color:var(--accent); }
.today-pill{ position:absolute; top:8px; right:8px; font-family:var(--font-display); font-weight:700; font-size:.52rem;
  letter-spacing:.12em; text-transform:uppercase; background:var(--accent); color:var(--accent-ink); padding:3px 7px; border-radius:999px; }
.sday-slots{ padding:12px; display:flex; flex-direction:column; gap:10px; flex:1; min-height:70px; }
.slot2{ position:relative; padding:11px 12px 11px 14px; border-radius:9px; background:var(--bg-2);
  border:1px solid var(--line-2); border-left:3px solid var(--accent); transition:.25s var(--ease); }
.slot2[data-type="nogi"]{ border-left-color:var(--planet-mint); }
.slot2[data-type="fund"]{ border-left-color:var(--soft-mint); }
.slot2[data-type="kids"]{ border-left-color:var(--texas-canvas); }
.slot2[data-type="open"]{ border-left-color:var(--orbit-green); }
.slot2:hover{ transform:translateX(2px); border-color:rgba(197,250,193,.3); background:rgba(197,250,193,.05); }
.slot2-time{ display:block; font-family:var(--font-display); font-weight:700; font-size:.9rem; color:var(--text); letter-spacing:.01em; }
.slot2-name{ display:block; font-size:.76rem; color:var(--text-dim); margin-top:3px; }
.slot2.dimmed{ opacity:.16; filter:saturate(.3); }
.sched-note{ display:flex; align-items:center; gap:8px; justify-content:center; text-align:center;
  color:var(--text-dim); font-size:.85rem; margin-top:26px; }
.sched-note svg{ width:18px; height:18px; color:var(--accent); flex-shrink:0; }
@media (max-width:1024px){ .sched2{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:640px){ .sched2{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:430px){ .sched2{ grid-template-columns:1fr; } }

/* ---------- Booking page ---------- */
#book{ scroll-margin-top:96px; }   /* land below the fixed header on anchor jump */
.booking-toggle{ display:flex; gap:8px; justify-content:center; margin-bottom:30px; }
.booking-tab{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:.08em;
  font-size:.84rem; padding:12px 30px; border-radius:999px; border:1px solid var(--line);
  background:transparent; color:var(--text-dim); cursor:pointer; transition:.25s var(--ease); }
.booking-tab:hover{ color:var(--text); border-color:var(--accent); }
.booking-tab.active{ background:var(--cta); color:var(--cta-ink); border-color:var(--cta); }
.booking-cal{ max-width:920px; margin:0 auto; background:var(--surface); border:1px solid var(--line);
  border-radius:14px; overflow:hidden; padding:10px; }
.booking-cal iframe{ width:100%; min-height:740px; border:0; display:block; overflow:hidden; }
.booking-cal[hidden]{ display:none; }

/* ---------- Free-trial modal ---------- */
.modal-overlay{ position:fixed; inset:0; z-index:2000; display:flex; align-items:center; justify-content:center;
  padding:20px; background:rgba(0,1,0,.74); backdrop-filter:blur(6px);
  opacity:0; visibility:hidden; transition:opacity .35s var(--ease), visibility .35s; }
.modal-overlay.open{ opacity:1; visibility:visible; }
.modal{ position:relative; width:100%; max-width:560px; max-height:92vh; overflow-y:auto;
  background:var(--mat-charcoal); border:1px solid var(--line); border-radius:16px;
  padding:clamp(26px,4vw,40px); box-shadow:0 40px 110px rgba(0,0,0,.65);
  transform:translateY(22px) scale(.98); transition:transform .4s var(--ease); }
.modal-overlay.open .modal{ transform:none; }
.modal-close{ position:absolute; top:14px; right:14px; width:38px; height:38px; display:grid; place-items:center;
  background:transparent; border:1px solid var(--line); border-radius:9px; color:var(--text-dim); cursor:pointer; transition:.25s; }
.modal-close:hover{ border-color:var(--accent); color:var(--accent); }
.modal-close svg{ width:18px; height:18px; }
.modal h3{ margin:8px 0 6px; }
.modal .modal-sub{ color:var(--text-dim); font-size:.95rem; margin-bottom:22px; }
.modal .field label .req{ color:var(--accent); }
.opt-label{ display:block; font-family:var(--font-display); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--text-dim); margin:4px 0 10px; font-weight:600; }
.opt-grid{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:20px; }
.opt{ position:relative; }
.opt input{ position:absolute; inset:0; opacity:0; cursor:pointer; margin:0; }
.opt span{ display:flex; align-items:center; gap:9px; padding:13px 14px; border:1px solid var(--line);
  border-radius:10px; font-family:var(--font-display); font-weight:600; font-size:.82rem; letter-spacing:.04em;
  text-transform:uppercase; color:var(--text-dim); cursor:pointer; transition:.2s; height:100%; }
.opt span::before{ content:""; width:14px; height:14px; border-radius:50%; border:2px solid var(--line); flex-shrink:0; transition:.2s; }
.opt input:checked + span{ border-color:var(--accent); color:var(--accent); background:rgba(197,250,193,.08); }
.opt input:checked + span::before{ border-color:var(--accent); background:var(--accent); box-shadow:inset 0 0 0 3px var(--mat-charcoal); }
.opt input:focus-visible + span{ outline:2px solid var(--accent); outline-offset:2px; }
@media (max-width:480px){ .opt-grid{ grid-template-columns:1fr; } }

/* ---------- Scroll reveal ---------- */
[data-reveal]{ opacity:0; transform:translateY(32px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal][data-delay="1"]{ transition-delay:.08s; }
[data-reveal][data-delay="2"]{ transition-delay:.16s; }
[data-reveal][data-delay="3"]{ transition-delay:.24s; }
[data-reveal][data-delay="4"]{ transition-delay:.32s; }
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; }
  [data-reveal]{ opacity:1; transform:none; }
  .hero h1 .line>span{ transform:none; }
}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .footer-grid{ grid-template-columns:1fr 1fr; gap:34px; }
  .sched{ grid-template-columns:repeat(3,1fr); }
  .g-4{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:880px){
  :root{ --header-h:78px; }
  .nav-links, .nav-cta{ display:none; }
  .burger{ display:flex; }
  .split{ grid-template-columns:1fr; }
  .split.rev .split-media{ order:0; }
  .split-media .badge{ left:14px; bottom:14px; }
  .contact-grid{ grid-template-columns:1fr; gap:34px; }
  .review-grid{ grid-template-columns:1fr; }
}
@media (max-width:640px){
  body{ font-size:16px; }
  .g-2, .g-3, .g-4, .price-grid{ grid-template-columns:1fr; }
  .sched{ grid-template-columns:repeat(2,1fr); }
  .footer-grid{ grid-template-columns:1fr; }
  .review-card{ width:300px; }
  .hero-meta{ display:none; }
  .scroll-cue{ display:none; }
  .price-card{ padding:30px 24px; }
}
@media (max-width:420px){
  .sched{ grid-template-columns:1fr; }
}
