/* =====================================================================
   SuiSport ONE — Tokyo fight-night editorial
   Spec: .impeccable.md (Design Context). Aesthetic direction: red-dominant
   editorial / sports-broadcast, monumental type, gold-only-when-earning,
   fight-night cadence (punch / breathe / punch), photo-first.
   ===================================================================== */

/* ---------------------------------------------------------------------
   Tokens
   --------------------------------------------------------------------- */

:root {
  /* Neutrals — warm-tinted toward the brand red. Never pure #000/#fff. */
  --ink-bg:     oklch(12.5% 0.014 25);
  --ink-bg-2:   oklch(17%   0.016 25);
  --ink-bg-3:   oklch(22%   0.012 25);
  --ink-line:   oklch(28%   0.012 25);
  --ink-line-2: oklch(40%   0.014 25);

  --white:      oklch(96%   0.006 60);
  --white-soft: oklch(85%   0.008 30);
  --white-dim:  oklch(62%   0.010 25);
  --white-faint:oklch(45%   0.012 25);

  /* Brand. Red leads everything. Gold = earning only. */
  --red:        oklch(57%   0.215 25);     /* #f44436-ish, ONE crimson */
  --red-deep:   oklch(36%   0.180 25);
  --red-darker: oklch(22%   0.130 25);
  --red-pale:   oklch(82%   0.090 18);     /* the OG's headline pink */
  --red-glow:   oklch(70%   0.200 18);

  --gold:       oklch(83%   0.160 88);     /* ONE belt #facb00 */
  --gold-deep:  oklch(60%   0.140 78);

  /* Type system. Anton (display sports-poster condensed grotesque) +
     Manrope (body, designed sans w/ character) +
     DM Serif Display Italic (third voice for fighter names + pull quotes). */
  --ff-display: 'Anton', 'Roboto Condensed', 'Arial Narrow', sans-serif;
  --ff-body:    'Manrope', 'Helvetica Neue', system-ui, sans-serif;
  --ff-italic:  'DM Serif Display', 'Times New Roman', serif;

  /* Type scale — monumental at the top, no comfortable middle. */
  --fs-mono-xl: clamp(3.5rem, 0.5rem + 14vw, 16rem);   /* SP counter, CTA */
  --fs-mono:    clamp(3rem,   1rem + 10vw, 13rem);     /* hero, manifesto */
  --fs-h2:      clamp(2.5rem, 1.2rem + 5vw, 6rem);
  --fs-h3:      clamp(1.5rem, 1.1rem + 1.4vw, 2.25rem);
  --fs-lede:    clamp(1.15rem, 0.95rem + 0.7vw, 1.5rem);
  --fs-body:    clamp(1rem, 0.95rem + 0.2vw, 1.0625rem);
  --fs-meta:    clamp(0.78rem, 0.72rem + 0.2vw, 0.85rem);

  /* Spacing cadence — varied, never uniform. */
  --gutter:     clamp(1.25rem, 0.5rem + 3vw, 3.5rem);
  --pad-tight:  clamp(2rem, 1rem + 3vw, 4rem);
  --pad-room:   clamp(4rem, 2rem + 6vw, 8rem);
  --pad-room-x: clamp(6rem, 3rem + 10vw, 14rem);

  /* Motion. Exponential easing only. */
  --ease-out:   cubic-bezier(0.16, 1, 0.3, 1);     /* expo */
  --ease-quart: cubic-bezier(0.25, 1, 0.5, 1);
}

/* ---------------------------------------------------------------------
   Reset / base
   --------------------------------------------------------------------- */

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

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  scroll-padding-top: 88px;
  background: var(--ink-bg);
}

body {
  margin: 0;
  font-family: var(--ff-body);
  font-size: var(--fs-body);
  line-height: 1.55;
  color: var(--white);
  background: var(--ink-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: clip;
}

img, svg, video { display: block; max-width: 100%; }
ul, ol { padding: 0; margin: 0; list-style: none; }

a {
  color: inherit;
  text-decoration: none;
  text-underline-offset: 0.25em;
  transition: color 200ms var(--ease-out);
}

button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }

::selection { background: var(--red); color: var(--white); }

