/* v1.5.1 Neuborn webfont settings.
   Place the licensed Neuborn font files in assets/fonts/ using these exact filenames. */
@font-face {
  font-family: "Neuborn";
  src: url("assets/fonts/Neuborn-Regular.otf") format("opentype"),
       local("Neuborn Regular"),
       local("Neuborn-Regular");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Neuborn";
  src: url("assets/fonts/Neuborn-Medium.otf") format("opentype"),
       local("Neuborn Medium"),
       local("Neuborn-Medium");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Neuborn";
  src: url("assets/fonts/Neuborn-Bold.otf") format("opentype"),
       local("Neuborn Bold"),
       local("Neuborn-Bold");
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Neuborn Hollow";
  src: url("assets/fonts/Neuborn-RegularHollow.otf") format("opentype"),
       local("Neuborn Regular Hollow"),
       local("Neuborn-RegularHollow");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Neuborn Hollow";
  src: url("assets/fonts/Neuborn-MediumHollow.otf") format("opentype"),
       local("Neuborn Medium Hollow"),
       local("Neuborn-MediumHollow");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --bg: #050505;
  --bg-soft: #0a0a0a;
  --panel: rgba(255, 255, 255, 0.035);
  --panel-strong: rgba(255, 255, 255, 0.065);
  --text: #eeeeea;
  --muted: #a8a8a0;
  --dim: #6f6f68;
  --line: rgba(238, 238, 234, 0.18);
  --line-strong: rgba(238, 238, 234, 0.34);
  --accent: #d8d6c4;
  --accent-muted: #bdb9a3;
  --accent-line: rgba(216, 214, 196, 0.62);
  --accent-soft: rgba(216, 214, 196, 0.075);
  --accent-glow: rgba(216, 214, 196, 0.14);
  --accent: #d8d6c4;
  --accent-soft: rgba(216, 214, 196, 0.14);
  --accent-line: rgba(216, 214, 196, 0.42);
  --max: 1180px;
  --pad: clamp(1rem, 3vw, 2rem);
  --brand-font: "Neuborn Hollow", "Neuborn", "Inter", system-ui, sans-serif;
  --body-font: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background:
    radial-gradient(circle at 20% 10%, rgba(255, 255, 255, 0.08), transparent 26rem),
    radial-gradient(circle at 85% 25%, rgba(255, 255, 255, 0.045), transparent 22rem),
    linear-gradient(135deg, var(--bg), #090909 46%, #030303);
  color: var(--text);
  font-family: var(--body-font);
  line-height: 1.5;
  min-height: 100vh;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(rgba(255,255,255,0.028) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.022) 1px, transparent 1px);
  background-size: 84px 84px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,0.6), transparent 75%);
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.22;
  background-image: repeating-radial-gradient(circle at 50% 50%, rgba(255,255,255,0.12) 0 1px, transparent 1px 4px);
  mix-blend-mode: overlay;
}

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

a:hover,
a:focus-visible {
  color: #fff;
}

.skip-link {
  position: absolute;
  left: 1rem;
  top: 1rem;
  z-index: 10;
  transform: translateY(-150%);
  background: var(--text);
  color: var(--bg);
  padding: 0.65rem 0.85rem;
}

.skip-link:focus {
  transform: translateY(0);
}

.section-shell {
  width: min(100%, var(--max));
  margin-inline: auto;
  padding-inline: var(--pad);
}

.site-header {
  width: min(100%, calc(var(--max) + var(--pad) * 2));
  margin: 0 auto;
  padding: 1rem var(--pad);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  position: sticky;
  top: 0;
  z-index: 5;
  backdrop-filter: blur(18px);
  background: rgba(5, 5, 5, 0.72);
  border-bottom: 1px solid var(--line);
}

.brand-mark {
  font-family: var(--brand-font);
  font-weight: 800;
  letter-spacing: 0.08em;
  font-size: 0.95rem;
  border: 1px solid var(--line-strong);
  padding: 0.55rem 0.7rem;
  line-height: 1;
}

