:root {
  --bg: #000;
  --surface: rgba(12, 12, 11, 0.965);
  --surface-raised: rgba(18, 18, 16, 0.92);
  --surface-strong: #151512;
  --ink: #e9e3d8;
  --muted: #9d9487;
  --line: rgba(233, 227, 216, 0.16);
  --line-soft: rgba(233, 227, 216, 0.085);
  --dark: #000;
  --acid: #d8d0c2;
  --acid-soft: rgba(233, 227, 216, 0.07);
  --shadow: 0 28px 80px rgba(0, 0, 0, 0.48);
  --rail-width: 64px;
  --content-split: 63.2653%;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background:
    radial-gradient(circle at 18% -12%, rgba(233, 227, 216, 0.065), transparent 34rem),
    linear-gradient(180deg, #000 0%, #050504 44%, #000 100%);
  color: var(--ink);
  font-family: "Inter", system-ui, sans-serif;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.22;
  background-image: linear-gradient(rgba(233, 227, 216, 0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(233, 227, 216, 0.018) 1px, transparent 1px);
  background-size: 32px 32px;
}

img,
video {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
}

h1,
h2,
h3,
p,
ul {
  margin: 0;
}

p,
li,
a,
button {
  font-size: clamp(0.92rem, 0.24vw + 0.88rem, 1.02rem);
  line-height: 1.45;
}

button {
  font: inherit;
}

.page-shell {
  width: min(1360px, calc(100% - 36px));
  margin: 0 auto;
  padding: 14px 0 36px;
  position: relative;
  z-index: 1;
}

.page-panel {
  border: 1px solid var(--line);
  background: var(--surface);
  box-shadow: var(--shadow);
}

.site-header {
  position: sticky;
  top: 12px;
  z-index: 20;
  display: grid;
  grid-template-columns: 72px minmax(210px, 0.72fr) 1fr auto;
  align-items: center;
  margin-bottom: 14px;
  overflow: hidden;
  border-color: var(--line-soft);
  backdrop-filter: blur(14px);
}

.wordmark,
.top-nav a,
.book-nav,
.booking-email,
.contact-link,
.inline-link {
  text-decoration: none;
}

.wordmark {
  grid-column: 1 / 3;
  min-height: 54px;
  display: flex;
  align-items: center;
  padding: 0 18px;
  background: rgba(233, 227, 216, 0.92);
  color: var(--dark);
  font-size: 0.98rem;
  font-weight: 900;
  letter-spacing: 0.17em;
  text-transform: uppercase;
}

.top-nav {
  grid-column: 3;
  display: flex;
  justify-content: center;
  gap: 26px;
  padding: 0 22px;
  flex-wrap: wrap;
}

.top-nav a,
.eyebrow,
.card-kicker,
.section-number,
.rail-mark,
.clip-tag,
.book-nav,
.video-toggle,
.inline-link {
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: 800;
}

.top-nav a {
  padding: 8px 0;
  font-size: 0.75rem;
  color: var(--muted);
}

.book-nav {
  grid-column: 4;
  min-height: 54px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--surface-raised);
  color: var(--ink);
  border-left: 1px solid var(--line);
  padding: 0 22px;
  font-size: 0.75rem;
}

.hero-section,
.media-feature,
.info-module,
.text-section,
.contact-panel {
  display: grid;
  grid-template-columns: var(--rail-width) minmax(0, 1fr);
}

.hero-section {
  grid-template-columns:
    var(--rail-width)
    minmax(0, 1.55fr)
    minmax(320px, 0.9fr);
}

.section-rail {
  border-right: 1px solid var(--line);
  padding: 12px 9px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 16px;
  background: rgba(233, 227, 216, 0.025);
  color: rgba(233, 227, 216, 0.68);
}

.section-number {
  font-size: clamp(1rem, 0.9vw + 0.8rem, 1.3rem);
  line-height: 0.9;
  letter-spacing: 0.03em;
}

.rail-mark {
  font-size: 1.4rem;
  line-height: 1;
}

.eyebrow,
.card-kicker,
.clip-tag,
.video-toggle,
.inline-link {
  font-size: 0.72rem;
}

.hero-content {
  display: contents;
}

.hero-copy {
  grid-column: 2;
  padding: 22px 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 20px;
  min-height: 270px;
}

.hero-aside {
  grid-column: 3;
  border-left: 1px solid var(--line);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  background: rgba(233, 227, 216, 0.014);
  min-height: 270px;
}

.booking-strip {
  background: linear-gradient(180deg, rgba(233, 227, 216, 0.07), rgba(233, 227, 216, 0.035));
  border-bottom: 1px solid var(--line);
  padding: 20px;
  display: grid;
  gap: 8px;
  align-content: start;
}

.booking-email {
  font-size: clamp(0.98rem, 0.48vw + 0.88rem, 1.18rem);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.04em;
  overflow-wrap: anywhere;
}

.hero-image {
  margin: 0;
  padding: 20px;
  display: flex;
  align-items: center;
}

.hero-image img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border: 1px solid var(--line);
  filter: grayscale(1) contrast(1.08);
  background: var(--surface-strong);
}

h1,
h2,
h3 {
  text-transform: uppercase;
}

h1 {
  max-width: 8.2ch;
  font-size: clamp(3rem, 4vw, 5.2rem);
  line-height: 0.88;
  letter-spacing: -0.09em;
  margin-bottom: 10px;
}

.hero-subtitle {
  margin-bottom: 14px;
  font-size: clamp(1rem, 0.85vw + 0.86rem, 1.35rem);
  line-height: 1;
  letter-spacing: -0.04em;
  text-transform: uppercase;
  font-weight: 600;
}

.hero-text,
.feature-text,
.module-text,
.bio-block p,
.contact-content p {
  max-width: 44rem;
  color: rgba(233, 227, 216, 0.82);
}

.editorial-grid {
  display: grid;
  grid-template-columns:
    calc(var(--rail-width) + (100% - var(--rail-width)) * 0.6326530612)
    calc((100% - var(--rail-width)) * 0.3673469388);
  gap: 0;
  margin-top: 16px;
  border: 1px solid var(--line);
  background: var(--surface);
  box-shadow: var(--shadow);
}

.editorial-grid > .page-panel,
.editorial-grid .side-stack > .page-panel {
  border: 0;
  box-shadow: none;
  background: transparent;
}

.media-feature {
  min-height: 100%;
  border-right: 1px solid var(--line) !important;
}

.feature-content,
.module-content,
.text-content,
.contact-content {
  padding: 22px;
}

.side-stack .module-content {
  padding: 14px 16px;
}

.feature-content {
  display: grid;
  align-content: start;
  gap: 18px;
}

.feature-heading,
.module-header {
  display: grid;
  gap: 10px;
}

h2 {
  font-size: clamp(1.95rem, 2.2vw, 3.3rem);
  line-height: 0.92;
  letter-spacing: -0.07em;
  max-width: 12ch;
}

h3 {
  font-size: clamp(1.08rem, 0.9vw + 0.9rem, 1.65rem);
  line-height: 0.95;
  letter-spacing: -0.05em;
  max-width: 16ch;
}

.video-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  align-items: start;
}

.video-card {
  min-width: 0;
}

.video-frame {
  position: relative;
  aspect-ratio: 9 / 16;
  overflow: hidden;
  border: 1px solid var(--line);
  background: var(--surface-strong);
}

.video-frame video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(1) contrast(1.08);
  background: #111;
}

.clip-tag {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 2;
  padding: 6px 8px;
  background: rgba(0, 0, 0, 0.62);
  border: 1px solid var(--line);
  color: rgba(233, 227, 216, 0.82);
  backdrop-filter: blur(10px);
}

.video-toggle {
  position: absolute;
  right: 12px;
  bottom: 12px;
  z-index: 2;
  border: 1px solid var(--line);
  background: rgba(0, 0, 0, 0.68);
  color: var(--ink);
  padding: 6px 8px;
  cursor: pointer;
}

.video-fallback {
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 50px;
  z-index: 2;
  padding: 10px 12px;
  border: 1px solid var(--line);
  background: rgba(0, 0, 0, 0.76);
  font-size: 0.72rem;
  line-height: 1.35;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 800;
}

.side-stack {
  display: grid;
  gap: 0;
}

.side-stack > .page-panel + .page-panel {
  border-top: 1px solid var(--line);
}

.support-rows,
.format-list,
.listen-actions {
  display: grid;
  gap: 0;
}

.support-rows {
  margin-top: 10px;
  border-top: 1px solid var(--line);
}

.support-row {
  display: grid;
  grid-template-columns: minmax(120px, 0.42fr) minmax(0, 1fr);
  gap: 12px;
  padding: 8px 0;
  border-bottom: 1px solid var(--line);
}

.support-row:last-child {
  border-bottom: 0;
}

.format-list {
  list-style: none;
  padding: 0;
}

.format-list {
  margin-top: 16px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.format-list li {
  border-top: 1px solid var(--line);
  padding-top: 10px;
}

.accent-panel {
  background: linear-gradient(180deg, rgba(19, 18, 16, 0.92), rgba(12, 12, 11, 0.98) 52%);
}

.inline-link {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  border: 1px solid var(--line);
  padding: 10px 12px;
  background: var(--surface-strong);
}

.secondary-link {
  background: transparent;
}

.text-section,
.contact-panel {
  margin-top: 16px;
}

.bio-block {
  display: grid;
  grid-template-columns: minmax(260px, 0.72fr) minmax(0, 1fr);
  gap: 28px;
  align-items: start;
}

.bio-block p {
  max-width: 58rem;
}

.contact-content {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 0.72fr);
  gap: 24px;
  align-items: end;
  background: linear-gradient(180deg, rgba(17, 17, 15, 0.82), rgba(10, 10, 9, 0.96) 46%);
}

