/* ===================================================================
   Maks Donovan — style.css
   Detroit Militant register. Black ground, oxide red accent, bone ink.
   Saira Condensed Black display, Inter body, JetBrains Mono metadata.
   =================================================================== */

/* -------------------------------------------------------------------
   Reduced-motion global override (Convention 9)
   Sits at the top so it cascades over everything that follows.
   ------------------------------------------------------------------- */
@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;
  }
}

/* -------------------------------------------------------------------
   Tokens (Convention 8)
   ------------------------------------------------------------------- */
:root {
  /* Palette — strict three colors */
  --ink:        #000000;
  --bone:       #EFE9DD;
  --bone-soft:  rgba(239, 233, 221, 0.62);
  --bone-dim:   rgba(239, 233, 221, 0.38);
  --oxide:      #D73B2A;
  --oxide-dim:  rgba(215, 59, 42, 0.55);
  --rule:       rgba(239, 233, 221, 0.14);
  --rule-strong:rgba(239, 233, 221, 0.28);

  /* Sevra band — uses Sevra brand colors (the band is Sevra's surface,
     not the artist's) */
  --sevra-bg:   #2B221A;       /* warm walnut, slightly browner than Maks's pure black */
  --sevra-ink:  #F4ECDC;       /* Sevra's vellum */
  --sevra-accent: #D6A357;

  /* Typography */
  --display: 'Saira Condensed', 'Helvetica Neue', Helvetica, Arial, sans-serif;
  --body:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --mono:    'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;

  /* Type scale — fluid via clamp(). Hero wordmark floor sized to fit
     360px viewports per the audit-check learning from H&F. */
  --step-hero:    clamp(2.5rem, 0.6rem + 8.5vw, 7.5rem);   /* 40px floor → 120px ceiling */
  --step-display: clamp(2rem,   0.7rem + 5vw,   4rem);     /* 32 → 64 */
  --step-section: clamp(1.625rem, 0.9rem + 3vw, 2.625rem); /* 26 → 42 */
  --step-body:    clamp(1rem, 0.95rem + 0.25vw, 1.125rem); /* 16 → 18 */
  --step-meta:    0.75rem;       /* 12px — mono metadata */
  --step-meta-sm: 0.6875rem;     /* 11px — smaller mono */

  /* Layout */
  --container-max: 1180px;
  --gutter:        clamp(1.25rem, 4vw, 2.5rem);
  --section-pad:   clamp(4rem, 8vw, 7rem);

  /* Sticky chrome heights — used in both fixed sizing and scroll-padding-top */
  --sevra-band-h:  2.25rem;      /* 36px */
  --topbar-h:      4rem;         /* 64px desktop */

  /* Stack height = sevra-band + topbar; scroll-padding-top sits ~28px below */
  --chrome-h:      6.25rem;      /* 100px desktop */
  --scroll-offset: 6.5rem;       /* small breathing room below chrome */

  /* Easing */
  --ease-out: cubic-bezier(0.2, 0.8, 0.2, 1);
  --ease-io:  cubic-bezier(0.65, 0, 0.35, 1);

  /* Z-index scale */
  --z-skip:     200;
  --z-sevra:    150;
  --z-topbar:   140;
  --z-overlay:  120;
}

/* Mobile chrome sizing — the topbar is a single-row hamburger layout
   below 760px. */
@media (max-width: 759px) {
  :root {
    --topbar-h:      3.5rem;     /* 56px */
    --chrome-h:      5.75rem;    /* 92px */
    --scroll-offset: 6rem;
  }
}

/* -------------------------------------------------------------------
   Reset + base
   ------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  scroll-padding-top: var(--scroll-offset);
  background: var(--ink);
}

body {
  margin: 0;
  background: var(--ink);
  color: var(--bone);
  font-family: var(--body);
  font-size: var(--step-body);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img { display: block; max-width: 100%; height: auto; }

a {
  color: inherit;
  text-decoration: none;
}

ul { list-style: none; padding: 0; margin: 0; }

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

/* Skip link */
.skip-link {
  position: absolute;
  left: 0.5rem;
  top: 0.5rem;
  background: var(--oxide);
  color: var(--ink);
  font-family: var(--mono);
  font-size: var(--step-meta);
  padding: 0.5rem 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  z-index: var(--z-skip);
  transform: translateY(-150%);
  transition: transform 180ms var(--ease-out);
}
.skip-link:focus-visible {
  transform: translateY(0);
  outline: 2px solid var(--bone);
  outline-offset: 2px;
}