.site-nav {
  display: none;
  align-items: center;
  gap: 1rem;
  color: var(--muted);
  font-size: 0.76rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.hero {
  min-height: 76vh;
  display: grid;
  align-content: end;
  gap: 2rem;
  padding-block: clamp(5.5rem, 12vw, 9rem) 2rem;
}

.eyebrow,
.kicker {
  margin: 0;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

h1,
h2,
h3 {
  margin: 0;
  font-family: var(--brand-font);
  text-transform: uppercase;
  letter-spacing: 0.055em;
  line-height: 0.94;
}

h1 {
  margin-top: 1rem;
  font-size: clamp(4.4rem, 19vw, 14rem);
  font-weight: 800;
}

h2 {
  font-size: clamp(2.4rem, 8vw, 5.7rem);
  font-weight: 800;
}

h3 {
  font-size: clamp(1.1rem, 3vw, 1.55rem);
}

.hero__intro {
  max-width: 720px;
  margin: 1.25rem 0 0;
  color: var(--muted);
  font-size: clamp(1rem, 2vw, 1.25rem);
}

.hero__meta {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  color: var(--muted);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.tile-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.8rem;
  padding-block: 2rem 5rem;
}

.tile,
.event-card,
.release-panel,
.podcast-card,
.resident-card,
.merch-panel,
.about-section {
  border: 1px solid var(--line);
  background: var(--panel);
  box-shadow: 0 18px 60px rgba(0,0,0,0.28);
}

.tile {
  min-height: 220px;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: border-color 180ms ease, background 180ms ease, transform 180ms ease;
}

.tile:hover,
.tile:focus-visible {
  border-color: var(--line-strong);
  background: var(--panel-strong);
  transform: translateY(-2px);
}

.tile__number {
  color: var(--dim);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
}

.tile__title {
  font-family: var(--brand-font);
  font-size: clamp(1.75rem, 5.5vw, 3.4rem);
  font-weight: 800;
  line-height: 0.9;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  white-space: nowrap;
}

.tile__text {
  max-width: 24rem;
  color: var(--muted);
  font-size: 0.9rem;
}

.content-section {
  padding-block: 4rem;
  scroll-margin-top: 5.5rem;
}

.section-heading {
  margin-bottom: 1.5rem;
}

.section-heading--row {
  display: grid;
  gap: 1rem;
}

.section-note {
  margin: 0;
  color: var(--muted);
  max-width: 24rem;
}

.card-list,
.podcast-stack,
.resident-grid {
  display: grid;
  gap: 1rem;
}

.event-card {
  display: grid;
  grid-template-columns: 104px 1fr;
  min-height: 170px;
}

.event-card__poster,
.release-art,
.resident-card__image {
  display: grid;
  place-items: center;
  border-right: 1px solid var(--line);
  background:
    linear-gradient(145deg, rgba(255,255,255,0.14), rgba(255,255,255,0.025)),
    #111;
  color: var(--text);
  font-family: var(--brand-font);
  font-weight: 800;
  letter-spacing: 0.08em;
}

.event-card__body {
  padding: 1rem;
}

.event-card p,
.resident-card p {
  color: var(--muted);
  margin: 0.65rem 0 0;
}

.event-card a,
.resident-card a,
.footer-links a {
  display: inline-block;
  margin-top: 1rem;
  color: var(--text);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--line-strong);
}

.release-panel {
  padding: 1rem;
  display: grid;
  gap: 1rem;
}

.release-art {
  min-height: 270px;
  border: 1px solid var(--line);
  align-content: center;
  gap: 1rem;
  text-align: center;
}

.release-art span {
  font-size: clamp(2rem, 8vw, 4rem);
  line-height: 0.92;
}

.release-art small {
  color: var(--muted);
  letter-spacing: 0.18em;
}

.release-details {
  margin: 0;
  display: grid;
  gap: 0.85rem;
}

.release-details div {
  display: grid;
  gap: 0.2rem;
  padding-bottom: 0.85rem;
  border-bottom: 1px solid var(--line);
}

.release-details dt {
  color: var(--dim);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.release-details dd {
  margin: 0;
  font-size: clamp(1rem, 2vw, 1.25rem);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.podcast-card {
  padding: 1rem;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem;
  align-items: center;
}

.play-dot {
  width: 2.35rem;
  height: 2.35rem;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  position: relative;
}

.play-dot::after {
  content: "";
  position: absolute;
  left: 52%;
  top: 50%;
  transform: translate(-40%, -50%);
  border-left: 0.5rem solid var(--text);
  border-top: 0.32rem solid transparent;
  border-bottom: 0.32rem solid transparent;
}

.waveform {
  grid-column: 1 / -1;
  height: 34px;
  opacity: 0.62;
  background: repeating-linear-gradient(90deg, var(--muted) 0 2px, transparent 2px 7px);
  mask-image: linear-gradient(to bottom, transparent 0%, #000 35%, #000 70%, transparent 100%);
}

.resident-card {
  padding: 1rem;
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 1rem;
}

.resident-card__image {
  min-height: 92px;
  border: 1px solid var(--line);
  font-size: 2rem;
}

.about-section {
  padding-block: 4rem;
}

.about-copy {
  max-width: 880px;
  margin: 0;
  color: var(--text);
  font-size: clamp(1.15rem, 3vw, 2rem);
  line-height: 1.35;
  letter-spacing: -0.03em;
}

.site-footer {
  padding-block: 3rem;
  display: grid;
  gap: 1.5rem;
  border-top: 1px solid var(--line);
}

.footer-email {
  display: inline-block;
  margin-top: 0.5rem;
  font-size: clamp(1.4rem, 6vw, 3.2rem);
  font-family: var(--brand-font);
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1.25rem;
}

@media (min-width: 720px) {
  .site-nav {
    display: flex;
  }

  .hero__meta,
  .site-footer,
  .section-heading--row {
    grid-template-columns: 1fr auto;
    display: grid;
    align-items: end;
  }

  .tile-grid {
    grid-template-columns: repeat(6, 1fr);
  }

  .tile {
    grid-column: span 3;
  }

  .tile--large,
  .tile--wide {
    grid-column: span 6;
  }

  .release-panel,
  .resident-grid,
  .merch-panel {
    grid-template-columns: 0.85fr 1.15fr;
  }

  .event-card {
    grid-template-columns: 150px 1fr;
  }
}

@media (min-width: 980px) {
  .tile {
    grid-column: span 2;
  }

  .tile--large {
    grid-column: span 3;
  }

  .tile--long,
  .tile--wide {
    grid-column: span 3;
  }

  .card-list {
    grid-template-columns: repeat(3, 1fr);
  }

  .event-card {
    grid-template-columns: 1fr;
  }

  .event-card__poster {
    min-height: 250px;
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .podcast-card {
    grid-template-columns: auto 220px 1fr;
  }

  .waveform {
    grid-column: auto;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    transition: none !important;
  }
}

/* v1.3 refinements: staggered desktop tiles, mobile menu, footer meta, mobile back-to-top */
.menu-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  border: 1px solid var(--line-strong);
  background: rgba(255, 255, 255, 0.035);
  color: var(--text);
  padding: 0.55rem 0.7rem;
  font: inherit;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.72rem;
  font-weight: 800;
}

.menu-toggle__lines,
.menu-toggle__lines::before,
.menu-toggle__lines::after {
  display: block;
  width: 1rem;
  height: 1px;
  background: var(--text);
  content: "";
}

.menu-toggle__lines {
  position: relative;
}

.menu-toggle__lines::before,
.menu-toggle__lines::after {
  position: absolute;
  left: 0;
}

.menu-toggle__lines::before {
  top: -5px;
}

.menu-toggle__lines::after {
  top: 5px;
}

.site-header.is-menu-open .site-nav {
  display: grid;
}

.site-header .site-nav {
  position: absolute;
  top: calc(100% + 1px);
  left: var(--pad);
  right: var(--pad);
  padding: 0.8rem;
  background: rgba(5, 5, 5, 0.96);
  border: 1px solid var(--line);
  backdrop-filter: blur(18px);
  gap: 0;
}

.site-header .site-nav a {
  display: block;
  padding: 0.85rem 0.2rem;
  border-bottom: 1px solid var(--line);
}

.site-header .site-nav a:last-child {
  border-bottom: 0;
}

.footer-meta {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 1rem;
  color: var(--dim);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.footer-meta p {
  margin: 0;
}

.footer-meta a {
  color: var(--muted);
  border-bottom: 1px solid rgba(168, 168, 160, 0.35);
}

.back-to-top {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  z-index: 6;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.1rem;
  height: 3.1rem;
  border: 1px solid var(--line-strong);
  background: rgba(5, 5, 5, 0.78);
  backdrop-filter: blur(18px);
  color: var(--text);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

@media (min-width: 720px) {
  .menu-toggle {
    display: none;
  }

  .site-header .site-nav,
  .site-header.is-menu-open .site-nav {
    position: static;
    display: flex;
    padding: 0;
    background: transparent;
    border: 0;
    backdrop-filter: none;
    gap: 1rem;
  }

  .site-header .site-nav a {
    padding: 0;
    border-bottom: 0;
  }

  .tile--events {
    grid-column: span 4;
  }

  .tile--label {
    grid-column: span 2;
  }

  .tile--podcast,
  .tile--residents {
    grid-column: span 3;
  }

  .tile--merch {
    grid-column: span 2;
  }

  .tile--about {
    grid-column: span 4;
  }

  .back-to-top {
    display: none;
  }
}

@media (min-width: 980px) {
  .tile-grid {
    grid-template-columns: repeat(12, 1fr);
  }

  .tile--events {
    grid-column: span 5;
  }

  .tile--label {
    grid-column: span 3;
  }

  .tile--podcast {
    grid-column: span 4;
  }

  .tile--residents {
    grid-column: span 4;
  }

  .tile--merch {
    grid-column: span 3;
  }

  .tile--about {
    grid-column: span 5;
  }
}


/* v1.4.1 refinements: corrected accent variables and strengthened unified link interactions */
a,
button {
  transition:
    color 180ms ease,
    border-color 180ms ease,
    background 180ms ease,
    opacity 180ms ease,
    transform 180ms ease,
    box-shadow 180ms ease;
}

.text-link {
  color: var(--text);
  border-bottom: 1px solid rgba(238, 238, 234, 0.24);
}

.text-link:hover,
.text-link:focus-visible {
  color: var(--accent);
  border-color: var(--accent-line);
}

.site-nav a {
  position: relative;
  color: var(--muted);
}

.site-nav a:hover,
.site-nav a:focus-visible,
.site-header .site-nav a:hover,
.site-header .site-nav a:focus-visible {
  color: var(--accent);
  background: rgba(255, 255, 255, 0.035);
}

@media (min-width: 720px) {
  .site-nav a:hover,
  .site-nav a:focus-visible,
  .site-header .site-nav a:hover,
  .site-header .site-nav a:focus-visible {
    background: transparent;
  }
}

.menu-toggle:hover,
.menu-toggle:focus-visible {
  color: var(--accent);
  border-color: var(--accent-line);
  background: var(--accent-soft);
}

.menu-toggle:hover .menu-toggle__lines,
.menu-toggle:hover .menu-toggle__lines::before,
.menu-toggle:hover .menu-toggle__lines::after,
.menu-toggle:focus-visible .menu-toggle__lines,
.menu-toggle:focus-visible .menu-toggle__lines::before,
.menu-toggle:focus-visible .menu-toggle__lines::after {
  background: var(--accent);
}

.social-row,
.release-links,
.mini-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.social-row a,
.release-links a,
.mini-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.65rem;
  padding: 0.72rem 0.9rem;
  color: var(--muted);
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.025);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.13em;
  line-height: 1;
  text-transform: uppercase;
}

.social-row a:hover,
.social-row a:focus-visible,
.release-links a:hover,
.release-links a:focus-visible,
.mini-links a:hover,
.mini-links a:focus-visible {
  color: var(--accent);
  border-color: var(--accent-line);
  background: var(--accent-soft);
  box-shadow: inset 0 0 0 1px rgba(216, 214, 196, 0.035), 0 10px 30px rgba(0,0,0,0.22);
  transform: translateY(-2px);
}

.social-row--compact {
  gap: 0.5rem;
}

.social-row--compact a {
  min-height: 2.15rem;
  padding: 0.55rem 0.68rem;
  font-size: 0.66rem;
}

.footer-links {
  gap: 0.75rem;
}

.footer-links a {
  margin-top: 0;
  border-bottom: 0;
}

.tile {
  overflow: hidden;
  position: relative;
}

.tile::after {
  content: "";
  position: absolute;
  inset: auto 1rem 1rem 1rem;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent-line), transparent);
  opacity: 0;
  transform: translateX(-12%);
  transition: opacity 180ms ease, transform 180ms ease;
}

.tile:hover,
.tile:focus-visible {
  border-color: var(--accent-line);
  background: linear-gradient(145deg, rgba(216, 214, 196, 0.07), rgba(255, 255, 255, 0.03));
  box-shadow: 0 24px 76px rgba(0,0,0,0.42), 0 0 0 1px rgba(216, 214, 196, 0.045), inset 0 0 28px rgba(216, 214, 196, 0.025);
}

.tile:hover::after,
.tile:focus-visible::after {
  opacity: 1;
  transform: translateX(0);
}

.tile:hover .tile__title,
.tile:focus-visible .tile__title {
  color: var(--accent);
  text-shadow: 0 0 20px var(--accent-glow);
  letter-spacing: 0.045em;
}

.tile:hover .tile__number,
.tile:focus-visible .tile__number {
  color: var(--muted);
}

.event-card,
.release-card,
.resident-card,
.podcast-card,
.merch-panel {
  transition:
    border-color 180ms ease,
    background 180ms ease,
    transform 180ms ease,
    box-shadow 180ms ease;
}

.event-card:hover,
.event-card:focus-within,
.release-card:hover,
.release-card:focus-within,
.resident-card:hover,
.resident-card:focus-within,
.podcast-card:hover,
.podcast-card:focus-within,
.merch-panel:hover,
.merch-panel:focus-within {
  border-color: var(--accent-line);
  background: var(--panel-strong);
  transform: translateY(-2px);
}

.action-link,
.event-card a,
.resident-card a {
  position: relative;
  width: fit-content;
  color: var(--text);
  border-bottom: 1px solid var(--line-strong);
  transition: color 180ms ease, border-color 180ms ease, background 180ms ease, transform 180ms ease, padding-left 180ms ease;
}

.action-link:hover,
.action-link:focus-visible,
.event-card a:hover,
.event-card a:focus-visible,
.resident-card a:hover,
.resident-card a:focus-visible {
  color: var(--accent);
  border-color: var(--accent-line);
  background: linear-gradient(90deg, rgba(216, 214, 196, 0.08), transparent);
  padding-left: 0.35rem;
  transform: translateX(2px);
}

.event-card:hover .event-card__poster,
.event-card:focus-within .event-card__poster {
  color: var(--accent);
}

.release-panel--featured {
  margin-bottom: 3rem;
}

.release-content {
  display: grid;
  gap: 1.1rem;
}

.release-links {
  padding-top: 0.2rem;
}

.section-heading--small {
  margin-top: 0.5rem;
  margin-bottom: 1rem;
}

.section-heading--small h3 {
  margin-top: 0.45rem;
  font-size: clamp(1.6rem, 4vw, 2.6rem);
}

.release-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

.release-card {
  border: 1px solid var(--line);
  background: var(--panel);
  display: grid;
  min-height: 100%;
}

.release-card__art {
  min-height: 170px;
  display: grid;
  place-items: center;
  border-bottom: 1px solid var(--line);
  background:
    linear-gradient(145deg, rgba(255,255,255,0.11), rgba(255,255,255,0.02)),
    #111;
  color: var(--dim);
  font-family: var(--brand-font);
  font-size: clamp(2rem, 7vw, 3.5rem);
  font-weight: 800;
  letter-spacing: 0.08em;
}

.release-card__body {
  padding: 1rem;
}

.release-card__body h3 {
  margin-top: 0.4rem;
  font-size: clamp(1.15rem, 3vw, 1.45rem);
}

.release-card__body p:not(.kicker) {
  margin: 0.5rem 0 0;
  color: var(--muted);
}

.mini-links {
  gap: 0.45rem;
  margin-top: 1rem;
}

.mini-links a {
  min-height: 2.25rem;
  padding: 0.6rem 0.7rem;
  font-size: 0.65rem;
}

.footer-meta a:hover,
.footer-meta a:focus-visible {
  color: var(--accent);
  border-color: var(--accent-line);
}

.back-to-top {
  width: 2.8rem;
  height: 2.8rem;
  background: rgba(5, 5, 5, 0.42);
  border-color: rgba(238, 238, 234, 0.2);
  color: rgba(238, 238, 234, 0.68);
  opacity: 0.66;
  font-size: 1.25rem;
  line-height: 1;
  letter-spacing: 0;
  text-transform: none;
}

.back-to-top:hover,
.back-to-top:focus-visible {
  opacity: 0.95;
  color: var(--accent);
  border-color: var(--accent-line);
  background: rgba(5, 5, 5, 0.7);
  transform: translateY(-2px);
}

@media (max-width: 719px) {
  .social-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
  }

  .social-row a {
    width: 100%;
  }

  .social-row--compact {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 620px) {
  .release-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 980px) {
  .release-panel--featured {
    align-items: stretch;
  }

  .release-content {
    align-content: space-between;
  }

  .release-grid {
    grid-template-columns: repeat(5, 1fr);
  }

  .release-card__art {
    min-height: 150px;
  }
}


/* v1.4.3 refinements: add merch path for client review */
@media (min-width: 720px) {
  .tile--merch {
    grid-column: span 2;
  }

  .tile--about {
    grid-column: span 4;
  }
}

@media (min-width: 980px) {
  .tile--merch {
    grid-column: span 3;
  }

  .tile--about {
    grid-column: span 5;
  }
}

/* v1.4.4 correction: preserve v1.4.3 merch additions, restore v1.4.2 white hover behavior */
:root {
  --accent: #ffffff;
  --accent-muted: #eeeeea;
  --accent-line: rgba(238, 238, 234, 0.38);
  --accent-soft: rgba(255, 255, 255, 0.045);
  --accent-glow: rgba(255, 255, 255, 0.08);
}

.text-link:hover,
.text-link:focus-visible,
.site-nav a:hover,
.site-nav a:focus-visible,
.site-header .site-nav a:hover,
.site-header .site-nav a:focus-visible,
.menu-toggle:hover,
.menu-toggle:focus-visible,
.footer-meta a:hover,
.footer-meta a:focus-visible {
  color: #fff;
}

.social-row a:hover,
.social-row a:focus-visible,
.release-links a:hover,
.release-links a:focus-visible,
.mini-links a:hover,
.mini-links a:focus-visible {
  color: #fff;
  border-color: rgba(238, 238, 234, 0.42);
  background: rgba(255, 255, 255, 0.045);
  box-shadow: 0 10px 28px rgba(0,0,0,0.22);
  transform: translateY(-2px);
}

.tile:hover,
.tile:focus-visible {
  border-color: rgba(238, 238, 234, 0.36);
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.025));
  box-shadow: 0 24px 76px rgba(0,0,0,0.42), inset 0 0 28px rgba(255, 255, 255, 0.018);
}

