/* ============================================================
   CRASHOUT™ — Drop 001 landing · v2 "After Hours"
   Cinematic full-bleed scroll-film. White tee · black · purple #6A1B9A.
   ============================================================ */

:root {
  /* color — OKLCH, neutrals tinted toward the brand purple hue (~304) */
  --bg:        oklch(0.145 0.028 304);
  --bg-2:      oklch(0.200 0.038 304);
  --bg-3:      oklch(0.255 0.046 304);
  --white:     oklch(0.967 0.008 304);
  --muted:     oklch(0.760 0.030 304);
  --faint:     oklch(0.580 0.040 304);

  --purple:      oklch(0.470 0.196 304);   /* brand #6A1B9A */
  --purple-bri:  oklch(0.650 0.205 304);   /* electric — accents, links, glow on dark */
  --purple-deep: oklch(0.300 0.150 304);
  --line:        oklch(0.330 0.045 304);

  --space-2xs: 4px;  --space-xs: 8px;  --space-sm: 12px; --space-md: 16px;
  --space-lg: 24px;  --space-xl: 32px; --space-2xl: 48px; --space-3xl: 64px;
  --space-4xl: 96px; --space-5xl: 140px;

  --maxw: 1320px;
  --radius: 4px;
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --font-display: "Anton", "Arial Narrow", sans-serif;
  --font-body: "Hanken Grotesk", system-ui, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--white);
  font-family: var(--font-body);
  font-size: clamp(1rem, 0.96rem + 0.2vw, 1.0625rem);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
:where(section) { scroll-margin-top: 76px; }
::selection { background: var(--purple); color: var(--white); }
:focus-visible { outline: 2px solid var(--purple-bri); outline-offset: 3px; border-radius: 2px; }

/* ---- scroll progress ---- */
.progress {
  position: fixed; top: 0; left: 0; right: 0; height: 3px;
  z-index: 200; pointer-events: none;
  background: color-mix(in oklch, var(--line) 40%, transparent);
}
.progress span {
  display: block; height: 100%; width: 100%;
  transform: scaleX(0); transform-origin: left;
  background: linear-gradient(90deg, var(--purple), var(--purple-bri));
  box-shadow: 0 0 12px -2px var(--purple-bri);
}

/* ---- film grain ---- */
.grain {
  position: fixed; inset: 0; z-index: 190; pointer-events: none;
  opacity: 0.05; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.aurora {
  position: absolute; border-radius: 50%;
  filter: blur(90px); opacity: 0.5; pointer-events: none; z-index: 0;
  background: radial-gradient(circle at center, var(--purple) 0%, transparent 70%);
}

/* ============================================================ HEADER */
.site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-md);
  padding: var(--space-md) clamp(var(--space-md), 4vw, var(--space-2xl));
  transition: background 0.4s var(--ease-out), backdrop-filter 0.4s var(--ease-out), border-color 0.4s var(--ease-out);
  border-bottom: 1px solid transparent;
}
.site-header.is-stuck {
  background: color-mix(in oklch, var(--bg) 72%, transparent);
  backdrop-filter: blur(12px);
  border-bottom-color: color-mix(in oklch, var(--line) 55%, transparent);
}
.wordmark {
  font-family: var(--font-display); font-size: clamp(1.15rem, 1rem + 1vw, 1.55rem);
  letter-spacing: 0.04em; line-height: 1; text-transform: uppercase; color: var(--white);
  text-shadow: 0 2px 18px color-mix(in oklch, var(--bg) 70%, transparent);
}
.wordmark .tm { color: var(--purple-bri); font-size: 0.5em; vertical-align: super; }
.nav { display: flex; align-items: center; gap: clamp(var(--space-md), 2.5vw, var(--space-xl)); }
.nav > a:not(.nav-cta) {
  font-size: 0.82rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--white); opacity: 0.82; transition: opacity 0.25s var(--ease-out);
  text-shadow: 0 1px 12px color-mix(in oklch, var(--bg) 70%, transparent);
}
.nav > a:not(.nav-cta):hover { opacity: 1; }
.nav > a:not(.nav-cta) { display: none; }
.nav-cta {
  font-weight: 700; font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.06em;
  padding: var(--space-xs) var(--space-md); border: 1px solid var(--purple-bri); color: var(--white);
  border-radius: var(--radius);
  transition: background 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out);
}
.nav-cta:hover { background: var(--purple); box-shadow: 0 0 24px -6px var(--purple-bri); }