.skip {
  position: absolute;
  left: -9999px;
  top: 0;
  background: var(--red);
  color: var(--white);
  padding: 0.75rem 1rem;
  font-weight: 700;
  z-index: 100;
}
.skip:focus { left: 0; }

.visually-hidden {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

em { font-family: var(--ff-italic); font-style: italic; font-weight: 400; }

/* ---------------------------------------------------------------------
   Nav
   --------------------------------------------------------------------- */

.nav {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.25rem var(--gutter);
  transition: background 280ms var(--ease-out), border-color 280ms var(--ease-out);
  border-bottom: 1px solid transparent;
}
.nav.is-stuck {
  background: color-mix(in oklab, var(--ink-bg) 88%, transparent);
  backdrop-filter: blur(18px) saturate(150%);
  -webkit-backdrop-filter: blur(18px) saturate(150%);
  border-bottom-color: var(--ink-line);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  font-family: var(--ff-display);
  font-size: 1.2rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--white);
}
.brand-mark {
  width: 32px; height: 32px;
  border-radius: 7px;
  object-fit: cover;
}
.brand-sm .brand-mark { width: 22px; height: 22px; border-radius: 5px; }
.brand-one {
  color: var(--red);
  margin-left: 0.18em;
  letter-spacing: 0.02em;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.nav-links > a:not(.btn) {
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.10em;
  font-size: 0.85rem;
  padding: 0.5rem 0.9rem;
  color: var(--white-soft);
  border-radius: 4px;
  transition: color 180ms var(--ease-out);
}
.nav-links > a:not(.btn):hover { color: var(--red-glow); }

@media (max-width: 720px) {
  .nav-links > a:not(.btn-primary) { display: none; }
}

/* ---------------------------------------------------------------------
   Buttons
   --------------------------------------------------------------------- */

.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.85rem 1.25rem;
  border-radius: 4px;
  font-family: var(--ff-display);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  font-size: 0.92rem;
  white-space: nowrap;
  transition:
    background 200ms var(--ease-out),
    color 200ms var(--ease-out),
    transform 200ms var(--ease-quart);
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

.btn-primary {
  background: var(--red);
  color: var(--white);
  box-shadow:
    inset 0 1px 0 oklch(75% 0.20 25 / 0.5),
    0 12px 30px -12px oklch(57% 0.215 25 / 0.6);
}
.btn-primary:hover { background: var(--red-glow); }

.btn-lg {
  padding: 1rem 1.4rem;
  font-size: 1rem;
}

/* Inline text-link CTA — no chrome, just type + arrow */
.btn-text {
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.9rem;
  color: var(--white);
  border-bottom: 1px solid currentColor;
  padding-bottom: 0.15em;
  transition: color 180ms var(--ease-out), border-color 180ms var(--ease-out);
}
.btn-text:hover { color: var(--red-glow); border-color: var(--red-glow); }

/* ---------------------------------------------------------------------
   HERO
   --------------------------------------------------------------------- */

.hero {
  position: relative;
  min-height: 100vh;
  min-height: 100svh;
  padding: 9rem var(--gutter) 4rem;
  overflow: hidden;
  isolation: isolate;
  background:
    radial-gradient(80% 60% at 90% 20%, oklch(45% 0.20 25 / 0.55) 0%, transparent 70%),
    radial-gradient(60% 70% at 10% 90%, oklch(28% 0.16 25 / 0.55) 0%, transparent 70%),
    linear-gradient(180deg, oklch(11% 0.01 25) 0%, var(--ink-bg) 100%);
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  overflow: hidden;
}
.hero-bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0.32;
  filter: grayscale(0.3) contrast(1.1);
  mix-blend-mode: screen;
}
.hero::after {
  /* film grain — subtle, not at all kitsch */
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  opacity: 0.05;
  pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 1 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/></svg>");
}

/* Vertical katakana strip down the right edge */
.kana {
  position: absolute;
  top: clamp(7rem, 12vh, 10rem);
  right: clamp(0.75rem, 2vw, 1.75rem);
  display: grid;
  grid-auto-flow: row;
  gap: 0.4em;
  font-family: var(--ff-display);
  font-size: clamp(1rem, 0.5rem + 0.9vw, 1.4rem);
  color: var(--red-pale);
  opacity: 0.55;
  letter-spacing: -0.04em;
  writing-mode: vertical-rl;
  text-orientation: upright;
}
.kana span { display: block; }
@media (max-width: 720px) { .kana { display: none; } }