.tile:hover .tile__title,
.tile:focus-visible .tile__title {
  color: #fff;
  text-shadow: 0 0 18px rgba(255,255,255,0.055);
  letter-spacing: 0.04em;
}

.tile::after {
  background: linear-gradient(90deg, transparent, rgba(238, 238, 234, 0.36), transparent);
}

.action-link:hover,
.action-link:focus-visible,
.event-card a:hover,
.event-card a:focus-visible,
.resident-card a:hover,
.resident-card a:focus-visible {
  color: #fff;
  border-color: rgba(238, 238, 234, 0.42);
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.045), transparent);
}

.event-card:hover .event-card__poster,
.event-card:focus-within .event-card__poster {
  color: #fff;
}

.back-to-top:hover,
.back-to-top:focus-visible {
  color: #fff;
  border-color: rgba(238, 238, 234, 0.4);
}

@media (max-width: 719px) {
  .social-row--compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}


/* v1.4.8 refinements: persistent desktop/mobile back-to-top button + cache-busted assets */
.back-to-top,
.back-to-top:link,
.back-to-top:visited,
.back-to-top:hover,
.back-to-top:focus,
.back-to-top:focus-visible,
.back-to-top:active {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.8rem;
  height: 2.8rem;
  background: rgba(5, 5, 5, 0.42);
  border: 1px solid rgba(238, 238, 234, 0.2);
  color: rgba(238, 238, 234, 0.68);
  opacity: 0.66;
  box-shadow: none;
  transform: none;
}