.contact-link {
  min-height: 148px;
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 22px;
  background: var(--surface-strong);
  font-size: clamp(1.08rem, 1.25vw, 1.52rem);
  font-weight: 900;
  letter-spacing: -0.04em;
  word-break: break-word;
}

.top-nav a:hover,
.top-nav a:focus-visible,
.booking-email:hover,
.booking-email:focus-visible,
.wordmark:hover,
.wordmark:focus-visible,
.book-nav:hover,
.book-nav:focus-visible,
.contact-link:hover,
.contact-link:focus-visible,
.inline-link:hover,
.inline-link:focus-visible,
.video-toggle:hover,
.video-toggle:focus-visible {
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

@media (max-width: 1120px) {
  .site-header {
    grid-template-columns: 1fr;
  }

  .book-nav {
    border-left: 0;
    border-top: 1px solid var(--line);
  }

  .hero-content,
  .editorial-grid,
  .contact-content,
  .support-columns {
    grid-template-columns: 1fr;
  }

  .hero-aside {
    border-left: 0;
    border-top: 1px solid var(--line);
  }

  .video-grid {
    grid-template-columns: 1.05fr 1fr 1.18fr;
  }
}

@media (max-width: 900px) {
  .hero-section,
  .media-feature,
  .info-module,
  .text-section,
  .contact-panel {
    grid-template-columns: 1fr;
  }

  .section-rail {
    border-right: 0;
    border-bottom: 1px solid var(--line);
    flex-direction: row;
    align-items: center;
  }

  .video-grid,
  .support-row,
  .format-list,
  .contact-content,
  .bio-block {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .page-shell {
    width: min(100% - 16px, 1480px);
  }

  .site-header {
    position: static;
  }

  .wordmark,
  .book-nav {
    min-height: 50px;
  }

  .top-nav {
    justify-content: flex-start;
    gap: 16px;
    padding: 14px 18px;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
  }

  .hero-copy,
  .feature-content,
  .module-content,
  .text-content,
  .contact-content,
  .hero-image,
  .booking-strip {
    padding: 16px;
  }

  h1 {
    font-size: clamp(3rem, 17vw, 4.7rem);
  }

  h2 {
    max-width: none;
    font-size: clamp(2rem, 11vw, 3.2rem);
  }

  .video-grid {
    grid-template-columns: 1fr;
  }

  .video-frame {
    aspect-ratio: 9 / 13;
  }
}

.clean-format-list {
  margin-top: 10px;
  grid-template-columns: 1fr;
}

.clean-format-list li {
  padding: 8px 0;
  border-top: 1px solid var(--line);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 700;
}

.mixcloud-embed {
  display: block;
  width: 100%;
  height: 82px;
  border: 1px solid var(--line);
  background: var(--line);
  margin-top: 10px;
}


.support-row {
  grid-template-columns: minmax(92px, 0.32fr) minmax(0, 1fr);
  align-items: start;
}

.support-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 7px;
  align-items: baseline;
}

.support-tags span {
  white-space: nowrap;
}

.support-tags span:not(:last-child)::after {
  content: " ·";
}

/* Align media feature with right-side 002/003 stack */
.editorial-grid {
  align-items: stretch;
}

.media-feature {
  height: 100%;
}

.feature-content {
  height: 100%;
}

.video-grid {
  align-items: stretch;
}

.video-card,
.video-frame {
  height: 100%;
}


/* Video-only media feature */
.media-feature .feature-content {
  padding-top: 20px;
  padding-bottom: 20px;
}

.media-feature .video-grid {
  height: 100%;
}

/* Final composition tweaks: bio under videos + cleaner support rows */
.hero-copy {
  justify-content: center;
}

.media-feature .feature-content {
  height: 100%;
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 18px;
}

.media-feature .video-grid {
  height: auto;
  align-items: start;
}

.media-feature .video-card,
.media-feature .video-frame {
  height: auto;
}

.media-bio {
  align-self: end;
  border-top: 1px solid var(--line);
  padding-top: 14px;
  display: grid;
  grid-template-columns: minmax(90px, 0.25fr) minmax(0, 1fr) minmax(0, 1fr);
  gap: 16px;
}

.media-bio h3 {
  max-width: none;
}

.media-bio p {
  max-width: 34rem;
}

.support-row {
  display: block;
  padding: 9px 0;
}

.support-row .card-kicker {
  margin-bottom: 5px;
  letter-spacing: 0.1em;
  line-height: 1.15;
}

.support-tags {
  gap: 3px 6px;
  line-height: 1.35;
}

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

/* Hard override: keep support labels/names from colliding */
.support-row {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 6px !important;
  padding: 9px 0 !important;
}

.support-row .card-kicker {
  margin: 0 !important;
  max-width: none !important;
  white-space: normal !important;
}

.support-tags {
  display: block !important;
  line-height: 1.35 !important;
}

.support-tags span {
  white-space: normal !important;
}

/* Bio rhythm refinement */
.media-bio {
  grid-template-columns: minmax(70px, 0.18fr) minmax(0, 1fr) minmax(0, 1fr);
  gap: 12px;
  padding-top: 12px;
}

.media-bio p {
  max-width: none;
  line-height: 1.38;
}

/* Tighten gap under vertical videos */
.media-feature .feature-content {
  grid-template-rows: auto auto !important;
  align-content: start !important;
  gap: 10px !important;
}

.media-bio {
  align-self: start !important;
  margin-top: 0 !important;
  padding-top: 10px !important;
}

/* Hero wordmark closer to reference */
.hero-wordmark {
  max-width: none !important;
  white-space: nowrap;
  font-size: clamp(3.9rem, 6.15vw, 6.75rem) !important;
  line-height: 0.82 !important;
  letter-spacing: -0.105em !important;
}

@media (max-width: 900px) {
  .hero-wordmark {
    white-space: normal;
    font-size: clamp(3rem, 13vw, 5rem) !important;
  }
}

/* Match video top inset and bio divider spacing */
.media-feature .feature-content {
  gap: 20px !important;
}

.media-bio {
  padding-top: 12px !important;
}

/* Bio expanded copy layout */
.media-bio {
  grid-template-columns: minmax(70px, 0.16fr) repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.media-bio p {
  font-size: clamp(0.82rem, 0.18vw + 0.8rem, 0.92rem);
  line-height: 1.34;
}

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

/* Hero type fit + location moved under descriptor */
.hero-wordmark {
  font-size: clamp(3.35rem, 5.35vw, 5.9rem) !important;
  letter-spacing: -0.11em !important;
}

.hero-location {
  margin-top: 10px;
}

/* Narrower hero wordmark */
.hero-wordmark {
  font-size: clamp(3rem, 4.65vw, 5.1rem) !important;
  letter-spacing: -0.095em !important;
}

.hero-copy {
  padding-left: 24px;
}

/* Simplified compact header */
.site-header {
  position: static !important;
  grid-template-columns: minmax(260px, 0.42fr) 1fr minmax(120px, 150px) !important;
}

.wordmark {
  grid-column: 1 !important;
}

.top-nav {
  grid-column: 2 !important;
}

.book-nav {
  grid-column: 3 !important;
}

/* Header: external links right, no Book Us block */
.site-header {
  grid-template-columns: minmax(260px, 0.42fr) 1fr !important;
}

.top-nav {
  grid-column: 2 !important;
  justify-content: flex-end !important;
  padding-right: 0 !important;
}

.book-nav {
  display: none !important;
}

/* Media starts monochrome; clicking a video brings it into colour with sound */
.video-frame video,
.hero-image img {
  filter: grayscale(1) contrast(1.08);
  transition: filter 220ms ease;
}

.video-frame.is-active video {
  filter: none;
}

.video-frame {
  cursor: pointer;
}

/* Hero image: no internal border */
.hero-image img {
  border: 0 !important;
}

/* Hero image fills its box edge-to-edge */
.hero-image {
  padding: 0 !important;
  margin: 0 !important;
}

.hero-image img {
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: auto !important;
  object-fit: cover !important;
  border: 0 !important;
}

/* Local audio player for Listen section */
.local-audio {
  display: block;
  width: 100%;
  margin-top: 10px;
  border: 1px solid var(--line);
  background: var(--surface-strong);
}

/* Hero image turns colour only while pressed */
.hero-image img:active {
  filter: none !important;
}

.listen-link {
  display: inline-block;
  margin-top: 8px;
  color: var(--ink);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* Keep Club Mix Hybrid / Mixcloud player monochrome */
.mixcloud-embed {
  filter: grayscale(1) contrast(1.05);
}

/* Release artwork carousel */
.release-strip {
  margin-top: 18px;
  padding: 14px 0 16px;
  overflow: hidden;
  background: var(--surface);
}

.release-strip-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 0 14px 12px;
  border-bottom: 1px solid var(--line);
}

.release-strip-header h3 {
  margin: 0;
  font-size: clamp(1.2rem, 2vw, 2rem);
  line-height: 0.95;
  text-transform: uppercase;
  letter-spacing: -0.05em;
}

.release-marquee {
  width: 100%;
  overflow: hidden;
  padding-top: 14px;
}

.release-track {
  display: flex;
  width: max-content;
  gap: 12px;
  animation: release-scroll 30s linear infinite;
}

.release-strip:hover .release-track {
  animation-play-state: paused;
}

.release-tile {
  width: clamp(86px, 10vw, 132px);
  aspect-ratio: 1 / 1;
  display: grid;
  place-items: end start;
  padding: 9px;
  border: 1px solid var(--line);
  background:
    linear-gradient(135deg, rgba(0, 0, 0, 0.08), transparent 42%),
    repeating-linear-gradient(90deg, var(--surface-strong) 0 10px, var(--surface) 10px 20px);
  filter: grayscale(1) contrast(1.08);
}

.release-tile span {
  max-width: 100%;
  font-size: clamp(0.62rem, 0.82vw, 0.8rem);
  line-height: 0.9;
  font-weight: 800;
  letter-spacing: -0.04em;
  text-transform: uppercase;
}

@keyframes release-scroll {
  from { transform: translateX(0); }
  to { transform: translateX(calc(-50% - 6px)); }
}

@media (prefers-reduced-motion: reduce) {
  .release-track {
    animation: none;
  }
}

/* Releases section sits beneath the main body, with artwork bleeding together */
.release-strip {
  margin-top: 22px !important;
  padding: 0 !important;
}

.release-strip-header {
  padding: 12px 14px !important;
}

.release-marquee {
  padding-top: 0 !important;
}

.release-track {
  gap: 0 !important;
}

.release-tile {
  border: 0 !important;
  border-right: 1px solid var(--line) !important;
}

.release-tile:first-child {
  border-left: 0 !important;
}

.release-art {
  padding: 0 !important;
  overflow: hidden;
  background: var(--ink) !important;
}

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

.release-art:active img,
.release-art:hover img {
  filter: none;
}

/* Release artwork remains monochrome until clicked/pressed */
.release-art:hover img {
  filter: grayscale(1) contrast(1.08) !important;
}

.release-art:active img,
.release-art:focus-visible img {
  filter: none !important;
}

/* Release artwork turns colour on hover */
.release-art:hover img,
.release-art:active img,
.release-art:focus-visible img {
  filter: none !important;
}

/* Release hover colour fix: remove parent grayscale on real artwork tiles */
.release-tile.release-art {
  filter: none !important;
}

.release-tile.release-art img {
  filter: grayscale(1) contrast(1.08) !important;
}

.release-tile.release-art:hover img,
.release-tile.release-art:active img,
.release-tile.release-art:focus-visible img {
  filter: none !important;
}

/* Slightly more editorial bio formatting */
.media-bio p {
  max-width: 68ch;
  margin-bottom: 0.9rem;
}

.media-bio p:last-child {
  margin-bottom: 0;
}

/* Bio as one readable column */
.media-bio {
  display: block !important;
}

.media-bio h3 {
  margin-bottom: 0.8rem !important;
}

.media-bio p {
  max-width: 72ch !important;
}

.media-bio strong {
  font-weight: 850;
}

/* Hero image and videos turn colour on hover */
.hero-image:hover img,
.video-frame:hover video {
  filter: none !important;
}

/* Animated HOM mark inside hero text box */
.hero-text-lockup {
  display: grid;
  gap: 10px;
  align-content: start;
}

.hero-gif-mark {
  width: clamp(56px, 7vw, 96px);
  height: auto;
  display: block;
  filter: grayscale(1) contrast(1.08);
  mix-blend-mode: multiply;
}

.hero-text-lockup:hover .hero-gif-mark {
  filter: none;
}

/* Full-bleed GIF inside hero text box */
.hero-copy {
  position: relative !important;
  overflow: hidden !important;
}

.hero-text-lockup {
  position: absolute !important;
  inset: 0 !important;
  display: block !important;
  z-index: 0 !important;
}

.hero-gif-mark {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  filter: grayscale(1) contrast(1.08) !important;
  mix-blend-mode: normal !important;
}

.hero-text-lockup:hover .hero-gif-mark,
.hero-copy:hover .hero-gif-mark {
  filter: none !important;
}

.hero-text-lockup .hero-wordmark,
.hero-text-lockup .hero-subtitle,
.hero-text-lockup .hero-location {
  position: relative !important;
  z-index: 1 !important;
  margin-left: 24px !important;
  margin-right: 24px !important;
}

.hero-text-lockup .hero-wordmark {
  margin-top: 22px !important;
}

/* GIF temporarily removed from hero */
.hero-text-lockup,
.hero-gif-mark {
  display: none !important;
}

/* Never show blank video cards: real poster frames fill the boxes before playback */
.video-frame video {
  background-size: cover !important;
  background-position: center !important;
}

.video-frame video[poster*="clip-01"] { background-image: url("assets/posters/clip-01-poster.jpg"); }
.video-frame video[poster*="clip-02"] { background-image: url("assets/posters/clip-02-poster.jpg"); }
.video-frame video[poster*="clip-03"] { background-image: url("assets/posters/clip-03-poster.jpg"); }

/* Splash / entrance page */
.splash-body {
  min-height: 100vh;
  overflow: hidden;
  background: #000;
  color: #f3eee6;
}
.splash-body::before {
  display: none;
}
.splash-page {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
  position: relative;
  z-index: 1;
}
.splash-house {
  width: min(72vmin, 720px);
  aspect-ratio: 1;
  display: block;
  border: 0;
  background: #000;
  box-shadow: none;
  overflow: hidden;
  cursor: pointer;
  transition: transform 180ms ease;
}
.splash-house:hover,
.splash-house:focus-visible {
  transform: scale(0.985);
  outline: 0;
}
.splash-house video,
.splash-house img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
@media (max-width: 760px) {
  .splash-page { padding: 12px; }
  .splash-house { width: min(88vmin, 520px); }
}


/* Dark booking-page finish: black luxury, editorial restraint, HOUSE OF MOLLY identity */
body:not(.splash-body) .page-panel,
body:not(.splash-body) .editorial-grid,
body:not(.splash-body) .video-frame,
body:not(.splash-body) .spotify-embed,
body:not(.splash-body) .contact-link {
  border-color: var(--line);
}
body:not(.splash-body) img,
body:not(.splash-body) video {
  border-color: var(--line);
}

/* Subtle premium section reveal: keeps layout fixed, eases content in */
body:not(.splash-body) .site-header,
body:not(.splash-body) .hero-section,
body:not(.splash-body) .editorial-grid,
body:not(.splash-body) .release-strip {
  opacity: 0;
  transform: translateY(18px);
  transition:
    opacity 760ms cubic-bezier(0.16, 1, 0.3, 1),
    transform 760ms cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
}

/* Premium HOM pass — inspired by black luxury/product-editorial UI language, not a copied layout */
body:not(.splash-body) {
  background:
    radial-gradient(circle at 8% 0%, rgba(233, 227, 216, 0.08), transparent 28rem),
    radial-gradient(circle at 92% 18%, rgba(150, 139, 122, 0.045), transparent 30rem),
    linear-gradient(180deg, #000 0%, #040403 38%, #000 100%);
}

body:not(.splash-body) .page-shell {
  padding-top: 18px;
}

body:not(.splash-body) .page-panel,
body:not(.splash-body) .editorial-grid {
  background:
    linear-gradient(180deg, rgba(18, 18, 16, 0.94), rgba(7, 7, 6, 0.965)),
    var(--surface);
  box-shadow:
    0 1px 0 rgba(233, 227, 216, 0.06) inset,
    0 34px 110px rgba(0, 0, 0, 0.54);
}

body:not(.splash-body) .site-header {
  background: rgba(3, 3, 3, 0.82);
  border: 1px solid var(--line-soft);
}

body:not(.splash-body) .wordmark {
  background: #e9e3d8;
  color: #050504;
}

body:not(.splash-body) .hero-section {
  min-height: 286px;
}

body:not(.splash-body) .hero-copy {
  background:
    linear-gradient(135deg, rgba(233, 227, 216, 0.055), transparent 38%),
    linear-gradient(180deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.26));
}

body:not(.splash-body) .hero-wordmark {
  text-shadow: 0 20px 54px rgba(0, 0, 0, 0.65);
}

body:not(.splash-body) .booking-strip,
body:not(.splash-body) .accent-panel {
  background:
    linear-gradient(135deg, rgba(233, 227, 216, 0.082), rgba(233, 227, 216, 0.018) 52%),
    rgba(9, 9, 8, 0.94);
}

body:not(.splash-body) .section-rail {
  background: linear-gradient(180deg, rgba(233, 227, 216, 0.045), rgba(233, 227, 216, 0.012));
}

body:not(.splash-body) .section-number,
body:not(.splash-body) .rail-mark {
  color: rgba(233, 227, 216, 0.62);
}

body:not(.splash-body) .video-frame,
body:not(.splash-body) .release-art,
body:not(.splash-body) .hero-image img {
  transition:
    filter 260ms ease,
    transform 260ms cubic-bezier(0.16, 1, 0.3, 1),
    border-color 260ms ease;
}

body:not(.splash-body) .video-frame:hover,
body:not(.splash-body) .video-frame:focus-within,
body:not(.splash-body) .release-art:hover,
body:not(.splash-body) .release-art:focus-visible {
  border-color: rgba(233, 227, 216, 0.32) !important;
}

body:not(.splash-body) .video-frame:hover video,
body:not(.splash-body) .release-art:hover img,
body:not(.splash-body) .hero-image:hover img {
  transform: scale(1.012);
}

body:not(.splash-body) .booking-email,
body:not(.splash-body) .listen-link,
body:not(.splash-body) .top-nav a {
  transition: color 180ms ease, opacity 180ms ease;
}

body:not(.splash-body) .booking-email:hover,
body:not(.splash-body) .booking-email:focus-visible,
body:not(.splash-body) .listen-link:hover,
body:not(.splash-body) .listen-link:focus-visible,
body:not(.splash-body) .top-nav a:hover,
body:not(.splash-body) .top-nav a:focus-visible {
  color: #fff8ec;
}

body:not(.splash-body) .media-bio {
  border-top-color: rgba(233, 227, 216, 0.2);
}

body:not(.splash-body) .media-bio p {
  color: rgba(233, 227, 216, 0.84);
}

body:not(.splash-body) .support-tags span,
body:not(.splash-body) .clean-format-list li {
  color: rgba(233, 227, 216, 0.88);
}

body:not(.splash-body) :focus-visible {
  outline: 1px solid rgba(233, 227, 216, 0.72);
  outline-offset: 3px;
}

@media (max-width: 760px) {
  body:not(.splash-body) .top-nav {
    justify-content: flex-start !important;
    padding-right: 18px !important;
  }

  body:not(.splash-body) .hero-section {
    min-height: 0;
  }

  body:not(.splash-body) .hero-wordmark {
    white-space: normal !important;
    letter-spacing: -0.09em !important;
  }
}

body:not(.splash-body) .site-header.is-visible,
body:not(.splash-body) .hero-section.is-visible,
body:not(.splash-body) .editorial-grid.is-visible,
body:not(.splash-body) .release-strip.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  body:not(.splash-body) .site-header,
  body:not(.splash-body) .hero-section,
  body:not(.splash-body) .editorial-grid,
  body:not(.splash-body) .release-strip {
    opacity: 1;
    transform: none;
    transition: none;
    will-change: auto;
  }
}

/* Atomic-closest original pass — cinematic agency energy, HOM content, existing column rhythm */
body:not(.splash-body) {
  --surface: rgba(5, 5, 4, 0.96);
  --surface-raised: rgba(12, 12, 10, 0.88);
  --ink: #ece6dc;
  --muted: #a79f92;
  --line: rgba(236, 230, 220, 0.13);
  --line-soft: rgba(236, 230, 220, 0.07);
  background:
    radial-gradient(circle at 18% 8%, rgba(236, 230, 220, 0.055), transparent 34rem),
    radial-gradient(circle at 82% 4%, rgba(236, 230, 220, 0.035), transparent 28rem),
    linear-gradient(180deg, #000 0%, #010101 48%, #000 100%) !important;
}

body:not(.splash-body)::before {
  opacity: 0.13;
  background-size: 42px 42px;
}

body:not(.splash-body) .page-shell {
  width: min(1360px, calc(100% - 36px)) !important;
  padding-top: 16px !important;
}

.atomic-header.site-header {
  position: sticky !important;
  top: 14px !important;
  display: grid !important;
  grid-template-columns: minmax(220px, 0.34fr) minmax(260px, 0.42fr) minmax(220px, 0.36fr) auto !important;
  min-height: 58px;
  background: rgba(0, 0, 0, 0.72) !important;
  border: 1px solid var(--line-soft) !important;
  box-shadow: 0 20px 70px rgba(0,0,0,0.42) !important;
  backdrop-filter: blur(18px);
}

.atomic-header .wordmark {
  grid-column: 1 !important;
  min-height: 58px;
  background: transparent !important;
  color: var(--ink) !important;
  border-right: 1px solid var(--line-soft);
  padding: 0 18px !important;
  letter-spacing: 0.08em !important;
  font-size: 0.86rem !important;
}

.header-detail {
  grid-column: 2;
  padding: 0 18px;
  color: rgba(236, 230, 220, 0.58);
  text-transform: uppercase;
  letter-spacing: 0.13em;
  font-size: 0.68rem;
  font-weight: 800;
  line-height: 1.25;
}

.atomic-header .primary-nav,
.atomic-header .external-nav {
  display: flex !important;
  align-items: center;
  gap: 20px;
  padding: 0 18px !important;
  border-left: 1px solid var(--line-soft);
}

.atomic-header .primary-nav {
  grid-column: 3 !important;
  justify-content: flex-start !important;
}

.atomic-header .external-nav {
  grid-column: 4 !important;
  justify-content: flex-end !important;
}

.atomic-header .top-nav a {
  font-size: 0.68rem !important;
  color: rgba(236, 230, 220, 0.66) !important;
}

.atomic-hero.hero-section {
  min-height: 620px !important;
  grid-template-columns: var(--rail-width) minmax(0, 1.55fr) minmax(320px, 0.9fr) !important;
  background:
    linear-gradient(90deg, rgba(236,230,220,0.025), transparent 38%),
    linear-gradient(180deg, rgba(14,14,12,0.92), rgba(2,2,2,0.98)) !important;
  overflow: hidden;
}

.atomic-hero .hero-copy {
  min-height: 620px !important;
  padding: clamp(22px, 2.2vw, 34px) !important;
  justify-content: space-between !important;
  background:
    linear-gradient(135deg, rgba(236,230,220,0.055), transparent 34%),
    radial-gradient(circle at 18% 88%, rgba(236,230,220,0.07), transparent 22rem) !important;
}

.hero-meta-row {
  display: grid;
  grid-template-columns: 0.72fr 1.1fr 0.55fr;
  gap: 14px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line-soft);
  color: rgba(236, 230, 220, 0.56);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: clamp(0.62rem, 0.16vw + 0.6rem, 0.74rem);
  font-weight: 850;
}

.hero-statement {
  max-width: 860px;
  align-self: end;
}

.atomic-hero .hero-wordmark {
  max-width: 9ch !important;
  white-space: normal !important;
  font-size: clamp(5.25rem, 9.4vw, 10.9rem) !important;
  line-height: 0.73 !important;
  letter-spacing: -0.125em !important;
  margin: 12px 0 18px !important;
  text-wrap: balance;
}

.atomic-hero .hero-subtitle {
  max-width: 720px;
  color: rgba(236,230,220,0.78);
  font-size: clamp(1.06rem, 0.92vw + 0.9rem, 1.65rem) !important;
  line-height: 1.05 !important;
  letter-spacing: -0.055em !important;
  text-transform: uppercase;
}

.atomic-hero .hero-location {
  color: rgba(236, 230, 220, 0.66);
}

.hero-cta-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line-soft);
}