/* Hero grid is asymmetric — content lives in left 11/12, type bleeds */
.hero-grid {
  position: relative;
  width: min(1280px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1.5rem, 1rem + 1vw, 2rem);
}

.hero-eyebrow {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.85rem 1.25rem;
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.78rem;
  color: var(--white-soft);
}
.live-tag {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.35rem 0.75rem;
  background: oklch(57% 0.215 25 / 0.16);
  border: 1px solid oklch(57% 0.215 25 / 0.45);
  color: var(--red-glow);
  border-radius: 3px;
  font-weight: 400;
}
.live-dot {
  width: 8px; height: 8px;
  border-radius: 999px;
  background: var(--red);
  box-shadow: 0 0 0 0 oklch(57% 0.215 25 / 0.55);
  animation: livePulse 1.6s var(--ease-out) infinite;
}
@keyframes livePulse {
  0%   { box-shadow: 0 0 0 0 oklch(57% 0.215 25 / 0.55); }
  70%  { box-shadow: 0 0 0 12px oklch(57% 0.215 25 / 0); }
  100% { box-shadow: 0 0 0 0 oklch(57% 0.215 25 / 0); }
}

.hero-h1 {
  font-family: var(--ff-display);
  font-size: var(--fs-mono);
  font-weight: 400;       /* Anton is a single weight; size carries the heavy */
  line-height: 0.84;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  color: var(--white);
  margin: 0.25em 0 0.4em;
  /* Bleed past the gutter for monument scale on wide screens */
  margin-left: -0.04em;
}
.hero-h1 .line {
  display: block;
}
.hero-h1 .accent {
  background: linear-gradient(180deg, var(--red-pale) 0%, var(--red) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-style: italic;
  /* DM Serif italic is the third voice. Monumental + serif italic = magazine. */
  font-family: var(--ff-italic);
  letter-spacing: -0.02em;
  /* The italic face is much wider — pull it inward a touch */
  line-height: 0.95;
}

.hero-sub {
  max-width: 56ch;
  font-size: var(--fs-lede);
  color: var(--white-soft);
  line-height: 1.4;
  margin: 0 0 2rem;
}
.hero-sub em { color: var(--white); font-size: 1.05em; }

.hero-cta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 1.5rem;
  margin-bottom: 3rem;
}

.hero-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, max-content));
  gap: clamp(2rem, 1rem + 4vw, 5rem);
  border-top: 1px solid var(--ink-line);
  padding-top: 1.5rem;
  margin: auto 0 0;
}
.hero-meta dt {
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.7rem;
  color: var(--white-faint);
  margin-bottom: 0.5rem;
}
.hero-meta dd {
  margin: 0;
  font-family: var(--ff-display);
  font-size: clamp(2rem, 1rem + 2.5vw, 3rem);
  line-height: 1;
  color: var(--white);
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}

/* ---------------------------------------------------------------------
   MARQUEE — fight-card crawl
   --------------------------------------------------------------------- */

.marquee {
  position: relative;
  background: var(--red);
  color: var(--white);
  overflow: hidden;
  border-block: 1px solid oklch(45% 0.18 25);
}
.marquee-track {
  display: flex;
  align-items: center;
  gap: 2rem;
  padding-block: 0.95rem;
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.85rem;
  white-space: nowrap;
  width: max-content;
  animation: marquee 38s linear infinite;
  will-change: transform;
}
.marquee:hover .marquee-track { animation-play-state: paused; }
.marquee .dot { color: oklch(80% 0.15 25); font-size: 0.5em; }

@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ---------------------------------------------------------------------
   MANIFESTO — VERIFIED. EARNED. OWNED. (asymmetric)
   --------------------------------------------------------------------- */

.manifesto {
  padding: var(--pad-room) var(--gutter);
  background: var(--ink-bg);
}
.manifesto-grid {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 1rem + 4vw, 6rem);
  align-items: end;
}
@media (max-width: 880px) {
  .manifesto-grid { grid-template-columns: 1fr; align-items: start; }
}