@media (min-width: 720px) {
  .back-to-top,
  .back-to-top:link,
  .back-to-top:visited,
  .back-to-top:hover,
  .back-to-top:focus,
  .back-to-top:focus-visible,
  .back-to-top:active {
    display: inline-flex;
  }
}


/* v1.4.9 refinements: real event flyers, release placeholder art, SoundCloud embeds, live/coming-soon links */
.social-row .link-disabled,
.release-links .link-disabled,
.mini-links .link-disabled,
.footer-links .link-disabled {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.65rem;
  padding: 0.72rem 0.9rem;
  color: rgba(238, 238, 234, 0.38);
  border: 1px solid rgba(238, 238, 234, 0.08);
  background: rgba(255, 255, 255, 0.012);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.13em;
  line-height: 1;
  text-transform: uppercase;
  cursor: default;
}

.link-disabled small {
  display: inline-block;
  margin-left: 0.4rem;
  color: rgba(238, 238, 234, 0.32);
  font-size: 0.72em;
  letter-spacing: 0.08em;
}

.social-row--compact .link-disabled {
  min-height: 2.15rem;
  padding: 0.55rem 0.68rem;
  font-size: 0.66rem;
}

.mini-links .link-disabled {
  min-height: 2.25rem;
  padding: 0.6rem 0.7rem;
  font-size: 0.65rem;
}