.cinema-link {
  min-height: 78px;
  display: grid;
  align-content: center;
  gap: 5px;
  padding: 14px 16px;
  text-decoration: none;
  border-right: 1px solid var(--line-soft);
  background: rgba(236,230,220,0.018);
  transition: background 220ms ease, color 220ms ease;
}

.cinema-link:last-child { border-right: 0; }
.cinema-link span {
  color: rgba(236,230,220,0.54);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.65rem;
  font-weight: 850;
}
.cinema-link strong {
  color: var(--ink);
  text-transform: uppercase;
  letter-spacing: -0.035em;
  line-height: 0.95;
  font-size: clamp(1rem, 0.52vw + 0.9rem, 1.32rem);
}
.cinema-link:hover,
.cinema-link:focus-visible,
.cinema-link.primary {
  background: rgba(236,230,220,0.075);
}

.atomic-aside.hero-aside {
  min-height: 620px !important;
  grid-template-rows: auto auto minmax(0, 1fr) !important;
  background: rgba(0,0,0,0.28) !important;
}

.atomic-aside .booking-strip {
  min-height: 116px;
  padding: 22px !important;
  background: rgba(236,230,220,0.048) !important;
}

.atomic-aside .booking-email {
  font-size: clamp(1.02rem, 0.52vw + 0.9rem, 1.28rem) !important;
  letter-spacing: -0.05em !important;
}