/* ============================================================ HERO (full-bleed) */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex; align-items: flex-end;
  padding: clamp(var(--space-3xl), 12vh, 160px) clamp(var(--space-md), 5vw, var(--space-4xl)) clamp(var(--space-2xl), 8vh, var(--space-4xl));
  overflow: hidden;
}
.hero-bg { position: absolute; inset: 0; z-index: 0; will-change: transform; }
.hero-bg img {
  width: 100%; height: 100%; object-fit: cover; object-position: center 28%;
  filter: saturate(1.05) contrast(1.04);
  animation: kenburns 26s var(--ease-in-out) infinite alternate;
}
@keyframes kenburns { from { transform: scale(1.04); } to { transform: scale(1.14); } }
.hero-scrim {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(180deg, color-mix(in oklch, var(--bg) 55%, transparent) 0%, transparent 22%, transparent 45%, color-mix(in oklch, var(--bg) 88%, transparent) 100%),
    linear-gradient(75deg, color-mix(in oklch, var(--bg) 80%, transparent) 0%, transparent 60%);
}
.hero-inner { position: relative; z-index: 2; max-width: 44rem; width: 100%; }

.eyebrow {
  display: inline-flex; align-items: center; gap: var(--space-xs); margin: 0 0 var(--space-lg);
  font-size: 0.78rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.18em; color: var(--white); opacity: 0.9;
}
.eyebrow .dot {
  width: 7px; height: 7px; border-radius: 50%; background: var(--purple-bri);
  animation: pulse 2.4s var(--ease-out) infinite;
}
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 color-mix(in oklch, var(--purple-bri) 70%, transparent); }
  70%, 100% { box-shadow: 0 0 0 9px transparent; }
}
.hero-headline {
  font-family: var(--font-display); font-weight: 400; text-transform: uppercase;
  line-height: 0.88; letter-spacing: 0.005em; margin: 0 0 var(--space-lg);
  font-size: clamp(2.9rem, 1.4rem + 9vw, 6.4rem);
  text-shadow: 0 4px 40px color-mix(in oklch, var(--bg) 60%, transparent);
}
.hero-static {
  display: block; font-family: var(--font-body); font-weight: 600;
  font-size: clamp(0.95rem, 0.8rem + 1.2vw, 1.4rem); letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--white); opacity: 0.78; margin-bottom: var(--space-sm); text-shadow: none;
}
.rotator { display: block; position: relative; min-height: 2.85em; color: var(--white); }
.rotator-item {
  position: absolute; inset: 0; opacity: 0; transform: translateY(0.4em); filter: blur(6px);
  transition: opacity 0.55s var(--ease-out), transform 0.55s var(--ease-out), filter 0.55s var(--ease-out);
}
.rotator-item.is-active { opacity: 1; transform: translateY(0); filter: blur(0); }
.rotator-item.is-out { opacity: 0; transform: translateY(-0.4em); filter: blur(6px); }

.hero-sub {
  margin: 0 0 var(--space-xl); max-width: 38ch;
  color: color-mix(in oklch, var(--white) 88%, transparent);
  font-size: clamp(1rem, 0.95rem + 0.3vw, 1.15rem);
  text-shadow: 0 1px 16px color-mix(in oklch, var(--bg) 60%, transparent);
}
.hero-sub em { color: var(--white); font-style: italic; }

