/* ============================================================
   LIGHTNING NINJA ACADEMY · v3 — main stylesheet
   Consumes styles/tokens.css only. No one-off values.
   ============================================================ */

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  overflow-x: clip;
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

body {
  background: var(--ink);
  color: var(--bone);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-body);
  -webkit-font-smoothing: antialiased;
  overflow-x: clip;
}

img, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; }

::selection { background: var(--volt); color: var(--volt-ink); }

/* ---------- a11y primitives ---------- */
.visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  margin: -1px; padding: 0; border: 0;
  clip-path: inset(50%);
  overflow: hidden;
  white-space: nowrap;
}
.skip-link {
  position: fixed;
  top: var(--space-1); left: var(--space-1);
  z-index: 100;
  background: var(--volt);
  color: var(--volt-ink);
  font-weight: 700;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius);
  transform: translateY(-300%);
}
.skip-link:focus-visible { transform: none; }

:focus-visible {
  outline: 2px solid var(--volt);
  outline-offset: 3px;
  border-radius: var(--radius);
}

/* ---------- header ---------- */
.top {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 20;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-2) var(--gutter);
  transition: background var(--dur-fast) var(--ease-out);
}
.top.is-scrolled { background: var(--scrim-solid); backdrop-filter: blur(8px); }
.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  min-height: var(--tap-min);
  text-decoration: none;
}
.brand img { width: 34px; height: 36px; }
.brand span {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-base);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
}
.top-call {
  display: inline-flex;
  align-items: center;
  min-height: var(--tap-min);
  font-size: var(--text-sm);
  font-weight: 700;
  text-decoration: none;
  border-bottom: 1px solid var(--hairline-strong);
  transition: border-color var(--dur-fast) var(--ease-out);
}
.top-call:hover { border-color: var(--bone); }

/* ---------- shared beat plumbing ---------- */
.beat-inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: var(--space-5) var(--gutter);
}
.kicker {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--grey);
  margin-bottom: var(--space-2);
}
.display {
  font-family: var(--font-display);
  font-weight: 800;
  text-transform: uppercase;
  line-height: var(--leading-tight);
  letter-spacing: 0.005em;
  text-wrap: balance;
}
.display-md { font-size: var(--text-2xl); max-width: 14ch; }
.sub {
  margin-top: var(--space-2);
  max-width: var(--measure);
  font-size: var(--text-md);
  text-wrap: pretty;
}
.meta {
  margin-top: var(--space-2);
  font-size: var(--text-sm);
  color: var(--grey);
}
.volt-mark { color: var(--volt); }

/* media beats: full-bleed picture + scrim + content pinned low */
.media-beat {
  position: relative;
  display: flex;
  align-items: flex-end;
  min-height: 92svh;
  overflow: hidden;
  background: var(--ink-2); /* honest fallback while media loads / if broken */
}
.media-beat .media,
.media-beat .media img,
.media-beat video.media {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.media-beat .scrim {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    var(--scrim-solid) 0%,
    var(--scrim-solid) 22%,
    var(--scrim-mid) 48%,
    var(--scrim-thin) 78%,
    var(--scrim-mid) 100%
  );
}

/* ---------- buttons & text links ---------- */
.cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-3);
  align-items: center;
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--tap-min);
  padding: 0.85rem 1.7rem;
  border-radius: var(--radius);
  text-decoration: none;
  font-weight: 700;
  font-size: var(--text-base);
  letter-spacing: 0.02em;
  transition: transform var(--dur-med) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
}
.btn:hover { transform: translateY(-2px); }
.btn-volt { background: var(--volt); color: var(--volt-ink); }
.btn-ghost { border: 1px solid var(--hairline-strong); color: var(--bone); font-weight: 500; }
.btn-ghost:hover { border-color: var(--bone); }
.link-volt {
  display: inline-flex;
  align-items: center;
  min-height: var(--tap-min);
  margin-top: var(--space-3);
  text-decoration: none;
  font-weight: 700;
  font-size: var(--text-base);
  color: var(--volt);
  border-bottom: 2px solid var(--volt);
}
.link-quiet {
  color: var(--bone);
  text-decoration: none;
  border-bottom: 1px solid var(--hairline-strong);
  transition: border-color var(--dur-fast) var(--ease-out);
}
.link-quiet:hover { border-color: var(--bone); }

/* ============================================================
   BEAT 1 · HERO
   ============================================================ */