.hero-proof-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  border-bottom: 1px solid var(--line);
}

.proof-stat {
  min-height: 86px;
  display: grid;
  align-content: space-between;
  gap: 12px;
  padding: 14px;
  border-right: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  background: rgba(236,230,220,0.018);
}
.proof-stat:nth-child(2n) { border-right: 0; }
.proof-stat:nth-last-child(-n + 2) { border-bottom: 0; }
.proof-stat span {
  color: rgba(236,230,220,0.48);
  text-transform: uppercase;
  letter-spacing: 0.13em;
  font-size: 0.62rem;
  font-weight: 850;
}
.proof-stat strong {
  color: rgba(236,230,220,0.9);
  text-transform: uppercase;
  letter-spacing: -0.04em;
  line-height: 0.95;
  font-size: clamp(0.95rem, 0.5vw + 0.82rem, 1.22rem);
}

.layered-media.hero-image {
  position: relative;
  min-height: 0;
  padding: 16px !important;
  align-items: stretch !important;
  background:
    linear-gradient(145deg, transparent 0 52%, rgba(236,230,220,0.04) 52% 52.5%, transparent 52.5%),
    rgba(236,230,220,0.014);
}
.layered-media.hero-image::before,
.layered-media.hero-image::after {
  content: "";
  position: absolute;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}