.link-disabled--inline {
  width: fit-content;
  border-bottom: 1px solid rgba(238, 238, 234, 0.12);
}

.event-card__poster--image {
  display: block;
  overflow: hidden;
  border-right: 1px solid var(--line);
  background: #050505;
}

.event-card__poster--image img {
  width: 100%;
  height: 100%;
  min-height: 100%;
  display: block;
  object-fit: cover;
  filter: grayscale(20%) saturate(0.92) contrast(1.04) brightness(0.82);
  transition: filter 180ms ease, transform 220ms ease;
}

.event-card:hover .event-card__poster--image img,
.event-card:focus-within .event-card__poster--image img {
  filter: grayscale(0%) saturate(1.02) contrast(1.06) brightness(0.92);
  transform: scale(1.018);
}

.release-art--image,
.release-card__art--image {
  position: relative;
  overflow: hidden;
  background: #050505;
}

.release-art--image img,
.release-card__art--image img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  filter: grayscale(100%) contrast(1.08) brightness(0.62);
}

.release-art--image::after,
.release-card__art--image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(5,5,5,0.08), rgba(5,5,5,0.42));
  pointer-events: none;
}

.release-art__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 1rem;
  padding: 1rem;
  text-align: center;
  background: rgba(0, 0, 0, 0.08);
}