/* Focus visibility (Convention 13) */
a:focus-visible,
button:focus-visible {
  outline: 2px solid var(--oxide);
  outline-offset: 3px;
  border-radius: 1px;
}

/* -------------------------------------------------------------------
   Sevra showcase attribution band (top sticky)
   The band is Sevra's surface — uses Sevra brand colors, not Maks's.
   ------------------------------------------------------------------- */
.sevra-band {
  position: sticky;
  top: 0;
  z-index: var(--z-sevra);
  background: var(--sevra-bg);
  color: var(--sevra-ink);
  height: var(--sevra-band-h);
  display: flex;
  align-items: center;
  border-bottom: 1px solid rgba(0, 0, 0, 0.5);
}

.sevra-band__inner {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex;
  align-items: center;
  gap: 0.625rem;
  font-family: var(--body);
  font-size: var(--step-meta-sm);
  font-weight: 400;
  letter-spacing: 0.04em;
}

/* "Sd" monogram — Sevra brand mark. Same treatment as the palette
   tool's logo: dark box with serif "S" in vellum and italic "d" in
   the Sevra gold accent. Geographic-anchor for the band. */
.sevra-band__logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background: var(--ink);
  border-radius: 3px;
  flex-shrink: 0;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1;
  color: var(--sevra-ink);
  letter-spacing: -0.01em;
  /* Slight nudge to optically center the letters */
  padding-bottom: 1px;
  margin-right: 0.25rem;
}
.sevra-band__logo em {
  font-style: italic;
  font-weight: 400;
  color: var(--sevra-accent);
}

.sevra-band__brand { font-weight: 500; }
.sevra-band__sep   { color: rgba(244, 236, 220, 0.4); }
.sevra-band__role,
.sevra-band__client { color: rgba(244, 236, 220, 0.85); }

/* Wrapping anchor around .sevra-band__logo + .sevra-band__brand.
   Returns the user to the main marketing site. The anchor is one
   flex child of .sevra-band__inner, so its inner spans flow inline
   naturally — the logo's existing margin-right handles spacing.
   Inherits colour from the band so the logo's dark box and the
   wordmark text both keep their existing treatment. */
.sevra-band__home {
  display: inline-flex;
  align-items: center;
  color: inherit;
  text-decoration: none;
  transition: color 180ms var(--ease-out);
}
.sevra-band__home:hover { color: var(--sevra-accent); }

.sevra-band__back {
  margin-left: auto;
  color: var(--sevra-accent);
  font-family: var(--mono);
  font-size: var(--step-meta-sm);
  letter-spacing: 0.1em;
  border-bottom: 1px solid transparent;
  transition: border-color 180ms var(--ease-out);
}
.sevra-band__back:hover { border-bottom-color: var(--sevra-accent); }

@media (max-width: 540px) {
  /* Tighten band on very narrow viewports */
  .sevra-band__role { display: none; }
  .sevra-band__sep:nth-of-type(1) { display: none; }
}

/* -------------------------------------------------------------------
   Maks topbar (sticky beneath Sevra band)
   Black ground, oxide red dot accent, mono nav.
   ------------------------------------------------------------------- */
.topbar {
  position: sticky;
  top: var(--sevra-band-h);
  z-index: var(--z-topbar);
  height: var(--topbar-h);
  background: var(--ink);
  border-bottom: 1px solid var(--rule);
}

.topbar__inner {
  height: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex;
  align-items: center;
  gap: clamp(0.875rem, 2vw, 1.5rem);
}

.topbar__brand {
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  font-family: var(--display);
  font-weight: 900;
  font-size: 1.125rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--bone);
  white-space: nowrap;
  margin-right: auto; /* pushes everything else to the right */
}