.layered-media.hero-image::before { inset: 28px 8px 42px 34px; }
.layered-media.hero-image::after { inset: 44px 34px 18px 10px; }
.layered-media.hero-image img {
  position: relative;
  z-index: 1;
  border: 1px solid rgba(236,230,220,0.12) !important;
  box-shadow: 0 30px 90px rgba(0,0,0,0.62);
}

body:not(.splash-body) .editorial-grid {
  margin-top: 14px !important;
  background: rgba(3,3,3,0.95) !important;
}

body:not(.splash-body) .media-feature,
body:not(.splash-body) .info-module,
body:not(.splash-body) .release-strip {
  background:
    linear-gradient(180deg, rgba(236,230,220,0.024), rgba(0,0,0,0.12)),
    rgba(5,5,4,0.95) !important;
}

body:not(.splash-body) .video-frame {
  border-color: rgba(236,230,220,0.105) !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.38);
}


body:not(.splash-body) .support-row,
body:not(.splash-body) .clean-format-list li,
body:not(.splash-body) .media-bio {
  border-color: var(--line-soft) !important;
}

body:not(.splash-body) .release-strip {
  margin-top: 14px !important;
}

body:not(.splash-body) .release-track {
  animation-duration: 38s !important;
}

body:not(.splash-body) .release-tile {
  width: clamp(104px, 11.4vw, 156px) !important;
}

body:not(.splash-body) .site-header,
body:not(.splash-body) .hero-section,
body:not(.splash-body) .editorial-grid,
body:not(.splash-body) .release-strip,
body:not(.splash-body) .video-card,
body:not(.splash-body) .info-module {
  opacity: 0;
  transform: translateY(18px);
  transition:
    opacity 820ms cubic-bezier(0.16, 1, 0.3, 1),
    transform 820ms cubic-bezier(0.16, 1, 0.3, 1);
}

body:not(.splash-body) .site-header.is-visible,
body:not(.splash-body) .hero-section.is-visible,
body:not(.splash-body) .editorial-grid.is-visible,
body:not(.splash-body) .release-strip.is-visible,
body:not(.splash-body) .video-card.is-visible,
body:not(.splash-body) .info-module.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 1120px) {
  .atomic-header.site-header {
    grid-template-columns: 1fr 1fr !important;
  }
  .atomic-header .wordmark { grid-column: 1 !important; }
  .header-detail { grid-column: 2; }
  .atomic-header .primary-nav { grid-column: 1 !important; border-top: 1px solid var(--line-soft); border-left: 0; }
  .atomic-header .external-nav { grid-column: 2 !important; border-top: 1px solid var(--line-soft); }
  .atomic-hero.hero-section {
    grid-template-columns: var(--rail-width) minmax(0, 1fr) !important;
  }
  .atomic-aside.hero-aside {
    grid-column: 2 !important;
    border-left: 0;
    border-top: 1px solid var(--line);
    min-height: 0 !important;
  }
  .atomic-hero .hero-wordmark {
    font-size: clamp(4.6rem, 12vw, 8.5rem) !important;
  }
}

@media (max-width: 900px) {
  .atomic-hero.hero-section {
    grid-template-columns: 1fr !important;
    min-height: 0 !important;
  }
  .atomic-hero .hero-copy,
  .atomic-aside.hero-aside {
    grid-column: auto !important;
    min-height: 0 !important;
  }
  .hero-meta-row,
  .hero-cta-row,
  .hero-proof-grid {
    grid-template-columns: 1fr !important;
  }
  .cinema-link,
  .proof-stat { border-right: 0 !important; }
  body:not(.splash-body) .video-card:nth-child(2),
  body:not(.splash-body) .video-card:nth-child(3) {
    transform: none;
  }
}

@media (max-width: 760px) {
  body:not(.splash-body) .page-shell {
    width: min(100% - 16px, 1480px) !important;
    padding-top: 8px !important;
  }
  .atomic-header.site-header {
    position: static !important;
    grid-template-columns: 1fr !important;
  }
  .atomic-header .wordmark,
  .header-detail,
  .atomic-header .primary-nav,
  .atomic-header .external-nav {
    grid-column: 1 !important;
    border-left: 0 !important;
    border-right: 0 !important;
  }
  .header-detail { padding: 14px 18px; border-top: 1px solid var(--line-soft); }
  .atomic-header .primary-nav,
  .atomic-header .external-nav { justify-content: flex-start !important; flex-wrap: wrap; min-height: 48px; }
  .atomic-hero .hero-copy { padding: 18px !important; gap: 38px; }
  .atomic-hero .hero-wordmark {
    font-size: clamp(4.05rem, 21.5vw, 7rem) !important;
    line-height: 0.76 !important;
    letter-spacing: -0.12em !important;
  }
  .atomic-hero .hero-subtitle { font-size: clamp(1rem, 4vw, 1.25rem) !important; }
  .layered-media.hero-image { min-height: 360px; }
}

@media (prefers-reduced-motion: reduce) {
  body:not(.splash-body) .site-header,
  body:not(.splash-body) .hero-section,
  body:not(.splash-body) .editorial-grid,
  body:not(.splash-body) .release-strip,
  body:not(.splash-body) .video-card,
  body:not(.splash-body) .info-module {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
  body:not(.splash-body) .release-track { animation: none !important; }
}

/* Keep the three vertical videos precisely aligned */
body:not(.splash-body) .video-grid {
  align-items: start !important;
}
body:not(.splash-body) .video-card,
body:not(.splash-body) .video-card:nth-child(2),
body:not(.splash-body) .video-card:nth-child(3) {
  margin-top: 0 !important;
}
body:not(.splash-body) .video-frame {
  height: auto !important;
  aspect-ratio: 9 / 16;
}

/* Pure black foundation override */
:root {
  --bg: #000;
  --surface: #000;
  --surface-raised: #000;
  --surface-strong: #000;
}
html,
body,
body:not(.splash-body),
body:not(.splash-body) .page-shell,
body:not(.splash-body) .page-panel,
body:not(.splash-body) .site-header,
body:not(.splash-body) .hero-section,
body:not(.splash-body) .hero-aside,
body:not(.splash-body) .editorial-grid,
body:not(.splash-body) .media-feature,
body:not(.splash-body) .info-module,
body:not(.splash-body) .release-strip,
body:not(.splash-body) .contact-panel,
body:not(.splash-body) .booking-strip,
body:not(.splash-body) .section-rail,
body:not(.splash-body) .hero-copy,
body:not(.splash-body) .feature-content,
body:not(.splash-body) .module-content,
body:not(.splash-body) .contact-content,
body:not(.splash-body) .listen-content {
  background: #000 !important;
  background-image: none !important;
}
body:not(.splash-body)::before {
  display: none !important;
}

/* Hero realignment: return to the original booking-page rhythm */
body:not(.splash-body) .atomic-hero.hero-section {
  min-height: 0 !important;
  grid-template-columns: var(--rail-width) minmax(0, 1fr) !important;
  overflow: hidden;
}
body:not(.splash-body) .atomic-hero .hero-content {
  grid-column: 2;
  display: grid !important;
  grid-template-columns: minmax(0, 1.55fr) minmax(320px, 0.9fr) !important;
  min-height: 270px !important;
}
body:not(.splash-body) .atomic-hero .hero-copy {
  grid-column: 1 !important;
  min-height: 270px !important;
  padding: 22px 24px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  gap: 20px !important;
  background: #000 !important;
}
body:not(.splash-body) .hero-statement {
  max-width: none !important;
  align-self: auto !important;
}
body:not(.splash-body) .atomic-hero .hero-wordmark {
  max-width: none !important;
  white-space: normal !important;
  font-size: clamp(3rem, 4.65vw, 5.1rem) !important;
  line-height: 0.88 !important;
  letter-spacing: -0.095em !important;
  margin: 0 0 10px !important;
  text-wrap: auto !important;
}
body:not(.splash-body) .atomic-hero .hero-subtitle {
  max-width: 620px !important;
  margin-bottom: 14px !important;
  font-size: clamp(1rem, 0.85vw + 0.86rem, 1.35rem) !important;
  line-height: 1 !important;
  letter-spacing: -0.04em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  color: var(--ink) !important;
}
body:not(.splash-body) .atomic-hero .hero-location {
  color: var(--muted) !important;
}
body:not(.splash-body) .atomic-aside.hero-aside {
  grid-column: 2 !important;
  min-height: 270px !important;
  border-left: 1px solid var(--line) !important;
  display: grid !important;
  grid-template-rows: auto minmax(0, 1fr) !important;
  background: #000 !important;
}
body:not(.splash-body) .atomic-aside .booking-strip {
  min-height: 0 !important;
  padding: 20px !important;
  display: grid !important;
  gap: 8px !important;
  align-content: start !important;
  border-bottom: 1px solid var(--line) !important;
  background: #000 !important;
}
body:not(.splash-body) .atomic-aside .booking-email {
  font-size: clamp(0.98rem, 0.48vw + 0.88rem, 1.18rem) !important;
  line-height: 1.05 !important;
  letter-spacing: -0.04em !important;
}
body:not(.splash-body) .layered-media.hero-image {
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  align-items: stretch !important;
  background: #000 !important;
}
body:not(.splash-body) .layered-media.hero-image::before,
body:not(.splash-body) .layered-media.hero-image::after {
  display: none !important;
}
body:not(.splash-body) .layered-media.hero-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  border: 0 !important;
  box-shadow: none !important;
}
@media (max-width: 1120px) {
  body:not(.splash-body) .atomic-hero .hero-content {
    grid-template-columns: 1fr !important;
  }
  body:not(.splash-body) .atomic-aside.hero-aside {
    grid-column: 1 !important;
    border-left: 0 !important;
    border-top: 1px solid var(--line) !important;
  }
}
@media (max-width: 900px) {
  body:not(.splash-body) .atomic-hero.hero-section {
    grid-template-columns: 1fr !important;
  }
  body:not(.splash-body) .atomic-hero .hero-content {
    grid-column: 1 !important;
  }
}