.release-card__art--image {
  min-height: 190px;
}

.release-card__art--image::before {
  content: "TIII";
  position: absolute;
  z-index: 2;
  left: 0.85rem;
  bottom: 0.72rem;
  color: rgba(238, 238, 234, 0.72);
  font-family: var(--brand-font);
  font-size: 1.1rem;
  font-weight: 800;
  letter-spacing: 0.12em;
}

.podcast-embed-list {
  display: grid;
  gap: 1rem;
}

.podcast-embed-card {
  border: 1px solid var(--line);
  background: var(--panel);
  padding: 0.75rem;
  box-shadow: 0 18px 60px rgba(0,0,0,0.28);
  transition: border-color 180ms ease, background 180ms ease, transform 180ms ease, box-shadow 180ms ease;
}

.podcast-embed-card:hover,
.podcast-embed-card:focus-within {
  border-color: rgba(238, 238, 234, 0.36);
  background: var(--panel-strong);
  transform: translateY(-2px);
}

.podcast-embed-code iframe {
  display: block;
  width: 100%;
  border: 0;
  background: #050505;
}

.podcast-embed-code > div {
  margin-top: 0.45rem;
  opacity: 0.62;
}

.section-link {
  display: inline-flex;
  width: fit-content;
  margin-top: 1.25rem;
  color: var(--text);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--line-strong);
}