.topbar__dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  background: var(--oxide);
}

.topbar__wordmark { line-height: 1; }

.topbar__nav ul {
  display: flex;
  align-items: center;
  gap: clamp(1.25rem, 2.5vw, 2rem);
}

.topbar__nav a {
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.18em;
  color: var(--bone-soft);
  text-transform: lowercase;
  transition: color 160ms var(--ease-out);
  position: relative;
  padding: 0.25rem 0;
}
.topbar__nav a:hover,
.topbar__nav a:focus-visible { color: var(--oxide); }

/* Hamburger button — hidden on desktop */
.topbar__menu-toggle {
  display: none;
  background: transparent;
  border: 1px solid var(--rule-strong);
  color: var(--bone);
  width: 38px;
  height: 38px;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: border-color 160ms var(--ease-out), color 160ms var(--ease-out);
}
.topbar__menu-toggle:hover {
  border-color: var(--oxide);
  color: var(--oxide);
}

/* Sound toggle — always visible (desktop AND mobile). Square icon-only
   button that mirrors the hamburger's visual weight. Off state shows
   speaker-with-X; on state shows speaker-with-soundwaves in oxide red. */
.topbar__sound-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid var(--rule-strong);
  color: var(--bone-soft);
  width: 38px;
  height: 38px;
  padding: 0;
  cursor: pointer;
  transition: color 160ms var(--ease-out), border-color 160ms var(--ease-out);
}
.topbar__sound-toggle:hover {
  color: var(--bone);
  border-color: var(--bone-soft);
}
.topbar__sound-toggle.is-on {
  color: var(--oxide);
  border-color: var(--oxide);
}

/* Two icons live inside the button; CSS swaps which one is visible
   based on the .is-on class. Default = off (X), .is-on = on (waves). */
.topbar__sound-icon {
  display: inline-flex;
}
.topbar__sound-icon--on { display: none; }
.topbar__sound-toggle.is-on .topbar__sound-icon--off { display: none; }
.topbar__sound-toggle.is-on .topbar__sound-icon--on  { display: inline-flex; }

/* Mobile nav: hamburger toggles dropdown panel beneath topbar (Convention 17) */
@media (max-width: 759px) {
  .topbar__menu-toggle {
    display: inline-flex;
  }

  .topbar__nav {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--ink);
    border-bottom: 1px solid var(--rule);
    visibility: hidden;
    opacity: 0;
    transform: translateY(-6px);
    transition:
      opacity 220ms var(--ease-out),
      transform 220ms var(--ease-out),
      visibility 0s linear 220ms;
  }
  .topbar.is-open .topbar__nav {
    visibility: visible;
    opacity: 1;
    transform: none;
    transition:
      opacity 220ms var(--ease-out),
      transform 220ms var(--ease-out);
  }

  .topbar__nav ul {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 0.5rem var(--gutter) 1rem;
  }

  .topbar__nav li + li {
    border-top: 1px solid var(--rule);
  }

  .topbar__nav a {
    display: block;
    padding: 1rem 0;
    font-size: 0.8125rem;
  }
}

/* -------------------------------------------------------------------
   Container
   ------------------------------------------------------------------- */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

/* -------------------------------------------------------------------
   Section header pattern (every section uses this)
   Eyebrow (mono) → title (display, all-caps stamped) → body (Inter).
   The id lives here, NOT on the outer <section> (Convention 3).
   ------------------------------------------------------------------- */
.section-header {
  max-width: 720px;
  margin-bottom: clamp(2.5rem, 5vw, 4rem);
}

.eyebrow {
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.22em;
  color: var(--oxide);
  text-transform: uppercase;
  margin: 0 0 1.5rem;
  font-weight: 500;
}

.section-title {
  font-family: var(--display);
  font-weight: 900;
  font-size: var(--step-display);
  line-height: 0.95;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  margin: 0 0 1.75rem;
  color: var(--bone);
}
.section-title br + ::after { content: ''; }
/* Period accent — last word of each title line picks up oxide red.
   We let the dot in markup do this implicitly; for now the type-treatment
   alone carries the conviction. */