/* Restore acid booking strip */
body:not(.splash-body) .atomic-aside .booking-strip {
  background: #d8ff3c !important;
  color: #000 !important;
}
body:not(.splash-body) .atomic-aside .booking-strip a,
body:not(.splash-body) .atomic-aside .booking-strip .card-kicker {
  color: #000 !important;
}

/* HOM hero wordmark colour */
body:not(.splash-body) .atomic-hero .hero-wordmark {
  color: #E3008A !important;
}

/* Disable scroll reveal/easing — keep scrolling immediate */
body:not(.splash-body) .site-header,
body:not(.splash-body) .hero-section,
body:not(.splash-body) .editorial-grid,
body:not(.splash-body) .release-strip,
body:not(.splash-body) .video-card,
body:not(.splash-body) .info-module {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}

/* Revert HOM hero wordmark from pink */
body:not(.splash-body) .atomic-hero .hero-wordmark {
  color: var(--ink) !important;
}

/* Atomic-inspired releases treatment — original HOM version */
body:not(.splash-body) .release-strip {
  margin-top: 18px !important;
  padding: 0 !important;
  overflow: hidden !important;
  background: #000 !important;
  border-color: var(--line-soft) !important;
}
body:not(.splash-body) .release-strip-header {
  min-height: 86px;
  padding: 16px 18px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 18px !important;
  border-bottom: 1px solid var(--line-soft) !important;
}
body:not(.splash-body) .release-heading-lockup {
  display: flex;
  align-items: baseline;
  gap: 18px;
}
body:not(.splash-body) .release-strip-header h3 {
  font-size: clamp(2.8rem, 7vw, 7.4rem) !important;
  line-height: 0.78 !important;
  letter-spacing: -0.105em !important;
  text-transform: uppercase;
}
body:not(.splash-body) .release-controls {
  display: flex;
  align-items: center;
  gap: 10px;
}
body:not(.splash-body) .release-controls button {
  width: clamp(54px, 5.4vw, 76px);
  height: clamp(54px, 5.4vw, 76px);
  border-radius: 999px;
  border: 1px solid rgba(233,227,216,0.22);
  background: rgba(233,227,216,0.045);
  color: var(--ink);
  font-size: 0;
  cursor: default;
  position: relative;
}
body:not(.splash-body) .release-controls button::before {
  content: "";
  position: absolute;
  inset: 50% auto auto 50%;
  width: 16px;
  height: 16px;
  border-top: 1px solid currentColor;
  border-right: 1px solid currentColor;
  transform: translate(-60%, -50%) rotate(45deg);
}
body:not(.splash-body) .release-controls button:first-child::before {
  transform: translate(-40%, -50%) rotate(-135deg);
}
body:not(.splash-body) .release-marquee {
  overflow-x: auto !important;
  overflow-y: hidden !important;
  padding: 18px !important;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}
body:not(.splash-body) .release-marquee::-webkit-scrollbar { display: none; }
body:not(.splash-body) .release-track {
  display: flex !important;
  gap: 18px !important;
  width: max-content !important;
  animation: none !important;
  transform: none !important;
}
body:not(.splash-body) .release-tile.release-art {
  width: clamp(260px, 27vw, 410px) !important;
  aspect-ratio: 0.78 !important;
  flex: 0 0 auto !important;
  position: relative;
  display: block !important;
  padding: 0 !important;
  overflow: hidden;
  scroll-snap-align: start;
  border: 1px solid rgba(233,227,216,0.16) !important;
  border-radius: 0 !important;
  background: #050505 !important;
}
body:not(.splash-body) .release-tile.release-art img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  filter: grayscale(1) contrast(1.08) brightness(0.72) !important;
  transform: scale(1.015);
  transition: filter 360ms ease, transform 520ms cubic-bezier(0.16, 1, 0.3, 1);
}
body:not(.splash-body) .release-tile.release-art::before {
  content: attr(data-title);
  position: absolute;
  left: 16px;
  right: 72px;
  bottom: 16px;
  z-index: 2;
  color: var(--ink);
  font-size: clamp(1.25rem, 2vw, 2.05rem);
  line-height: 0.9;
  letter-spacing: -0.07em;
  font-weight: 900;
  text-transform: uppercase;
}
body:not(.splash-body) .release-tile.release-art::after {
  content: "";
  position: absolute;
  right: 16px;
  bottom: 16px;
  z-index: 2;
  width: 48px;
  height: 48px;
  border-radius: 999px;
  border: 1px solid rgba(233,227,216,0.32);
  background: rgba(0,0,0,0.42);
  background-image:
    linear-gradient(45deg, transparent 47%, var(--ink) 48% 52%, transparent 53%),
    linear-gradient(135deg, transparent 47%, var(--ink) 48% 52%, transparent 53%);
  background-size: 15px 15px, 15px 15px;
  background-position: 17px 16px, 17px 26px;
  background-repeat: no-repeat;
}
body:not(.splash-body) .release-tile.release-art:hover img,
body:not(.splash-body) .release-tile.release-art:focus-visible img {
  filter: grayscale(0) contrast(1.02) brightness(0.92) !important;
  transform: scale(1.045);
}
@media (max-width: 760px) {
  body:not(.splash-body) .release-strip-header {
    align-items: flex-start !important;
    flex-direction: column;
  }
  body:not(.splash-body) .release-strip-header h3 {
    font-size: clamp(3.2rem, 17vw, 5.4rem) !important;
  }
  body:not(.splash-body) .release-controls button {
    width: 50px;
    height: 50px;
  }
  body:not(.splash-body) .release-marquee { padding: 12px !important; }
  body:not(.splash-body) .release-track { gap: 12px !important; }
  body:not(.splash-body) .release-tile.release-art {
    width: min(78vw, 340px) !important;
  }
}

/* Acid title hover */
body:not(.splash-body) h1,
body:not(.splash-body) h2,
body:not(.splash-body) h3,
body:not(.splash-body) .hero-wordmark,
body:not(.splash-body) .wordmark,
body:not(.splash-body) .release-tile.release-art::before {
  transition: color 180ms ease;
}
body:not(.splash-body) h1:hover,
body:not(.splash-body) h2:hover,
body:not(.splash-body) h3:hover,
body:not(.splash-body) .hero-wordmark:hover,
body:not(.splash-body) .wordmark:hover,
body:not(.splash-body) .release-tile.release-art:hover::before,
body:not(.splash-body) .release-tile.release-art:focus-visible::before {
  color: #d8ff3c !important;
}

/* Keep hero image stable on hover */
body:not(.splash-body) .hero-image img,
body:not(.splash-body) .hero-image:hover img,
body:not(.splash-body) .layered-media.hero-image img,
body:not(.splash-body) .layered-media.hero-image:hover img {
  transform: none !important;
}
body:not(.splash-body) .hero-image img {
  transition: filter 220ms ease !important;
}

/* Smaller sharper release carousel + controls under left image */
body:not(.splash-body) .release-strip-header {
  min-height: 64px !important;
}
body:not(.splash-body) .release-strip-header h3 {
  font-size: clamp(2.1rem, 4.6vw, 4.8rem) !important;
}
body:not(.splash-body) .release-marquee {
  padding: 16px 16px 0 !important;
  scroll-behavior: smooth;
}
body:not(.splash-body) .release-track {
  gap: 14px !important;
}
body:not(.splash-body) .release-tile.release-art {
  width: clamp(150px, 15vw, 230px) !important;
  aspect-ratio: 1 / 1 !important;
}
body:not(.splash-body) .release-tile.release-art img {
  transform: none !important;
}
body:not(.splash-body) .release-tile.release-art:hover img,
body:not(.splash-body) .release-tile.release-art:focus-visible img {
  transform: none !important;
}
body:not(.splash-body) .release-tile.release-art::before {
  left: 10px;
  right: 44px;
  bottom: 10px;
  font-size: clamp(0.78rem, 1vw, 1.08rem);
  line-height: 0.95;
  letter-spacing: -0.045em;
}
body:not(.splash-body) .release-tile.release-art::after {
  right: 10px;
  bottom: 10px;
  width: 30px;
  height: 30px;
  background-size: 10px 10px, 10px 10px;
  background-position: 11px 10px, 11px 17px;
}
body:not(.splash-body) .release-controls {
  display: flex !important;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  padding: 12px 16px 16px !important;
  border-top: 0 !important;
}
body:not(.splash-body) .release-controls button {
  width: 48px !important;
  height: 48px !important;
  border-radius: 999px;
  border: 1px solid rgba(233,227,216,0.24);
  background: rgba(233,227,216,0.045);
  color: var(--ink);
  font-size: 0;
  cursor: pointer !important;
  position: relative;
  transition: background 180ms ease, border-color 180ms ease;
}
body:not(.splash-body) .release-controls button:hover,
body:not(.splash-body) .release-controls button:focus-visible {
  background: #d8ff3c;
  border-color: #d8ff3c;
  color: #000;
}
body:not(.splash-body) .release-controls button::before {
  content: "";
  position: absolute;
  inset: 50% auto auto 50%;
  width: 13px;
  height: 13px;
  border-top: 1px solid currentColor;
  border-right: 1px solid currentColor;
  transform: translate(-60%, -50%) rotate(45deg);
}
body:not(.splash-body) .release-controls .release-prev::before {
  transform: translate(-40%, -50%) rotate(-135deg);
}
@media (max-width: 760px) {
  body:not(.splash-body) .release-tile.release-art {
    width: min(48vw, 190px) !important;
  }
  body:not(.splash-body) .release-controls button {
    width: 44px !important;
    height: 44px !important;
  }
}