.manifesto-h2 {
  margin: 0;
  font-family: var(--ff-display);
  font-size: var(--fs-mono);
  font-weight: 400;
  line-height: 0.86;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  color: var(--white);
}
.manifesto-h2 span {
  display: block;
  /* Stagger the three words horizontally for tabloid weight */
}
.manifesto-h2 span:nth-child(1) { color: var(--white); }
.manifesto-h2 span:nth-child(2) {
  color: var(--red);
  margin-left: 0.4ch;
}
.manifesto-h2 span:nth-child(3) {
  color: var(--white);
  margin-left: 0.8ch;
}

.manifesto-body { max-width: 44ch; }
.manifesto-body .lede {
  font-size: var(--fs-lede);
  color: var(--white-soft);
  margin: 0 0 1.25rem;
  line-height: 1.4;
}
.manifesto-body p { margin: 0 0 0.75rem; color: var(--white-dim); }

/* ---------------------------------------------------------------------
   POINTS MONUMENT — the only gold moment on the page
   --------------------------------------------------------------------- */

.points {
  padding: var(--pad-room-x) var(--gutter);
  background:
    radial-gradient(50% 80% at 50% 50%, oklch(83% 0.16 88 / 0.06) 0%, transparent 70%),
    var(--ink-bg);
  text-align: center;
  border-block: 1px solid var(--ink-line);
}
.points-eyebrow {
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-size: 0.78rem;
  color: var(--white-faint);
  margin: 0 0 1.25rem;
}
.points-number {
  margin: 0;
  font-family: var(--ff-display);
  font-size: var(--fs-mono-xl);
  line-height: 0.84;
  letter-spacing: -0.045em;
  color: var(--gold);
  /* The single page moment where gradient is allowed — the gold belt itself */
  background: linear-gradient(180deg, oklch(92% 0.13 90) 0%, var(--gold) 50%, var(--gold-deep) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-variant-numeric: tabular-nums;
  text-wrap: balance;
}
.points-foot {
  margin: 1.5rem auto 0;
  max-width: 48ch;
  color: var(--white-dim);
  font-size: 0.95rem;
}

/* ---------------------------------------------------------------------
   FEATURED CAMP — magazine spread
   --------------------------------------------------------------------- */

.camp {
  padding: var(--pad-room) var(--gutter) var(--pad-room);
  background:
    radial-gradient(70% 100% at 80% 0%, oklch(40% 0.18 25 / 0.55) 0%, transparent 70%),
    var(--ink-bg);
  position: relative;
  overflow: hidden;
}

.camp-meta {
  max-width: 1280px;
  margin: 0 auto 1.5rem;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem 1.5rem;
}
.camp-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.45rem 0.85rem;
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.72rem;
  color: var(--white);
  background: var(--red);
  border-radius: 3px;
}
.camp-eyebrow {
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.75rem;
  color: var(--white-faint);
}

.camp-h2 {
  max-width: 1280px;
  margin: 0 auto 0.75rem;
  font-family: var(--ff-display);
  font-size: var(--fs-mono);
  font-weight: 400;
  line-height: 0.84;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  color: var(--white);
}
.camp-h2 span { display: block; }
.camp-h2 .accent {
  font-family: var(--ff-italic);
  font-style: italic;
  color: var(--red-pale);
  letter-spacing: -0.02em;
  line-height: 0.95;
  margin-left: 0.2ch;
}

.camp-by {
  max-width: 1280px;
  margin: 0 auto 3rem;
  font-size: 1.05rem;
  color: var(--white-dim);
}
.camp-by em { color: var(--white); font-size: 1.1em; }

.camp-stats {
  max-width: 1280px;
  margin: 0 auto 4rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--ink-line);
  border-bottom: 1px solid var(--ink-line);
}
@media (max-width: 720px) {
  .camp-stats { grid-template-columns: repeat(2, 1fr); }
}
.camp-stats > div {
  padding: 1.5rem 1rem;
  border-right: 1px solid var(--ink-line);
}
.camp-stats > div:last-child { border-right: 0; }
@media (max-width: 720px) {
  .camp-stats > div:nth-child(2n) { border-right: 0; }
  .camp-stats > div:nth-child(-n+2) { border-bottom: 1px solid var(--ink-line); }
}
.stat-num {
  font-family: var(--ff-display);
  font-size: clamp(2.5rem, 1rem + 4vw, 4.5rem);
  line-height: 0.9;
  letter-spacing: -0.025em;
  color: var(--white);
  font-variant-numeric: tabular-nums;
}
.stat-num .suffix {
  font-size: 0.55em;
  color: var(--white-faint);
  margin-left: 0.06em;
}
.stat-lbl {
  margin-top: 0.4rem;
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.72rem;
  color: var(--white-faint);
}
.stat-lbl em { color: var(--gold); font-size: 0.95em; }