.hero { min-height: 100svh; }
.hero h1 { font-size: var(--text-3xl); max-width: 12ch; }
.hero .beat-inner { padding-top: var(--space-6); }
.hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-3);
  margin-top: var(--space-4);
  padding-top: var(--space-2);
  border-top: 1px solid var(--hairline);
  font-size: var(--text-sm);
  color: var(--grey);
}

/* ============================================================
   BEAT 2 · PILLARS (kinetic type)
   ============================================================ */
.pillars {
  background: var(--ink);
  padding: var(--space-6) 0;
}
.marquee {
  overflow: hidden;
  white-space: nowrap;
  border-top: 1px solid var(--hairline);
  padding: clamp(0.6rem, 1.4vw, 1.2rem) 0;
}
.marquee:last-of-type { border-bottom: 1px solid var(--hairline); }
.marquee .track {
  display: inline-flex;
  will-change: transform;
  animation: slide var(--dur-marquee) linear infinite;
}
.marquee.rev .track {
  animation-name: slide-rev;
  animation-duration: calc(var(--dur-marquee) * 1.2);
}
.marquee .track span {
  font-family: var(--font-display);
  font-weight: 800;
  text-transform: uppercase;
  font-size: var(--text-marquee);
  line-height: 1;
  padding-right: 0.55em;
}
.marquee .track .ghost {
  color: transparent;
  -webkit-text-stroke: 1.5px var(--hairline-strong);
}
.marquee .track .volt-row { color: var(--volt); }
@keyframes slide { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes slide-rev { from { transform: translateX(-50%); } to { transform: translateX(0); } }

.pillars-static { display: none; }

.pillars-captions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-4);
  max-width: var(--max-w);
  margin: var(--space-4) auto 0;
  padding: 0 var(--gutter);
  list-style: none;
}
.pillars-captions li {
  font-size: var(--text-sm);
  color: var(--grey);
  max-width: 24ch;
}
.pillars-captions strong {
  display: block;
  color: var(--bone);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-base);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  margin-bottom: calc(var(--space-1) / 2);
}

/* reduced motion: kill marquees, show static stacked words */
@media (prefers-reduced-motion: reduce) {
  .marquee { display: none; }
  .pillars-static {
    display: block;
    list-style: none;
    max-width: var(--max-w);
    margin: 0 auto;
    padding: 0 var(--gutter);
  }
  .pillars-static li {
    font-family: var(--font-display);
    font-weight: 800;
    text-transform: uppercase;
    font-size: var(--text-2xl);
    line-height: 1.05;
    padding: var(--space-1) 0;
    border-top: 1px solid var(--hairline);
  }
  .pillars-static li:last-child { border-bottom: 1px solid var(--hairline); }
  .pillars-static li:nth-child(2) { color: var(--volt); }
}

/* ============================================================
   BEAT 3 · CLASSES — portrait media sits right on desktop
   ============================================================ */
.classes .media img { object-position: center 22%; }

/* ============================================================
   BEAT 4 · PARTIES
   ============================================================ */
.parties .media img { object-position: center 30%; }
@media (max-width: 700px) {
  /* keep the kid on the truss in frame when the wide shot crops to portrait */
  .parties .media img { object-position: 74% 30%; }
}

/* ============================================================
   BEAT 5 · CAMPS (type-only)
   ============================================================ */
.camps { background: var(--ink-2); }
.camps .beat-inner { padding-block: var(--space-6); }
.camp-dates {
  list-style: none;
  margin-top: var(--space-3);
}
.camp-dates li {
  font-family: var(--font-display);
  font-weight: 800;
  text-transform: uppercase;
  font-size: var(--text-2xl);
  line-height: 1.08;
  border-top: 1px solid var(--hairline);
  padding: var(--space-1) 0;
}
.camp-dates li:last-child { border-bottom: 1px solid var(--hairline); }

/* ============================================================
   BEAT 6 · PROOF (rotating review over team photo)
   ============================================================ */