/* Active release: leftmost visible artwork is in colour */
body:not(.splash-body) .release-tile.release-art.is-leftmost img {
  filter: grayscale(0) contrast(1.02) brightness(0.92) !important;
}
body:not(.splash-body) .release-tile.release-art.is-leftmost {
  border-color: rgba(216,255,60,0.72) !important;
}

/* Pink subtitle/kicker highlights */
body:not(.splash-body) .support-row .card-kicker,
body:not(.splash-body) .module-header .card-kicker,
body:not(.splash-body) .card-kicker {
  color: #E3008A !important;
}

/* Pink kicker labels only on hover */
body:not(.splash-body) .card-kicker {
  color: var(--muted) !important;
  transition: color 180ms ease;
}
body:not(.splash-body) .support-row:hover .card-kicker,
body:not(.splash-body) .module-content:hover .card-kicker,
body:not(.splash-body) .booking-strip:hover .card-kicker,
body:not(.splash-body) .card-kicker:hover {
  color: #E3008A !important;
}

/* Match Releases heading size to Format heading */
body:not(.splash-body) .release-strip-header h3 {
  font-size: clamp(1.08rem, 0.9vw + 0.9rem, 1.65rem) !important;
  line-height: 0.95 !important;
  letter-spacing: -0.05em !important;
  max-width: 16ch !important;
}
body:not(.splash-body) .release-strip-header {
  min-height: auto !important;
}

/* Remove persistent pink from support/proof block; hover only */
body:not(.splash-body) .support-row .card-kicker,
body:not(.splash-body) .support-row .support-tags,
body:not(.splash-body) .support-row .support-tags span {
  color: var(--muted) !important;
}
body:not(.splash-body) .support-row:hover .card-kicker {
  color: #E3008A !important;
}
body:not(.splash-body) .support-row:hover .support-tags,
body:not(.splash-body) .support-row:hover .support-tags span {
  color: var(--ink) !important;
}

/* Hero subtitle hover pink */
body:not(.splash-body) .hero-subtitle {
  transition: color 180ms ease;
}
body:not(.splash-body) .hero-subtitle:hover {
  color: #E3008A !important;
}

/* Support/proof labels: only the directly hovered title turns pink */
body:not(.splash-body) .support-row:hover .card-kicker {
  color: var(--muted) !important;
}
body:not(.splash-body) .support-row .card-kicker:hover {
  color: #E3008A !important;
}

/* Booking label stays black on acid strip */
body:not(.splash-body) .booking-strip:hover .card-kicker,
body:not(.splash-body) .booking-strip .card-kicker,
body:not(.splash-body) .booking-strip .card-kicker:hover {
  color: #000 !important;
}

/* Top-left wordmark acid */
body:not(.splash-body) .site-header .wordmark {
  color: #d8ff3c !important;
}

/* No hover highlights in support/proof rows */
body:not(.splash-body) .support-row,
body:not(.splash-body) .support-row:hover,
body:not(.splash-body) .support-row:focus-within,
body:not(.splash-body) .support-row .card-kicker,
body:not(.splash-body) .support-row .card-kicker:hover,
body:not(.splash-body) .support-row:hover .card-kicker,
body:not(.splash-body) .support-row .support-tags,
body:not(.splash-body) .support-row .support-tags:hover,
body:not(.splash-body) .support-row:hover .support-tags,
body:not(.splash-body) .support-row .support-tags span,
body:not(.splash-body) .support-row .support-tags span:hover,
body:not(.splash-body) .support-row:hover .support-tags span {
  color: var(--muted) !important;
  background: transparent !important;
  text-decoration: none !important;
}

/* Remove vertical dividers from menu bar */
body:not(.splash-body) .site-header,
body:not(.splash-body) .site-header > *,
body:not(.splash-body) .site-header .wordmark,
body:not(.splash-body) .site-header .top-nav,
body:not(.splash-body) .site-header .external-nav,
body:not(.splash-body) .site-header .primary-nav,
body:not(.splash-body) .site-header .book-nav {
  border-left: 0 !important;
  border-right: 0 !important;
}

/* HARD LOCK: support/proof block has no hover states */
body:not(.splash-body) #support,
body:not(.splash-body) #support *,
body:not(.splash-body) #support:hover,
body:not(.splash-body) #support *:hover,
body:not(.splash-body) #support:focus-within,
body:not(.splash-body) #support *:focus,
body:not(.splash-body) #support *:focus-visible {
  background: transparent !important;
  text-decoration: none !important;
  box-shadow: none !important;
}
body:not(.splash-body) #support .card-kicker,
body:not(.splash-body) #support .card-kicker:hover,
body:not(.splash-body) #support:hover .card-kicker,
body:not(.splash-body) #support .module-content:hover .card-kicker,
body:not(.splash-body) #support .support-row:hover .card-kicker {
  color: var(--muted) !important;
}
body:not(.splash-body) #support .support-tags,
body:not(.splash-body) #support .support-tags:hover,
body:not(.splash-body) #support .support-tags span,
body:not(.splash-body) #support .support-tags span:hover,
body:not(.splash-body) #support .support-row:hover .support-tags,
body:not(.splash-body) #support .support-row:hover .support-tags span {
  color: rgba(233, 227, 216, 0.78) !important;
}

/* Lower hero text block inside the hero panel */
body:not(.splash-body) .atomic-hero .hero-copy {
  justify-content: flex-end !important;
  padding-bottom: clamp(34px, 4.8vw, 76px) !important;
}

/* Support row labels match Selected Support heading colour */
body:not(.splash-body) #support .card-kicker,
body:not(.splash-body) #support .card-kicker:hover,
body:not(.splash-body) #support:hover .card-kicker,
body:not(.splash-body) #support .support-row:hover .card-kicker {
  color: var(--ink) !important;
}

/* Mixcloud link acid hover */
body:not(.splash-body) .listen-link:hover,
body:not(.splash-body) .listen-link:focus-visible {
  color: #d8ff3c !important;
}

/* Support row labels permanently match Selected Support */
body:not(.splash-body) #support .card-kicker,
body:not(.splash-body) #support .card-kicker:hover,
body:not(.splash-body) #support .support-row:hover .card-kicker,
body:not(.splash-body) #support .module-content:hover .card-kicker {
  color: var(--ink) !important;
}

/* Header external links acid hover */
body:not(.splash-body) .site-header .external-nav a:hover,
body:not(.splash-body) .site-header .external-nav a:focus-visible {
  color: #d8ff3c !important;
}

/* Video sound button acid hover */
body:not(.splash-body) .video-toggle:hover,
body:not(.splash-body) .video-toggle:focus-visible {
  background: #d8ff3c !important;
  border-color: #d8ff3c !important;
  color: #000 !important;
}

/* Remove release-card corner arrows */
body:not(.splash-body) .release-tile.release-art::after {
  display: none !important;
}
body:not(.splash-body) .release-tile.release-art::before {
  right: 10px !important;
}

/* Hero wordmark stays highlighted after first hover */
body:not(.splash-body) .hero-wordmark.has-hovered {
  color: #d8ff3c !important;
}

/* Header external links default match Selected Support */
body:not(.splash-body) .site-header .external-nav a {
  color: var(--ink) !important;
}
body:not(.splash-body) .site-header .external-nav a:hover,
body:not(.splash-body) .site-header .external-nav a:focus-visible {
  color: #d8ff3c !important;
}

/* Hero wordmark highlights then slowly fades */
body:not(.splash-body) .hero-wordmark {
  transition: color 1400ms ease !important;
}
body:not(.splash-body) .hero-wordmark.has-hovered {
  color: var(--ink) !important;
}
body:not(.splash-body) .hero-wordmark.is-highlighted {
  color: #d8ff3c !important;
  transition-duration: 120ms !important;
}

/* Slightly slower hero highlight fade */
body:not(.splash-body) .hero-wordmark {
  transition: color 2200ms ease !important;
}