/* countdown */
.countdown { display: flex; align-items: flex-start; gap: var(--space-sm); margin-bottom: var(--space-xl); }
.cd-unit { display: flex; flex-direction: column; align-items: center; gap: 2px; min-width: 2.4ch; }
.cd-num {
  font-family: var(--font-display); font-size: clamp(1.7rem, 1.2rem + 2vw, 2.5rem); line-height: 1;
  color: var(--white); font-variant-numeric: tabular-nums; text-shadow: 0 2px 20px color-mix(in oklch, var(--bg) 55%, transparent);
}
.cd-label { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.16em; color: color-mix(in oklch, var(--white) 70%, transparent); font-weight: 600; }
.cd-sep { font-family: var(--font-display); font-size: clamp(1.5rem, 1rem + 2vw, 2.2rem); line-height: 1; color: var(--purple-bri); margin-top: 2px; }
.cd-live { font-family: var(--font-display); text-transform: uppercase; font-size: clamp(1.4rem, 1rem + 2vw, 2.2rem); color: var(--purple-bri); letter-spacing: 0.02em; }

/* signup */
.signup { max-width: 30rem; }
.field {
  display: flex; gap: var(--space-xs); border: 1px solid color-mix(in oklch, var(--white) 22%, transparent);
  border-radius: var(--radius); padding: var(--space-2xs);
  background: color-mix(in oklch, var(--bg) 55%, transparent); backdrop-filter: blur(8px);
  transition: border-color 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out);
}
.field:focus-within { border-color: var(--purple-bri); box-shadow: 0 0 0 3px color-mix(in oklch, var(--purple-bri) 24%, transparent); }
.field input {
  flex: 1; min-width: 0; background: transparent; border: 0; color: var(--white);
  font-family: var(--font-body); font-size: 1rem; padding: var(--space-sm) var(--space-md);
}
.field input::placeholder { color: color-mix(in oklch, var(--white) 55%, transparent); }
.field input:focus { outline: none; }
.field button {
  flex-shrink: 0; font-family: var(--font-body); font-weight: 700; font-size: 0.9rem;
  text-transform: uppercase; letter-spacing: 0.05em; color: var(--white); background: var(--purple);
  border: 0; border-radius: 2px; padding: var(--space-sm) clamp(var(--space-md), 3vw, var(--space-xl)); cursor: pointer;
  transition: background 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out), transform 0.15s var(--ease-out);
}
.field button:hover { background: var(--purple-bri); box-shadow: 0 0 28px -6px var(--purple-bri); }
.field button:active { transform: scale(0.97); }
.field button:disabled { opacity: 0.6; cursor: wait; }
.success-msg {
  margin: 0; padding: var(--space-sm) var(--space-md); font-family: var(--font-display);
  text-transform: uppercase; font-size: clamp(1.05rem, 0.9rem + 0.8vw, 1.4rem); line-height: 1.05;
  letter-spacing: 0.02em; color: var(--purple-bri);
}
.success-msg span {
  display: block; margin-top: var(--space-2xs); font-family: var(--font-body); font-weight: 500;
  text-transform: none; letter-spacing: 0; font-size: 0.85rem; color: var(--white);
}
.form-note { margin: var(--space-sm) 0 0; font-size: 0.8rem; color: color-mix(in oklch, var(--white) 72%, transparent); padding-left: var(--space-2xs); }
.form-note.is-error { color: var(--purple-bri); }
.form-note.is-success { color: var(--white); }

/* scroll cue */
.scroll-cue {
  position: absolute; left: 50%; bottom: var(--space-lg); transform: translateX(-50%); z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: var(--space-xs);
  font-size: 0.64rem; text-transform: uppercase; letter-spacing: 0.24em; color: var(--white); opacity: 0.65;
}
.scroll-cue i { display: block; width: 1px; height: 38px; background: linear-gradient(var(--purple-bri), transparent); position: relative; overflow: hidden; }
.scroll-cue i::after { content: ""; position: absolute; top: -50%; left: 0; width: 100%; height: 50%; background: var(--white); animation: cue 1.8s var(--ease-in-out) infinite; }
@keyframes cue { 0% { top: -50%; } 100% { top: 100%; } }