.section-link:hover,
.section-link:focus-visible {
  color: #fff;
  border-color: rgba(238, 238, 234, 0.42);
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.045), transparent);
  padding-left: 0.35rem;
  transform: translateX(2px);
}

@media (max-width: 719px) {
  .social-row .link-disabled,
  .release-links .link-disabled,
  .mini-links .link-disabled,
  .footer-links .link-disabled {
    width: 100%;
  }
}

@media (min-width: 980px) {
  .event-card__poster--image {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .event-card__poster--image img {
    min-height: 360px;
  }
}


/* v1.5.0 refinements: chronological event order, equal flyer frames, restored five-link latest release rows */
.card-list--events .event-card {
  grid-template-columns: 1fr;
  grid-template-rows: auto 1fr;
}

.card-list--events .event-card__poster--image {
  aspect-ratio: 4 / 5;
  width: 100%;
  min-height: 0;
  border-right: 0;
  border-bottom: 1px solid var(--line);
}

.card-list--events .event-card__poster--image img {
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
  object-position: center;
}

.card-list--events .event-card__body {
  display: flex;
  min-height: 100%;
  flex-direction: column;
}

.card-list--events .event-card__body .action-link {
  margin-top: auto;
}

.latest-release-note {
  color: var(--dim);
}


/* v1.5.1 refinements: webfont-ready Neuborn settings and merch panel consistency */
.merch-panel__body {
  padding: 1rem;
}

.merch-panel__body p:not(.kicker) {
  color: var(--muted);
  margin: 0.65rem 0 0;
}

.merch-panel__body .action-link {
  display: inline-block;
  margin-top: 1rem;
  color: var(--text);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border: 0;
  border-bottom: 1px solid var(--line-strong);
  background: transparent;
  padding: 0;
  min-height: auto;
}

.merch-panel__body .action-link.link-disabled,
.merch-panel__body .action-link.link-disabled--inline {
  color: var(--text);
  cursor: default;
}

.merch-panel__body .action-link.link-disabled:hover,
.merch-panel__body .action-link.link-disabled:focus-visible {
  color: var(--text);
  border-color: var(--line-strong);
  background: transparent;
  padding-left: 0;
  transform: none;
}

@media (min-width: 720px) {
  .merch-panel__body {
    align-self: stretch;
  }
}


/* v1.5.2 refinements: full flyer visibility, resident photos/bios, merch mark label alignment */
.card-list--events .event-card__poster--image img {
  object-fit: fill;
  object-position: center;
}

.event-card:hover .event-card__poster--image img,
.event-card:focus-within .event-card__poster--image img {
  transform: none;
}

.resident-card--image {
  grid-template-columns: 132px 1fr;
  align-items: stretch;
}

.resident-card__image--photo {
  min-height: 168px;
  overflow: hidden;
  border: 1px solid var(--line);
  background: #050505;
}

.resident-card__image--photo img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
  filter: grayscale(100%) contrast(1.06) brightness(0.82);
  transition: filter 180ms ease, transform 220ms ease;
}