.camp-detail {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: clamp(2rem, 1rem + 3vw, 4rem);
  align-items: start;
}
@media (max-width: 880px) { .camp-detail { grid-template-columns: 1fr; } }

.camp-plan {
  display: grid;
  gap: 0;
}
.camp-plan li {
  display: grid;
  grid-template-columns: minmax(70px, max-content) 1fr;
  grid-template-rows: auto auto;
  column-gap: 1.5rem;
  padding: 1.25rem 0;
  border-top: 1px solid var(--ink-line);
}
.camp-plan li:last-child { border-bottom: 1px solid var(--ink-line); }
.plan-day {
  grid-row: 1 / 3;
  align-self: start;
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.78rem;
  color: var(--red-glow);
  padding-top: 0.3rem;
}
.plan-name {
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: -0.01em;
  font-size: 1.5rem;
  line-height: 1;
  color: var(--white);
}
.plan-meta {
  margin-top: 0.4rem;
  color: var(--white-dim);
  font-size: 0.95rem;
}
.camp-plan li.more {
  grid-template-columns: 1fr;
  font-family: var(--ff-italic);
  font-style: italic;
  color: var(--white-faint);
  text-align: right;
  padding-top: 1rem;
}

.camp-stake {
  padding: 1.75rem;
  background: var(--ink-bg-2);
  border-left: 3px solid var(--red);
  border-radius: 2px;
}
.stake-eyebrow {
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.72rem;
  color: var(--red-glow);
  margin: 0 0 0.5rem;
}
.stake-line {
  font-family: var(--ff-display);
  text-transform: uppercase;
  font-size: 1.6rem;
  letter-spacing: -0.01em;
  line-height: 1;
  color: var(--white);
  margin: 0 0 0.85rem;
}
.stake-line strong { color: var(--gold); font-weight: 400; }
.stake-rule { margin: 0 0 1.25rem; color: var(--white-dim); font-size: 0.95rem; }

/* ---------------------------------------------------------------------
   FIGHTER TEASE — image left bleed, type right
   --------------------------------------------------------------------- */

.fighter {
  padding: var(--pad-room) var(--gutter);
  background: var(--ink-bg);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 1rem + 4vw, 6rem);
  align-items: center;
  max-width: 1280px;
  margin: 0 auto;
}
@media (max-width: 880px) { .fighter { grid-template-columns: 1fr; } }

.fighter-figure {
  margin: 0;
  position: relative;
  aspect-ratio: 4 / 5;
  background:
    linear-gradient(180deg, transparent 50%, oklch(15% 0.10 25 / 0.7) 100%),
    linear-gradient(135deg, var(--red-darker) 0%, oklch(15% 0.10 25) 100%);
  border-radius: 3px;
  overflow: hidden;
}
.fighter-figure img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: grayscale(0.15) contrast(1.05);
}
.fighter-figure.is-empty::before {
  content: "やまも";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-family: var(--ff-display);
  font-size: clamp(4rem, 8vw, 10rem);
  color: oklch(57% 0.21 25 / 0.18);
  letter-spacing: -0.05em;
}
.fighter-figure figcaption {
  position: absolute;
  inset: auto 0 0 0;
  padding: 1rem 1.25rem;
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.75rem;
  color: var(--white-soft);
}