/* ============================================================ MARQUEE */
.marquee {
  border-block: 1px solid var(--line); padding: var(--space-md) 0; overflow: hidden;
  background: linear-gradient(90deg, var(--bg-2), color-mix(in oklch, var(--purple-deep) 32%, var(--bg-2)), var(--bg-2));
}
.marquee-track { display: inline-flex; align-items: center; gap: var(--space-lg); white-space: nowrap; will-change: transform; animation: scroll-x 40s linear infinite; }
.marquee-track span { font-family: var(--font-display); text-transform: uppercase; font-size: clamp(1.2rem, 0.9rem + 2vw, 2.2rem); letter-spacing: 0.02em; color: var(--white); }
.marquee-track span:nth-child(4n+3) { color: transparent; -webkit-text-stroke: 1px var(--purple-bri); }
.marquee-track .star { color: var(--purple-bri); -webkit-text-stroke: 0; }
@keyframes scroll-x { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ============================================================ SCENES (immersive) */
.scenes { position: relative; }
.scenes-intro {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(var(--space-3xl), 10vw, var(--space-5xl)) clamp(var(--space-md), 4vw, var(--space-2xl)) clamp(var(--space-xl), 5vw, var(--space-3xl));
}
.section-kicker { display: block; font-size: 0.76rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.22em; color: var(--purple-bri); margin-bottom: var(--space-md); }
.scenes-intro h2, .section-head h2 {
  font-family: var(--font-display); text-transform: uppercase; font-weight: 400;
  font-size: clamp(2.2rem, 1.3rem + 5vw, 4.2rem); line-height: 0.92; margin: 0 0 var(--space-md); letter-spacing: 0.01em;
}
.scenes-intro p, .section-head p { margin: 0; color: var(--muted); max-width: 46ch; }

.scene {
  position: relative; margin: 0; height: clamp(560px, 92svh, 1100px); overflow: hidden;
  display: flex; align-items: flex-end;
}
.scene-media { position: absolute; inset: -8% 0; z-index: 0; will-change: transform; }
.scene-media img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; filter: saturate(1.05) contrast(1.03); }
.scene-scrim {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(180deg, color-mix(in oklch, var(--bg) 40%, transparent) 0%, transparent 30%, transparent 50%, color-mix(in oklch, var(--bg) 90%, transparent) 100%);
}
.scene-copy {
  position: relative; z-index: 2; width: 100%; max-width: var(--maxw); margin: 0 auto;
  padding: clamp(var(--space-xl), 6vw, var(--space-4xl)) clamp(var(--space-md), 4vw, var(--space-2xl));
}
.scene-copy.align-right { text-align: right; margin-left: auto; }
.scene-no { display: block; font-size: 0.74rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.2em; color: var(--purple-bri); margin-bottom: var(--space-sm); }
.scene-line {
  font-family: var(--font-display); text-transform: uppercase; font-weight: 400; margin: 0 0 var(--space-sm);
  font-size: clamp(3rem, 1.6rem + 11vw, 9rem); line-height: 0.84; letter-spacing: 0.005em;
  color: var(--white); text-shadow: 0 6px 50px color-mix(in oklch, var(--bg) 55%, transparent);
}
.scene-tag { display: block; font-size: clamp(0.84rem, 0.8rem + 0.4vw, 1rem); color: color-mix(in oklch, var(--white) 82%, transparent); letter-spacing: 0.02em; }