.section-body {
  font-size: var(--step-body);
  line-height: 1.6;
  color: var(--bone);
  max-width: 56ch;
  margin: 0;
}

.section-body em {
  font-style: italic;
  color: var(--oxide);
}

/* -------------------------------------------------------------------
   01 — HERO
   Three full-bleed photos crossfading + ken-burns zoom.
   Type sits in the lower-left third over a dark gradient overlay.
   ------------------------------------------------------------------- */
.hero {
  position: relative;
  min-height: clamp(560px, 88vh, 920px);
  height: calc(100vh - var(--chrome-h));
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  background: var(--ink);
}

.hero__photo {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  will-change: opacity, transform;
  /* Ken-burns animation runs on each photo, 18s closed loop —
     bumped from 30s for more kinetic feel. Photo crossfade is 36s
     (6s per photo across 6 images), intentionally desynced from
     zoom so each photo shows a different portion of the zoom curve. */
  animation: hero-zoom 18s ease-in-out infinite;
}

/* Six-photo rotation, alternating Maks shots and crowd shots:
   01 (Maks) → 05 (crowd) → 02 (Maks) → 08 (crowd overhead) → 06 (crowd portrait) → 03 (Maks) */
.hero__photo--1 {
  background-image: url('assets/dj-01.png');
  background-position: 60% center;
  animation: hero-zoom 18s ease-in-out infinite, hero-photo-1 36s linear infinite;
}
.hero__photo--2 {
  background-image: url('assets/dj-05.png');
  animation: hero-zoom 18s ease-in-out infinite, hero-photo-2 36s linear infinite;
}
.hero__photo--3 {
  background-image: url('assets/dj-02.png');
  background-position: 70% center;
  animation: hero-zoom 18s ease-in-out infinite, hero-photo-3 36s linear infinite;
}
.hero__photo--4 {
  background-image: url('assets/dj-08.png');
  animation: hero-zoom 18s ease-in-out infinite, hero-photo-4 36s linear infinite;
}
.hero__photo--5 {
  background-image: url('assets/dj-06.png');
  background-position: 65% center;
  animation: hero-zoom 18s ease-in-out infinite, hero-photo-5 36s linear infinite;
}
.hero__photo--6 {
  background-image: url('assets/dj-03.png');
  background-position: center 65%;
  animation: hero-zoom 18s ease-in-out infinite, hero-photo-6 36s linear infinite;
}

/* Six-photo rotation, REVEAL-FROM-BENEATH technique to avoid the dim-
   midpoint artifact of true alpha-crossfade. Each incoming photo
   "jumps" to opacity 1 just before the outgoing photo starts fading.
   The outgoing photo then fades 1→0 revealing the incoming (already
   at 100%) underneath. No double-50%-opacity moment, no black drag.

   Cycle: 36s. Each photo holds visible for ~16% of cycle (~5.8s),
   fade-out duration: 3% (~1s reveal). Loop closes at photo 1 = 1
   matching 0% = 1; all others 0 at both ends. (Convention 16.) */
@keyframes hero-photo-1 {
  0%, 14%   { opacity: 1; }
  17%, 95%  { opacity: 0; }
  96%, 100% { opacity: 1; }
}
@keyframes hero-photo-2 {
  0%, 13%   { opacity: 0; }
  14%, 30%  { opacity: 1; }
  33%, 100% { opacity: 0; }
}
@keyframes hero-photo-3 {
  0%, 29%   { opacity: 0; }
  30%, 47%  { opacity: 1; }
  50%, 100% { opacity: 0; }
}
@keyframes hero-photo-4 {
  0%, 46%   { opacity: 0; }
  47%, 64%  { opacity: 1; }
  67%, 100% { opacity: 0; }
}
@keyframes hero-photo-5 {
  0%, 63%   { opacity: 0; }
  64%, 80%  { opacity: 1; }
  83%, 100% { opacity: 0; }
}
@keyframes hero-photo-6 {
  0%, 79%   { opacity: 0; }
  80%, 96%  { opacity: 1; }
  100%      { opacity: 0; }
}

/* Ken-burns — closed loop, scale matches at 0% and 100% */
@keyframes hero-zoom {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.04); }
}