/* Shared highlight behaviour: quick acid in, slow fade out */
body:not(.splash-body) h1,
body:not(.splash-body) h2,
body:not(.splash-body) h3,
body:not(.splash-body) .hero-subtitle,
body:not(.splash-body) .site-header .external-nav a,
body:not(.splash-body) .listen-link,
body:not(.splash-body) .video-toggle,
body:not(.splash-body) .release-controls button,
body:not(.splash-body) .release-tile.release-art::before {
  transition:
    color 2200ms ease,
    background-color 2200ms ease,
    border-color 2200ms ease !important;
}
body:not(.splash-body) h1:hover,
body:not(.splash-body) h2:hover,
body:not(.splash-body) h3:hover,
body:not(.splash-body) .hero-subtitle:hover,
body:not(.splash-body) .site-header .external-nav a:hover,
body:not(.splash-body) .site-header .external-nav a:focus-visible,
body:not(.splash-body) .listen-link:hover,
body:not(.splash-body) .listen-link:focus-visible,
body:not(.splash-body) .video-toggle:hover,
body:not(.splash-body) .video-toggle:focus-visible,
body:not(.splash-body) .release-controls button:hover,
body:not(.splash-body) .release-controls button:focus-visible,
body:not(.splash-body) .release-tile.release-art:hover::before,
body:not(.splash-body) .release-tile.release-art:focus-visible::before {
  transition-duration: 120ms !important;
}

/* Mobile/structure refinement: proof first, videos right, tighter phone hero */
body:not(.splash-body) .editorial-grid {
  grid-template-columns:
    calc((100% - var(--rail-width)) * 0.3673469388)
    calc(var(--rail-width) + (100% - var(--rail-width)) * 0.6326530612) !important;
}
body:not(.splash-body) .editorial-grid .side-stack {
  order: 1;
}
body:not(.splash-body) .editorial-grid .media-feature {
  order: 2;
  border-right: 0 !important;
  border-left: 1px solid var(--line) !important;
}
body:not(.splash-body) .editorial-grid .media-feature .feature-content {
  min-height: 100%;
}

@media (max-width: 1120px) {
  body:not(.splash-body) .editorial-grid {
    grid-template-columns: 1fr !important;
  }
  body:not(.splash-body) .editorial-grid .side-stack {
    order: 1;
  }
  body:not(.splash-body) .editorial-grid .media-feature {
    order: 2;
    border-left: 0 !important;
    border-top: 1px solid var(--line) !important;
    border-bottom: 0 !important;
  }
}

@media (max-width: 760px) {
  body:not(.splash-body) .atomic-hero .hero-content {
    min-height: 0 !important;
  }
  body:not(.splash-body) .atomic-hero .hero-copy {
    min-height: 185px !important;
    padding: 18px 16px 24px !important;
  }
  body:not(.splash-body) .atomic-hero .hero-wordmark {
    font-size: clamp(2.65rem, 13.5vw, 4.05rem) !important;
    line-height: 0.86 !important;
    margin-bottom: 8px !important;
  }
  body:not(.splash-body) .atomic-hero .hero-subtitle {
    margin-bottom: 8px !important;
    font-size: clamp(0.9rem, 3.7vw, 1.08rem) !important;
  }
  body:not(.splash-body) .atomic-aside.hero-aside {
    min-height: 0 !important;
  }
  body:not(.splash-body) .atomic-aside .booking-strip {
    padding: 14px 16px !important;
  }
  body:not(.splash-body) .layered-media.hero-image {
    max-height: 315px !important;
    min-height: 0 !important;
  }
  body:not(.splash-body) .layered-media.hero-image img {
    max-height: 315px !important;
  }
}

/* Revert main body order: videos left, support/format stack right */
body:not(.splash-body) .editorial-grid {
  grid-template-columns:
    calc(var(--rail-width) + (100% - var(--rail-width)) * 0.6326530612)
    calc((100% - var(--rail-width)) * 0.3673469388) !important;
}
body:not(.splash-body) .editorial-grid .media-feature {
  order: 1 !important;
  border-left: 0 !important;
  border-right: 1px solid var(--line) !important;
  border-top: 0 !important;
}
body:not(.splash-body) .editorial-grid .side-stack {
  order: 2 !important;
}
@media (max-width: 1120px) {
  body:not(.splash-body) .editorial-grid {
    grid-template-columns: 1fr !important;
  }
  body:not(.splash-body) .editorial-grid .media-feature {
    order: 1 !important;
    border-right: 0 !important;
    border-bottom: 1px solid var(--line) !important;
  }
  body:not(.splash-body) .editorial-grid .side-stack {
    order: 2 !important;
  }
}

/* Keep only the narrower/tighter mobile hero */
@media (max-width: 760px) {
  body:not(.splash-body) .atomic-hero .hero-copy {
    min-height: 185px !important;
    padding: 18px 16px 24px !important;
  }
  body:not(.splash-body) .atomic-hero .hero-wordmark {
    font-size: clamp(2.65rem, 13.5vw, 4.05rem) !important;
    line-height: 0.86 !important;
    margin-bottom: 8px !important;
  }
  body:not(.splash-body) .layered-media.hero-image,
  body:not(.splash-body) .layered-media.hero-image img {
    max-height: 315px !important;
  }
}

/* Extra-tight mobile hero */
@media (max-width: 760px) {
  body:not(.splash-body) .atomic-hero .hero-copy {
    min-height: 145px !important;
    padding: 14px 14px 18px !important;
  }
  body:not(.splash-body) .atomic-hero .hero-wordmark {
    font-size: clamp(2.35rem, 11.5vw, 3.55rem) !important;
    line-height: 0.86 !important;
    margin-bottom: 6px !important;
  }
  body:not(.splash-body) .atomic-hero .hero-subtitle {
    font-size: clamp(0.82rem, 3.2vw, 0.98rem) !important;
    margin-bottom: 5px !important;
  }
  body:not(.splash-body) .atomic-hero .hero-location {
    font-size: 0.62rem !important;
  }
  body:not(.splash-body) .atomic-aside .booking-strip {
    padding: 11px 14px !important;
  }
  body:not(.splash-body) .atomic-aside .booking-email {
    font-size: clamp(0.86rem, 3.2vw, 1rem) !important;
  }
  body:not(.splash-body) .layered-media.hero-image,
  body:not(.splash-body) .layered-media.hero-image img {
    max-height: 250px !important;
  }
}

/* Ultra-tight mobile hero */
@media (max-width: 760px) {
  body:not(.splash-body) .atomic-hero .hero-copy {
    min-height: 112px !important;
    padding: 10px 12px 13px !important;
  }
  body:not(.splash-body) .atomic-hero .hero-wordmark {
    font-size: clamp(2.05rem, 10vw, 3.05rem) !important;
    line-height: 0.84 !important;
    margin-bottom: 4px !important;
  }
  body:not(.splash-body) .atomic-hero .hero-subtitle {
    font-size: clamp(0.76rem, 2.8vw, 0.9rem) !important;
    margin-bottom: 3px !important;
  }
  body:not(.splash-body) .atomic-hero .hero-location {
    font-size: 0.56rem !important;
    letter-spacing: 0.11em !important;
  }
  body:not(.splash-body) .atomic-aside .booking-strip {
    padding: 8px 12px !important;
  }
  body:not(.splash-body) .atomic-aside .booking-email {
    font-size: clamp(0.78rem, 2.9vw, 0.92rem) !important;
  }
  body:not(.splash-body) .layered-media.hero-image,
  body:not(.splash-body) .layered-media.hero-image img {
    max-height: 200px !important;
  }
}

/* Header external links pink */
body:not(.splash-body) .site-header .external-nav a {
  color: #E3008A !important;
}
body:not(.splash-body) .site-header .external-nav a:hover,
body:not(.splash-body) .site-header .external-nav a:focus-visible {
  color: #d8ff3c !important;
}

/* Permanent acid section headings */
body:not(.splash-body) #support h3,
body:not(.splash-body) #listen h3,
body:not(.splash-body) #format h3,
body:not(.splash-body) .media-bio h3,
body:not(.splash-body) .release-strip-header h3 {
  color: #d8ff3c !important;
}

/* Plus-only rail marker positioning */
body:not(.splash-body) .section-rail {
  justify-content: flex-start !important;
  align-items: center !important;
  padding-top: 12px !important;
}
body:not(.splash-body) .rail-mark {
  color: #d8ff3c !important;
}
@media (max-width: 900px) {
  body:not(.splash-body) .section-rail {
    justify-content: flex-start !important;
    align-items: center !important;
    padding: 8px 12px !important;
  }
}

/* Floating menu on mobile */
@media (max-width: 760px) {
  body:not(.splash-body) .site-header {
    position: sticky !important;
    top: 8px !important;
    z-index: 50 !important;
    backdrop-filter: blur(14px) !important;
    background: rgba(0, 0, 0, 0.82) !important;
  }
}

/* Sussex Mix / Mixcloud embed in colour */
body:not(.splash-body) .mixcloud-embed {
  filter: none !important;
}

/* Open on Mixcloud pink */
body:not(.splash-body) .listen-link {
  color: #E3008A !important;
}
body:not(.splash-body) .listen-link:hover,
body:not(.splash-body) .listen-link:focus-visible {
  color: #d8ff3c !important;
}

/* Open on Mixcloud: pink only when highlighted */
body:not(.splash-body) .listen-link {
  color: var(--ink) !important;
}
body:not(.splash-body) .listen-link:hover,
body:not(.splash-body) .listen-link:focus-visible {
  color: #E3008A !important;
}