/* ============================================================ CAST (horizontal film strip) */
.cast { padding: clamp(var(--space-3xl), 9vw, var(--space-5xl)) 0; }
.section-head { max-width: var(--maxw); margin: 0 auto var(--space-2xl); padding: 0 clamp(var(--space-md), 4vw, var(--space-2xl)); }
.cast-track {
  display: flex; gap: clamp(var(--space-sm), 1.5vw, var(--space-lg));
  overflow-x: auto; scroll-snap-type: x mandatory;
  padding: 0 clamp(var(--space-md), 4vw, var(--space-2xl)) var(--space-md);
  -webkit-overflow-scrolling: touch; scrollbar-width: thin; scrollbar-color: var(--purple) transparent;
}
.cast-track::-webkit-scrollbar { height: 6px; }
.cast-track::-webkit-scrollbar-thumb { background: var(--purple); border-radius: 99px; }
.cast-card {
  position: relative; flex: 0 0 auto; width: clamp(260px, 72vw, 380px); margin: 0;
  aspect-ratio: 4 / 5; border-radius: var(--radius); overflow: hidden; scroll-snap-align: start;
  background: var(--bg-2);
}
.cast-card img { width: 100%; height: 100%; object-fit: cover; object-position: center 22%; filter: brightness(0.92) saturate(1.04); transition: transform 0.7s var(--ease-out), filter 0.5s var(--ease-out); }
.cast-card figcaption {
  position: absolute; left: 0; right: 0; bottom: 0; z-index: 2;
  padding: var(--space-2xl) var(--space-md) var(--space-md);
  background: linear-gradient(180deg, transparent, color-mix(in oklch, var(--bg) 90%, transparent));
}
.cast-card figcaption b { display: block; font-family: var(--font-display); text-transform: uppercase; font-weight: 400; font-size: clamp(1.1rem, 0.9rem + 1vw, 1.5rem); line-height: 0.98; letter-spacing: 0.01em; }
.cast-card figcaption span { display: block; margin-top: 2px; font-size: 0.82rem; color: var(--muted); }
@media (hover: hover) { .cast-card:hover img { transform: scale(1.05); filter: brightness(1) saturate(1.06); } }

/* ============================================================ THE TEES */
.tees { max-width: var(--maxw); margin: 0 auto; padding: clamp(var(--space-2xl), 5vw, var(--space-3xl)) clamp(var(--space-md), 4vw, var(--space-2xl)) clamp(var(--space-3xl), 8vw, var(--space-5xl)); }
.tees .section-head { padding: 0; margin-bottom: var(--space-2xl); }
.tees-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(var(--space-xs), 1.4vw, var(--space-md)); }
.tee { position: relative; margin: 0; overflow: hidden; border-radius: var(--radius); background: var(--bg-2); aspect-ratio: 4 / 5; }
.tee img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.7s var(--ease-out); }
.tee figcaption {
  position: absolute; left: 0; right: 0; bottom: 0; padding: var(--space-2xl) var(--space-md) var(--space-md);
  font-family: var(--font-display); text-transform: uppercase; font-size: clamp(0.92rem, 0.7rem + 0.9vw, 1.25rem); line-height: 1.02;
  background: linear-gradient(180deg, transparent, color-mix(in oklch, var(--bg) 88%, transparent));
}
@media (hover: hover) { .tee:hover img { transform: scale(1.05); } }

/* ============================================================ MANIFESTO */
.manifesto { position: relative; max-width: 64rem; margin: 0 auto; padding: clamp(var(--space-3xl), 8vw, var(--space-4xl)) clamp(var(--space-md), 4vw, var(--space-2xl)); text-align: center; overflow: hidden; }
.manifesto .aurora { top: 50%; left: 50%; width: min(70%, 540px); aspect-ratio: 1; transform: translate(-50%, -50%); opacity: 0.3; }
.manifesto-kicker { position: relative; z-index: 1; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.22em; color: var(--purple-bri); font-weight: 700; margin: 0 0 var(--space-lg); }
.manifesto-text { position: relative; z-index: 1; font-family: var(--font-display); text-transform: uppercase; font-weight: 400; font-size: clamp(1.9rem, 1rem + 5.2vw, 4rem); line-height: 1.0; letter-spacing: 0.01em; margin: 0; color: var(--muted); }
.manifesto-text .hl { color: var(--white); }