/* Reduced-motion: hold image 1 visible at slight scale, hide others, no animation */
@media (prefers-reduced-motion: reduce) {
  .hero__photo { animation: none; transform: scale(1.02); }
  .hero__photo--1 { opacity: 1; }
  .hero__photo--2,
  .hero__photo--3,
  .hero__photo--4,
  .hero__photo--5,
  .hero__photo--6 { opacity: 0; }
}

/* Overlay — vertical gradient anchoring the type to the lower-left */
.hero__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to top, rgba(0,0,0,0.78) 0%, rgba(0,0,0,0.35) 45%, rgba(0,0,0,0.15) 100%),
    linear-gradient(to right, rgba(0,0,0,0.4) 0%, rgba(0,0,0,0) 60%);
  pointer-events: none;
}

.hero__inner {
  position: relative;
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--gutter) clamp(2.5rem, 5vw, 4.5rem);
}

.hero__eyebrow {
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.22em;
  color: var(--oxide);
  text-transform: uppercase;
  margin: 0 0 1.25rem;
  font-weight: 500;
}

.hero__wordmark {
  font-family: var(--display);
  font-weight: 900;
  font-size: var(--step-hero);
  line-height: 0.92;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: var(--bone);
  margin: 0 0 1.5rem;
  /* Hard slab — no italic, no mixed-case; the cap-height is the design */
}

.hero__tagline {
  font-family: var(--mono);
  font-size: 0.875rem;
  letter-spacing: 0.04em;
  color: var(--bone);
  margin: 0 0 1.5rem;
  line-height: 1.65;
  text-transform: lowercase;
  max-width: 52ch;
}

.hero__strip {
  font-family: var(--mono);
  font-size: var(--step-meta-sm);
  letter-spacing: 0.18em;
  color: var(--oxide);
  text-transform: uppercase;
  margin: 0;
  padding-top: 1.25rem;
  border-top: 1px solid var(--oxide-dim);
  display: inline-block;
  min-width: 18rem;
}

/* -------------------------------------------------------------------
   02 — TRANSMISSIONS (releases)
   ------------------------------------------------------------------- */
.transmissions {
  padding: var(--section-pad) 0 0;
  background: var(--ink);
}

.releases {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--rule);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}

.release {
  background: var(--ink);
  padding: clamp(1.75rem, 3vw, 2.5rem) clamp(1.5rem, 2.5vw, 2rem);
  display: flex;
  flex-direction: column;
  min-height: 16rem;
}

.release__year {
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.22em;
  color: var(--oxide);
  text-transform: uppercase;
  margin: 0 0 1.25rem;
  font-weight: 500;
}

.release__title {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  line-height: 1;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--bone);
  margin: 0 0 0.875rem;
}

.release__detail {
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.06em;
  color: var(--bone-soft);
  margin: 0 0 auto;
  text-transform: lowercase;
}

.release__listen {
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.18em;
  color: var(--oxide);
  text-transform: uppercase;
  margin-top: 1.75rem;
  border-bottom: 1px solid transparent;
  align-self: flex-start;
  transition: border-color 160ms var(--ease-out);
  padding-bottom: 1px;
}
.release__listen:hover { border-bottom-color: var(--oxide); }

@media (max-width: 859px) {
  .releases { grid-template-columns: 1fr; }
}

/* Photo break — full-bleed warm-tungsten hands shot */
.photobreak {
  margin: clamp(4rem, 7vw, 6rem) 0 0;
  padding: 0;
  position: relative;
  overflow: hidden;
}

.photobreak img {
  width: 100%;
  height: clamp(280px, 50vw, 540px);
  object-fit: cover;
  object-position: center;
  filter: contrast(1.05);
}

/* -------------------------------------------------------------------
   03 — MIXES (recorded sets — type-led, no images)
   ------------------------------------------------------------------- */
.mixes {
  padding: var(--section-pad) 0;
  background: var(--ink);
}

.mix-list {
  border-top: 1px solid var(--rule);
}

.mix {
  display: grid;
  grid-template-columns: 2fr minmax(10rem, 1fr) auto;
  gap: 1.5rem;
  align-items: center;
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--rule);
}