.fighter-eyebrow {
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.78rem;
  color: var(--red-glow);
  margin: 0 0 1rem;
}
.fighter-h2 {
  margin: 0 0 1.5rem;
  font-family: var(--ff-italic);
  font-style: italic;
  font-size: var(--fs-h2);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--white);
  text-wrap: balance;
}
.fighter-body { color: var(--white-dim); margin: 0 0 2rem; max-width: 42ch; }
.fighter-stats {
  display: grid;
  grid-template-columns: repeat(3, max-content);
  gap: clamp(1.5rem, 1rem + 3vw, 3.5rem);
  border-top: 1px solid var(--ink-line);
  padding-top: 1.5rem;
  margin: 0;
}
.fighter-stats dt {
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.7rem;
  color: var(--white-faint);
}
.fighter-stats dd {
  margin: 0.4rem 0 0;
  font-family: var(--ff-display);
  font-size: clamp(1.75rem, 1rem + 2vw, 2.5rem);
  letter-spacing: -0.02em;
  color: var(--white);
  font-variant-numeric: tabular-nums;
}

/* ---------------------------------------------------------------------
   APP SCREENS — magazine spread w/ vertical kana caption
   --------------------------------------------------------------------- */

.screens {
  padding: var(--pad-room) var(--gutter);
  background: linear-gradient(180deg, var(--ink-bg) 0%, oklch(9% 0.012 25) 100%);
}
.screens-head {
  max-width: 880px;
  margin: 0 auto 3rem;
  text-align: center;
}
.screens-eyebrow {
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-size: 0.78rem;
  color: var(--red-glow);
  margin: 0 0 0.85rem;
}
.screens-h2 {
  margin: 0;
  font-family: var(--ff-italic);
  font-style: italic;
  font-size: var(--fs-h2);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--white);
}

.screens-figure {
  position: relative;
  max-width: 1280px;
  margin: 0 auto;
}
.screens-figure img {
  width: 100%;
  height: auto;
  filter: drop-shadow(0 60px 80px oklch(0% 0 0 / 0.55))
          drop-shadow(0 0 120px oklch(57% 0.215 25 / 0.18));
}
.screens-kana {
  position: absolute;
  top: 50%;
  left: clamp(-1rem, -2vw, 1rem);
  transform: translateY(-50%);
  writing-mode: vertical-rl;
  text-orientation: upright;
  font-family: var(--ff-display);
  font-size: clamp(2rem, 1rem + 3vw, 4rem);
  letter-spacing: -0.04em;
  color: var(--red);
  opacity: 0.5;
  pointer-events: none;
}

/* ---------------------------------------------------------------------
   HOW — inline numbered list, no boxes
   --------------------------------------------------------------------- */

.how {
  padding: var(--pad-room) var(--gutter);
  background: var(--ink-bg);
}
.how-eyebrow {
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-size: 0.78rem;
  color: var(--red-glow);
  max-width: 1280px;
  margin: 0 auto 0.85rem;
}
.how-h2 {
  max-width: 1280px;
  margin: 0 auto 3rem;
  font-family: var(--ff-display);
  font-size: var(--fs-h2);
  font-weight: 400;
  line-height: 0.9;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  color: var(--white);
}

.how-list {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  gap: 0;
}
.how-list li {
  display: grid;
  grid-template-columns: minmax(80px, max-content) minmax(0, 1.2fr) minmax(0, 2fr);
  align-items: baseline;
  gap: clamp(1rem, 0.5rem + 2vw, 3rem);
  padding: 2rem 0;
  border-top: 1px solid var(--ink-line);
}
.how-list li:last-child { border-bottom: 1px solid var(--ink-line); }
@media (max-width: 720px) {
  .how-list li {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    gap: 0.5rem;
  }
}