.proof { min-height: 92svh; }
.proof .media img { object-position: center 35%; }
.proof .scrim {
  /* quote sits mid-frame over faces/lights — keep this band heavier than the default gradient */
  background: linear-gradient(
    to top,
    var(--scrim-solid) 0%,
    var(--scrim-solid) 26%,
    var(--scrim-heavy) 62%,
    var(--scrim-mid) 100%
  );
}
.rotator {
  position: relative;
  min-height: 11em; /* fits the longest quote at --text-lg on 320px wide */
  max-width: 34ch;
}
.rotator figure {
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  margin: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--dur-slow) var(--ease-out), visibility 0s linear var(--dur-slow);
}
.rotator figure.is-active {
  opacity: 1;
  visibility: visible;
  transition: opacity var(--dur-slow) var(--ease-out);
}
.rotator blockquote p {
  font-size: var(--text-lg);
  font-weight: 500;
  line-height: 1.4;
  text-wrap: pretty;
}
.rotator figcaption {
  margin-top: var(--space-1);
  font-size: var(--text-sm);
  color: var(--grey);
}
.proof-trust {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-3);
  margin-top: var(--space-4);
  padding-top: var(--space-2);
  border-top: 1px solid var(--hairline);
  font-size: var(--text-sm);
  color: var(--grey);
}
.proof-trust .link-quiet { color: var(--bone); }
@media (prefers-reduced-motion: reduce) {
  .rotator figure { transition: none; }
}

/* ============================================================
   BEAT 7 · VISIT
   ============================================================ */
.visit { background: var(--ink); }
.visit .beat-inner { padding-block: var(--space-6); }
.visit-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
  gap: var(--space-4) var(--space-5);
  align-items: start;
}
.visit address {
  font-style: normal;
  font-family: var(--font-display);
  font-weight: 700;
  text-transform: uppercase;
  font-size: var(--text-xl);
  line-height: var(--leading-snug);
}
.visit-hours {
  margin-top: var(--space-2);
  font-size: var(--text-md);
  color: var(--bone);
}
.visit-hours span { color: var(--grey); }
.visit-actions { display: flex; flex-direction: column; gap: var(--space-2); align-items: flex-start; }
.visit-actions .btn { width: 100%; max-width: 22rem; }
.visit-note {
  grid-column: 1 / -1;
  margin-top: var(--space-2);
  padding-top: var(--space-2);
  border-top: 1px solid var(--hairline);
  font-size: var(--text-sm);
  color: var(--grey);
  max-width: 60ch;
}
.visit-note a { color: var(--bone); }

/* ============================================================
   BEAT 8 · FINAL CTA + FOOTER
   ============================================================ */
.book { background: var(--ink-2); text-align: center; }
.book .beat-inner { padding-block: var(--space-6); }
.book h2 { font-size: var(--text-3xl); margin-inline: auto; max-width: 10ch; }
.book .sub { margin-inline: auto; }
.book .cta-row { justify-content: center; }

footer {
  background: var(--ink);
  border-top: 1px solid var(--hairline);
  padding: var(--space-4) var(--gutter);
}
.foot-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
}
.foot-brand { display: inline-flex; align-items: center; gap: 0.7rem; }
.foot-brand img { width: 30px; height: 32px; }
.foot-brand span {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--text-sm);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
}
.foot-nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1) var(--space-3);
  list-style: none;
}
.foot-nav a {
  display: inline-flex;
  align-items: center;
  min-height: var(--tap-min);
  font-size: var(--text-sm);
  text-decoration: none;
  color: var(--bone);
  border-bottom: 1px solid var(--hairline);
  transition: border-color var(--dur-fast) var(--ease-out);
}
.foot-nav a:hover { border-color: var(--bone); }
.foot-legal {
  width: 100%;
  font-size: var(--text-xs);
  color: var(--grey);
}

/* ---------- reveal: JS-added enhancement only ---------- */
.will-reveal { opacity: 0; transform: translateY(26px); }
.will-reveal.revealed {
  opacity: 1;
  transform: none;
  transition: opacity var(--dur-slow) var(--ease-out), transform var(--dur-slow) var(--ease-out);
}

/* ---------- waiver page ---------- */
.waiver-page .beat-inner { padding-top: calc(var(--space-5) + var(--tap-min)); }
.waiver-page h1 { font-size: var(--text-2xl); }
.embed-frame {
  width: 100%;
  border: 0;
  margin-top: var(--space-3);
  background: var(--bone);
  border-radius: var(--radius);
}

/* ---------- 404 ---------- */
.page-404 { min-height: 100svh; display: flex; align-items: center; text-align: center; }
.page-404 h1 { font-size: var(--text-3xl); margin-inline: auto; }
.page-404 .sub { margin-inline: auto; }
.page-404 .cta-row { justify-content: center; }

/* ---------- responsive ---------- */
@media (max-width: 860px) {
  .visit-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .brand span { display: none; }
  .btn { width: 100%; }
  .cta-row { flex-direction: column; align-items: stretch; }
  .book .cta-row { align-items: center; }
}

/* ---------- reduced motion: global ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .btn:hover { transform: none; }
}