.mix__title {
  font-family: var(--display);
  font-weight: 700;
  font-size: 1.0625rem;
  letter-spacing: 0.02em;
  color: var(--bone);
  text-transform: uppercase;
}

.mix__detail {
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.06em;
  color: var(--bone-soft);
  text-transform: lowercase;
}

.mix__listen {
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.18em;
  color: var(--oxide);
  text-transform: uppercase;
  border-bottom: 1px solid transparent;
  padding-bottom: 1px;
  transition: border-color 160ms var(--ease-out);
  justify-self: end;
}
.mix__listen:hover { border-bottom-color: var(--oxide); }

@media (max-width: 759px) {
  .mix {
    grid-template-columns: 1fr;
    gap: 0.5rem;
    padding: 1.25rem 0;
  }
  .mix__listen { justify-self: start; margin-top: 0.5rem; }
}

/* -------------------------------------------------------------------
   04 — RESIDENCY (live dates — schedule auto-bumps)
   ------------------------------------------------------------------- */
.residency {
  padding: var(--section-pad) 0;
  background: var(--ink);
}

.schedule {
  display: flex;
  flex-direction: column;
  gap: clamp(2rem, 4vw, 3.5rem);
}

/* Featured next gig — the single most prominent row, oxide-red bordered */
.schedule__featured {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  gap: 1.5rem;
  align-items: center;
  padding: 1.75rem clamp(1.25rem, 2.5vw, 2rem);
  border: 1px solid var(--oxide);
  background: rgba(215, 59, 42, 0.06);
}

.schedule__featured-label {
  font-family: var(--mono);
  font-size: var(--step-meta-sm);
  letter-spacing: 0.22em;
  color: var(--oxide);
  text-transform: uppercase;
  border: 1px solid var(--oxide);
  padding: 0.375rem 0.625rem;
}

.schedule__featured-date {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  letter-spacing: -0.01em;
  color: var(--bone);
  text-transform: uppercase;
  line-height: 1;
}

.schedule__featured-place {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  text-align: right;
}

.schedule__featured-city {
  font-family: var(--display);
  font-weight: 900;
  font-size: 1.125rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--bone);
}

.schedule__featured-venue {
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.06em;
  color: var(--bone-soft);
  text-transform: lowercase;
}

.schedule__featured-book {
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.18em;
  color: var(--ink);
  background: var(--oxide);
  text-transform: uppercase;
  padding: 0.625rem 1rem;
  transition: background 160ms var(--ease-out);
  white-space: nowrap;
}
.schedule__featured-book:hover { background: var(--bone); }

@media (max-width: 759px) {
  .schedule__featured {
    grid-template-columns: 1fr;
    gap: 1rem;
    text-align: left;
  }
  .schedule__featured-place { text-align: left; }
  .schedule__featured-book { justify-self: start; }
}

/* Group title (UPCOMING / PAST) */
.schedule__group {
  display: flex;
  flex-direction: column;
}

.schedule__group-title {
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.22em;
  color: var(--oxide);
  text-transform: uppercase;
  margin: 0 0 1.25rem;
  font-weight: 500;
}

.schedule__list {
  border-top: 1px solid var(--rule);
}

.schedule__row {
  display: grid;
  grid-template-columns: 7rem 11rem minmax(0, 1fr) auto;
  gap: 1.5rem;
  align-items: center;
  padding: 1rem 0;
  border-bottom: 1px solid var(--rule);
}

.schedule__list--past .schedule__row {
  opacity: 0.55;
}

.schedule__row-date {
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.06em;
  color: var(--bone);
}

.schedule__row-city {
  font-family: var(--display);
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--bone);
}

.schedule__row-venue {
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.06em;
  color: var(--bone-soft);
  text-transform: lowercase;
}

.schedule__row-book {
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.18em;
  color: var(--oxide);
  text-transform: uppercase;
  border-bottom: 1px solid transparent;
  padding-bottom: 1px;
  transition: border-color 160ms var(--ease-out);
  justify-self: end;
  white-space: nowrap;
}
.schedule__row-book:hover { border-bottom-color: var(--oxide); }