.how-num {
  font-family: var(--ff-display);
  font-size: clamp(2.5rem, 1rem + 4vw, 4.5rem);
  line-height: 0.85;
  color: var(--red);
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.how-name {
  font-family: var(--ff-display);
  text-transform: uppercase;
  font-size: clamp(1.25rem, 1rem + 0.8vw, 1.75rem);
  line-height: 1;
  letter-spacing: -0.01em;
  color: var(--white);
}
.how-meta { color: var(--white-dim); font-size: 1rem; }

/* ---------------------------------------------------------------------
   BUILT-ON BAND — white-on-red strip
   --------------------------------------------------------------------- */

.builtin {
  background: var(--red);
  color: var(--white);
  padding: clamp(2.5rem, 1.5rem + 2vw, 4rem) var(--gutter);
}
.builtin-row {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(1rem, 0.5rem + 2vw, 2.5rem);
}
@media (max-width: 720px) { .builtin-row { grid-template-columns: repeat(2, 1fr); gap: 1.75rem; } }
.builtin-num {
  font-family: var(--ff-display);
  font-size: clamp(2rem, 1rem + 2.5vw, 3rem);
  line-height: 1;
  letter-spacing: -0.025em;
}
.builtin-lbl {
  margin-top: 0.5rem;
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.75rem;
  color: oklch(96% 0.006 60 / 0.78);
}

/* ---------------------------------------------------------------------
   CTA
   --------------------------------------------------------------------- */

.cta {
  padding: var(--pad-room-x) var(--gutter);
  background: var(--ink-bg);
  text-align: left;
  max-width: 1280px;
  margin: 0 auto;
}
.cta-eyebrow {
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.78rem;
  color: var(--red-glow);
  margin: 0 0 1rem;
}
.cta-h2 {
  margin: 0 0 2.5rem;
  font-family: var(--ff-display);
  font-size: var(--fs-mono);
  font-weight: 400;
  line-height: 0.84;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  color: var(--white);
}
.cta-h2 span { display: block; }
.cta-h2 .accent {
  font-family: var(--ff-italic);
  font-style: italic;
  color: var(--red-pale);
  letter-spacing: -0.02em;
  line-height: 0.95;
  margin-left: 0.3ch;
}

.cta-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) max-content;
  align-items: end;
  gap: 0;
  max-width: 640px;
  border-bottom: 2px solid var(--ink-line-2);
  padding-bottom: 0.5rem;
  transition: border-color 220ms var(--ease-out);
}
.cta-form:focus-within { border-color: var(--red); }
.cta-form input {
  font: inherit;
  font-family: var(--ff-body);
  background: transparent;
  border: 0;
  padding: 0.85rem 0;
  color: var(--white);
  outline: none;
  font-size: clamp(1rem, 0.9rem + 0.4vw, 1.25rem);
}
.cta-form input::placeholder { color: var(--white-faint); }
.cta-form output {
  grid-column: 1 / -1;
  margin-top: 0.6rem;
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.78rem;
  color: var(--red-glow);
  min-height: 1.2em;
}

/* ---------------------------------------------------------------------
   Footer
   --------------------------------------------------------------------- */

.foot {
  background: oklch(8% 0.01 25);
  padding: 2rem var(--gutter) 1.25rem;
  border-top: 1px solid var(--ink-line);
}
.foot-row {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.foot-row .brand { font-size: 1rem; }
.foot-meta {
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.78rem;
  color: var(--white-faint);
  margin: 0;
}
.foot-links {
  display: flex;
  gap: 1.25rem;
}
.foot-links a {
  font-family: var(--ff-display);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.78rem;
  color: var(--white-soft);
}
.foot-links a:hover { color: var(--red-glow); }
.foot-fine {
  max-width: 1280px;
  margin: 1.5rem auto 0;
  padding-top: 1rem;
  border-top: 1px solid var(--ink-line);
  color: var(--white-faint);
  font-size: 0.8rem;
  line-height: 1.5;
}

/* ---------------------------------------------------------------------
   Reveal motion
   --------------------------------------------------------------------- */

[data-reveal] {
  opacity: 0;
  transform: translateY(14px);
  transition:
    opacity 700ms var(--ease-out),
    transform 700ms var(--ease-out);
  transition-delay: var(--reveal-delay, 0ms);
}
[data-reveal].is-revealed {
  opacity: 1;
  transform: none;
}

/* Stagger the manifesto pair */
.manifesto-grid > [data-reveal]:nth-child(1) { --reveal-delay: 0ms; }
.manifesto-grid > [data-reveal]:nth-child(2) { --reveal-delay: 140ms; }

/* Stagger the points moment */
.points > [data-reveal]:nth-child(1) { --reveal-delay: 0ms; }
.points > [data-reveal]:nth-child(2) { --reveal-delay: 120ms; }
.points > [data-reveal]:nth-child(3) { --reveal-delay: 280ms; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  [data-reveal] { opacity: 1; transform: none; }
  .marquee-track { animation: none; }
  .live-dot { animation: none; }
}

/* Focus visible — keep it crisp, branded */
:focus-visible {
  outline: 2px solid var(--red);
  outline-offset: 3px;
  border-radius: 3px;
}