.resident-card:hover .resident-card__image--photo img,
.resident-card:focus-within .resident-card__image--photo img {
  filter: grayscale(82%) contrast(1.08) brightness(0.92);
  transform: scale(1.018);
}

.merch-panel__mark {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  min-height: 100%;
  padding: 1rem;
  color: var(--dim);
  border-right: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.012);
  font-family: var(--body-font);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  line-height: 1;
  text-transform: uppercase;
}

@media (max-width: 719px) {
  .resident-card--image {
    grid-template-columns: 1fr;
  }

  .resident-card__image--photo {
    min-height: 260px;
  }

  .merch-panel__mark {
    min-height: auto;
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }
}


/* v1.5.3 final prototype refinements: residents, podcast embeds, section CTAs, merch height */
.resident-grid {
  grid-template-columns: 1fr;
}

.resident-card__image--photo {
  aspect-ratio: 1 / 1;
  min-height: 0;
  align-self: start;
}

.resident-card__image--photo img {
  height: 100%;
  min-height: 0;
  object-fit: cover;
  object-position: center;
}

.merch-panel__mark {
  min-height: 120px;
}

.merch-panel__body {
  align-self: center;
}

.releases-more-link small {
  display: inline-block;
  margin-left: 0.45rem;
  color: rgba(238, 238, 234, 0.32);
  font-size: 0.72em;
  letter-spacing: 0.08em;
}

@media (min-width: 720px) {
  .resident-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .resident-card {
    grid-template-columns: 0.72fr 1fr;
  }

  .resident-card__image--photo,
  .resident-card__image--photo img {
    min-height: 0;
  }
}

@media (max-width: 719px) {
  .merch-panel__mark {
    min-height: 72px;
  }
}


/* v1.5.5 refinements: section notes, subtle diagonal section breaks, merch CTA hover parity */
.content-section {
  position: relative;
}

.content-section::before {
  content: "";
  position: absolute;
  top: 0.35rem;
  left: var(--pad);
  right: var(--pad);
  height: clamp(1.6rem, 3.5vw, 3rem);
  pointer-events: none;
  opacity: 0.52;
  background:
    linear-gradient(164deg, transparent calc(50% - 0.5px), rgba(238, 238, 234, 0.18) 50%, transparent calc(50% + 0.5px));
}

.content-section:nth-of-type(even)::before {
  background:
    linear-gradient(16deg, transparent calc(50% - 0.5px), rgba(238, 238, 234, 0.14) 50%, transparent calc(50% + 0.5px));
}

.section-heading--row .section-note {
  align-self: end;
}

.merch-store-link {
  margin-top: 1rem;
}

.merch-panel__body .merch-store-link.link-disabled,
.merch-panel__body .merch-store-link.link-disabled--inline {
  color: var(--text);
  cursor: default;
}

.merch-panel__body .merch-store-link.link-disabled:hover,
.merch-panel__body .merch-store-link.link-disabled:focus-visible {
  color: #fff;
  border-color: rgba(238, 238, 234, 0.42);
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.045), transparent);
  padding-left: 0.35rem;
  transform: translateX(2px);
}

/* v1.5.6 refinements: solid Neuborn for smaller content titles */
.event-card h3,
.release-card__body h3,
.resident-card h3,
.merch-panel__body h3 {
  font-family: "Neuborn", "Inter", system-ui, sans-serif;
}

/* v1.5.7 final tweak: top-left brand mark uses solid Neuborn instead of hollow */
.brand-mark {
  font-family: "Neuborn", "Inter", system-ui, sans-serif;
}