@media (max-width: 759px) {
  .schedule__row {
    grid-template-columns: 1fr;
    gap: 0.375rem;
    padding: 1rem 0;
  }
  .schedule__row-book { justify-self: start; margin-top: 0.5rem; }
}

/* -------------------------------------------------------------------
   05 — CONTACT
   ------------------------------------------------------------------- */
.contact {
  padding: var(--section-pad) 0;
  background: var(--ink);
}

.contact-methods {
  border-top: 1px solid var(--rule);
  margin-bottom: clamp(4rem, 7vw, 6rem);
}

.contact-method {
  display: grid;
  grid-template-columns: minmax(11rem, auto) 1fr;
  gap: 1.5rem;
  align-items: baseline;
  padding: 1.25rem 0;
  border-bottom: 1px solid var(--rule);
}

.contact-method__label {
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.22em;
  color: var(--oxide);
  text-transform: uppercase;
}

.contact-method__value {
  font-family: var(--mono);
  font-size: 1rem;
  letter-spacing: 0.02em;
  color: var(--bone);
}

a.contact-method__value {
  border-bottom: 1px solid transparent;
  transition: border-color 160ms var(--ease-out), color 160ms var(--ease-out);
  padding-bottom: 2px;
}
a.contact-method__value:hover {
  border-bottom-color: var(--oxide);
  color: var(--oxide);
}

.contact-method__note {
  color: var(--bone-dim);
  font-size: 0.875rem;
  margin-left: 0.5rem;
  letter-spacing: 0.04em;
}

@media (max-width: 600px) {
  .contact-method {
    grid-template-columns: 1fr;
    gap: 0.375rem;
    padding: 1rem 0;
  }
}

.contact-closer {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(2rem, 5vw, 4rem);
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--oxide);
  text-align: center;
  margin: 0;
  padding: clamp(2rem, 5vw, 4rem) 0 0;
  line-height: 0.95;
}

/* -------------------------------------------------------------------
   Footer
   ------------------------------------------------------------------- */
.footer {
  padding: clamp(2.5rem, 5vw, 4rem) 0 clamp(3rem, 5vw, 4.5rem);
  border-top: 1px solid var(--rule);
  background: var(--ink);
}

.footer__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.footer__line {
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.18em;
  color: var(--bone-soft);
  text-transform: uppercase;
  margin: 0;
}

.footer__sevra {
  color: var(--oxide);
  border-bottom: 1px solid transparent;
  transition: border-color 160ms var(--ease-out);
}
.footer__sevra:hover { border-bottom-color: var(--oxide); }

/* -------------------------------------------------------------------
   Scroll reveals (Convention 18)
   CSS holds the initial hidden state. JS adds .is-revealed when the
   element enters the viewport. Stagger handled here via nth-child.
   ------------------------------------------------------------------- */
.reveal {
  opacity: 0;
  transform: translateY(14px);
  transition:
    opacity 700ms var(--ease-out),
    transform 700ms var(--ease-out);
}
.reveal.is-revealed {
  opacity: 1;
  transform: none;
}

.releases .release:nth-child(1) { transition-delay: 0ms; }
.releases .release:nth-child(2) { transition-delay: 90ms; }
.releases .release:nth-child(3) { transition-delay: 180ms; }

.mix-list .mix:nth-child(1) { transition-delay: 0ms; }
.mix-list .mix:nth-child(2) { transition-delay: 90ms; }
.mix-list .mix:nth-child(3) { transition-delay: 180ms; }

@media (prefers-reduced-motion: reduce) {
  .reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* -------------------------------------------------------------------
   Copy-to-clipboard toast (Convention 1)
   ------------------------------------------------------------------- */
.copy-status {
  position: fixed;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%) translateY(0.5rem);
  background: var(--oxide);
  color: var(--ink);
  padding: 0.625rem 1rem;
  font-family: var(--mono);
  font-size: var(--step-meta);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0;
  pointer-events: none;
  transition: opacity 200ms, transform 200ms;
  z-index: 1000;
}
.copy-status.is-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .copy-status { transition: none; }
}