/* ============================================================ GIANT WORDMARK */
.statement { position: relative; overflow: hidden; padding: clamp(var(--space-2xl), 5vw, var(--space-3xl)) 0 0; border-top: 1px solid var(--line); }
.statement-mark { font-family: var(--font-display); text-transform: uppercase; font-weight: 400; text-align: center; line-height: 0.78; letter-spacing: 0.005em; font-size: clamp(3.4rem, 20vw, 19rem); margin: 0; color: var(--white); white-space: nowrap; user-select: none; }
.statement-mark .tm { font-size: 0.18em; vertical-align: super; color: var(--purple-bri); }
.statement-mark .o { color: var(--purple); }

/* ============================================================ CLOSER */
.closer { position: relative; margin: clamp(var(--space-lg), 4vw, var(--space-2xl)) clamp(var(--space-md), 4vw, var(--space-2xl)) var(--space-2xl); border-radius: calc(var(--radius) * 2); overflow: hidden; isolation: isolate; }
.closer::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background:
    linear-gradient(155deg, color-mix(in oklch, var(--purple-deep) 80%, transparent), color-mix(in oklch, var(--bg) 84%, transparent) 70%),
    url("assets/scene-02-taillights.jpg") center 30% / cover no-repeat;
}
.closer-inner { max-width: var(--maxw); margin: 0 auto; padding: clamp(var(--space-3xl), 9vw, var(--space-5xl)) clamp(var(--space-lg), 5vw, var(--space-4xl)); }
.closer-head { font-family: var(--font-display); text-transform: uppercase; font-weight: 400; font-size: clamp(2.8rem, 1.6rem + 8vw, 6.5rem); line-height: 0.88; margin: 0 0 var(--space-md); letter-spacing: 0.01em; }
.closer-sub { color: color-mix(in oklch, var(--white) 88%, transparent); max-width: 40ch; margin: 0 0 var(--space-xl); font-size: 1.08rem; }

/* ============================================================ FOOTER */
.site-footer { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--space-md); max-width: var(--maxw); margin: 0 auto; padding: var(--space-2xl) clamp(var(--space-md), 4vw, var(--space-2xl)) var(--space-3xl); border-top: 1px solid var(--line); }
.foot-mark { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.04em; font-size: 1.1rem; }
.foot-mark .tm { color: var(--purple-bri); font-size: 0.55em; vertical-align: super; }
.foot-social { display: flex; gap: var(--space-lg); }
.foot-social a { font-size: 0.82rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); transition: color 0.25s var(--ease-out); }
.foot-social a:hover { color: var(--purple-bri); }
.foot-legal { font-size: 0.78rem; color: var(--faint); }

/* ============================================================ REVEAL */
.js .reveal { opacity: 0; transform: translateY(30px); transition: opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out); }
.js .reveal.in { opacity: 1; transform: none; }

/* ============================================================ RESPONSIVE */
@media (min-width: 720px) {
  .nav > a:not(.nav-cta) { display: inline; }
  .tees-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (min-width: 980px) {
  .scene-line { max-width: 12ch; }
  .scene-copy { max-width: var(--maxw); }
}

/* ============================================================ REDUCED MOTION */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; scroll-behavior: auto !important; }
  .reveal { opacity: 1; transform: none; }
  .hero-bg img { animation: none; transform: scale(1.04); }
  .rotator-item { transition: opacity 0.3s linear; }
  .scroll-cue i::after { display: none; }
  .wordmark:hover { animation: none; }
}

/* ============================================================ GEM — wordmark hover glitch (echoes the loader) */
@media (hover: hover) {
  .wordmark { position: relative; }
  .wordmark:hover { animation: wm-glitch 0.34s steps(2, end) 2; }
}
@keyframes wm-glitch {
  0%, 100% { transform: translate(0, 0); }
  25% { transform: translate(-1px, 0); text-shadow: 2px 0 var(--purple-bri), -2px 0 color-mix(in oklch, var(--white) 70%, transparent); }
  50% { transform: translate(1px, 0); }
  75% { transform: translate(-1px, 0); text-shadow: -2px 0 var(--purple-bri); }
}
