:root {
  --bg: #000000;
  --bg-soft: #000000;
  --canvas-bg: #000000;
  --panel: rgba(255, 255, 255, 0.03);
  --panel-strong: rgba(255, 255, 255, 0.045);
  --border: rgba(255, 255, 255, 0.08);
  --text: #f3ede3;
  --text-soft: rgba(243, 237, 227, 0.78);
  --text-dim: rgba(243, 237, 227, 0.42);
  --shadow: 0 28px 80px rgba(0, 0, 0, 0.28);
  --radius: 24px;
  color-scheme: dark;
  --font-mono: "Geist Mono", "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  --font-sans: "Geist", "Inter", "Avenir Next", "Helvetica Neue", Arial, sans-serif;
  --background-glow-color-rgb: 255 255 255;
  --background-glow-strength: 0;
  --background-glow-blur: 240px;
  --background-glow-x: 52%;
  --background-glow-y: 50%;
  --background-vignette: 1;
  --reflection-fade-height: 30%;
  --reflection-fade-blur: 18px;
  --reflection-fade-top: 0.11;
  --reflection-fade-mid: 0.71;
  --reflection-fade-bottom: 0.7;
  --reflection-fade-edge-dark: 0.44;
  --reflection-fade-edge-soft: 0.097;
  --reflection-fade-center-dark: 0.26;
  --reflection-fade-center-peak: 0.3;
  --reflection-gap-active: 4px;
  --reflection-gap-side: 0px;
  --reflection-opacity-master: 0.47;
  --reflection-opacity-active: 0.47;
  --reflection-opacity-near: 0.165;
  --reflection-opacity-far: 0.197;
  --reflection-blur-active: 2px;
  --reflection-blur-near: 8px;
  --reflection-blur-far: 24px;
  --reflection-glow-opacity-active: 0.052;
  --reflection-glow-opacity-near: 0.073;
  --reflection-glow-opacity-far: 0.103;
  --reflection-active-start: 0.007;
  --reflection-active-secondary: 0.0035;
  --reflection-active-black-1: 0.9;
  --reflection-active-black-2: 0.985;
  --reflection-side-start: 0;
  --reflection-side-black-1: 0.95;
  --reflection-side-black-2: 0.995;
  font-family: var(--font-mono);
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

html,
body {
  min-height: 100%;
}

body {
  margin: 0;
  background: var(--canvas-bg);
  color: var(--text);
  overflow-x: hidden;
  overflow-y: auto;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background: none;
  opacity: 0;
}

.app-shell {
  position: relative;
  z-index: 1;
  width: min(100%, 1520px);
  min-height: 100vh;
  margin: 0 auto;
  padding: clamp(1rem, 2vw, 1.6rem);
  display: grid;
  gap: 1.5rem;
}

.control-strip {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto auto;
  gap: 1rem;
  align-items: end;
  font-family: var(--font-sans);
}

.control-strip__summary {
  margin: 0 1rem 0 0;
  color: var(--text-dim);
  font-size: 0.78rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  white-space: nowrap;
}

.field {
  display: grid;
  gap: 0.4rem;
}

.field__label {
  color: var(--text-dim);
  font-size: 0.68rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-family: var(--font-sans);
}

.field input,
.field select,
.ghost-button {
  min-height: 3.1rem;
  padding: 0.82rem 1rem;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: var(--panel);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 1rem;
}

.field input::placeholder {
  color: rgba(243, 237, 227, 0.34);
}

.field select {
  appearance: none;
}

.field--compact {
  min-width: 10rem;
}

.ghost-button {
  cursor: pointer;
  transition: border-color 180ms ease, background 180ms ease, transform 180ms ease;
}

.ghost-button:hover,
.transport__button:hover {
  transform: translateY(-1px);
  border-color: rgba(255, 255, 255, 0.18);
  background: var(--panel-strong);
}

.experience-shell {
  display: grid;
  gap: 1.5rem;
}

.gallery-shell {
  position: relative;
  isolation: isolate;
  display: grid;
  gap: 1.35rem;
}

.gallery-stage {
  position: relative;
  isolation: isolate;
  z-index: 1;
  min-height: clamp(24rem, 62vh, 52rem);
  overflow: hidden;
  border-radius: 8px;
  background: var(--canvas-bg);
  box-shadow: none;
}

.gallery-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    radial-gradient(
      circle at var(--background-glow-x) var(--background-glow-y),
      rgba(255, 255, 255, 0.055) 0%,
      rgba(255, 255, 255, 0.018) 14%,
      rgba(255, 255, 255, 0) 28%
    ),
    radial-gradient(
      circle at var(--background-glow-x) var(--background-glow-y),
      rgba(0, 0, 0, 0) 0%,
      rgba(0, 0, 0, calc(var(--background-vignette) * 0.08)) 34%,
      rgba(0, 0, 0, calc(var(--background-vignette) * 0.34)) 58%,
      rgba(0, 0, 0, calc(var(--background-vignette) * 0.7)) 82%,
      rgba(0, 0, 0, var(--background-vignette)) 100%
    ),
    linear-gradient(
      90deg,
      rgba(0, 0, 0, calc(var(--background-vignette) * 0.34)) 0%,
      rgba(0, 0, 0, 0) 18%,
      rgba(0, 0, 0, 0) 82%,
      rgba(0, 0, 0, calc(var(--background-vignette) * 0.34)) 100%
    );
}

.gallery-stage::after {
  content: "";
  position: absolute;
  left: calc(var(--reflection-fade-blur) * -2);
  right: calc(var(--reflection-fade-blur) * -2);
  bottom: calc(var(--reflection-fade-blur) * -2);
  height: calc(var(--reflection-fade-height) + (var(--reflection-fade-blur) * 2));
  z-index: 3;
  pointer-events: none;
  background:
    linear-gradient(
      180deg,
      rgba(0, 0, 0, 0) 0%,
      rgba(0, 0, 0, var(--reflection-fade-top)) 14%,
      rgba(0, 0, 0, var(--reflection-fade-mid)) 48%,
      rgba(0, 0, 0, var(--reflection-fade-bottom)) 82%,
      rgba(0, 0, 0, 1) 100%
    ),
    linear-gradient(
      90deg,
      rgba(0, 0, 0, var(--reflection-fade-edge-dark)) 0%,
      rgba(0, 0, 0, var(--reflection-fade-edge-soft)) 20%,
      rgba(0, 0, 0, var(--reflection-fade-center-dark)) 36%,
      rgba(0, 0, 0, var(--reflection-fade-center-peak)) 50%,
      rgba(0, 0, 0, var(--reflection-fade-center-dark)) 64%,
      rgba(0, 0, 0, var(--reflection-fade-edge-soft)) 80%,
      rgba(0, 0, 0, var(--reflection-fade-edge-dark)) 100%
    );
  filter: blur(var(--reflection-fade-blur));
}

.gallery-ambience {
  position: absolute;
  inset: clamp(-7rem, -12vh, -3rem) -8rem 6rem;
  z-index: 0;
  overflow: visible;
  pointer-events: none;
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(255, 255, 255, 1) 0%,
    rgba(255, 255, 255, 1) 60%,
    rgba(255, 255, 255, 0.72) 72%,
    rgba(255, 255, 255, 0.22) 84%,
    rgba(255, 255, 255, 0) 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(255, 255, 255, 1) 0%,
    rgba(255, 255, 255, 1) 60%,
    rgba(255, 255, 255, 0.72) 72%,
    rgba(255, 255, 255, 0.22) 84%,
    rgba(255, 255, 255, 0) 100%
  );
}

.gallery-ambience::before {
  content: "";
  position: absolute;
  inset: calc(var(--background-glow-blur) * -1.5);
  pointer-events: none;
  background: radial-gradient(
    circle at var(--background-glow-x) var(--background-glow-y),
    rgb(var(--background-glow-color-rgb) / calc(var(--background-glow-strength) * 1.08)) 0%,
    rgb(var(--background-glow-color-rgb) / calc(var(--background-glow-strength) * 0.78)) 14%,
    rgb(var(--background-glow-color-rgb) / calc(var(--background-glow-strength) * 0.34)) 32%,
    rgb(var(--background-glow-color-rgb) / calc(var(--background-glow-strength) * 0.12)) 46%,
    rgb(var(--background-glow-color-rgb) / 0) 62%
  );
  filter: blur(var(--background-glow-blur));
  transform: translate3d(0, 0, 0);
}

.gallery-ambience::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: none;
}

.cover-layer {
  position: absolute;
  inset: 0;
  z-index: 1;
  perspective: 3400px;
  transform-style: preserve-3d;
  pointer-events: none;
  overflow: hidden;
}

.cover-frame {
  --card-reflection-gap: var(--reflection-gap-active);
  --card-reflection-opacity: var(--reflection-opacity-active);
  --card-reflection-blur: var(--reflection-blur-active);
  --card-reflection-glow-opacity: var(--reflection-glow-opacity-active);
  --card-reflection-start: var(--reflection-active-start);
  --card-reflection-secondary: var(--reflection-active-secondary);
  --card-reflection-black-1: var(--reflection-active-black-1);
  --card-reflection-black-2: var(--reflection-active-black-2);
  position: absolute;
  top: 48%;
  left: 50%;
  width: clamp(7.4rem, 13.6vw, 15rem);
  aspect-ratio: 1 / 1;
  pointer-events: none;
  transform-style: preserve-3d;
  will-change: transform, opacity;
  transition:
    transform 860ms cubic-bezier(0.12, 0.92, 0.24, 1),
    opacity 560ms cubic-bezier(0.22, 1, 0.36, 1);
}

.cover-card {
  position: absolute;
  inset: 0;
  padding: 0;
  appearance: none;
  border: 0;
  border-radius: 2px;
  overflow: hidden;
  background: #121212;
  transform: translateZ(0);
  transform-style: preserve-3d;
  backface-visibility: hidden;
  box-shadow:
    0 36px 110px rgba(0, 0, 0, 0.64),
    0 0 30px rgba(255, 255, 255, 0.05);
  transition:
    transform 860ms cubic-bezier(0.12, 0.92, 0.24, 1),
    filter 860ms cubic-bezier(0.12, 0.92, 0.24, 1),
    box-shadow 520ms cubic-bezier(0.22, 1, 0.36, 1);
  pointer-events: auto;
  cursor: pointer;
  will-change: filter;
  -webkit-box-reflect: below var(--card-reflection-gap) linear-gradient(
    to bottom,
    rgb(0 0 0 / 0) 0%,
    rgb(255 255 255 / calc(var(--card-reflection-opacity) * var(--card-reflection-start))) 10%,
    rgb(255 255 255 / calc(var(--card-reflection-opacity) * var(--card-reflection-secondary))) 16%,
    rgb(0 0 0 / calc(var(--card-reflection-opacity) * var(--card-reflection-black-1))) 32%,
    rgb(0 0 0 / calc(var(--card-reflection-opacity) * var(--card-reflection-black-2))) 52%,
    rgb(0 0 0 / var(--card-reflection-opacity)) 100%
  );
}

.cover-reflection {
  position: absolute;
  top: calc(100% + var(--card-reflection-gap));
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  pointer-events: none;
  opacity: var(--card-reflection-glow-opacity);
  transform: scaleY(-1);
  transform-origin: top center;
  filter: blur(var(--card-reflection-blur));
  transition:
    opacity 860ms cubic-bezier(0.12, 0.92, 0.24, 1),
    filter 860ms cubic-bezier(0.12, 0.92, 0.24, 1),
    top 860ms cubic-bezier(0.12, 0.92, 0.24, 1);
  -webkit-mask-image: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.88) 0%,
    rgba(255, 255, 255, 0.5) 24%,
    rgba(255, 255, 255, 0.14) 56%,
    rgba(255, 255, 255, 0) 100%
  );
  mask-image: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.88) 0%,
    rgba(255, 255, 255, 0.5) 24%,
    rgba(255, 255, 255, 0.14) 56%,
    rgba(255, 255, 255, 0) 100%
  );
}

.cover-reflection::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.02) 0%,
    rgba(255, 255, 255, 0.008) 14%,
    rgba(0, 0, 0, 0.72) 42%,
    rgba(0, 0, 0, 0.94) 72%,
    rgba(0, 0, 0, 1) 100%
  );
}

.cover-reflection__image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  background: #0f0f0f;
  transition: filter 860ms cubic-bezier(0.12, 0.92, 0.24, 1);
}

.cover-card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 18%, transparent 20%, rgba(0, 0, 0, 0.14));
}

.cover-card:hover,
.cover-card--active {
  box-shadow:
    0 42px 128px rgba(0, 0, 0, 0.76),
    0 0 36px rgba(255, 255, 255, 0.08);
}

.cover-card--to-center-from-left {
  animation: cover-card-to-center-from-left 900ms cubic-bezier(0.12, 0.92, 0.24, 1);
}

.cover-card--to-center-from-right {
  animation: cover-card-to-center-from-right 900ms cubic-bezier(0.12, 0.92, 0.24, 1);
}

.cover-card--from-center-to-left {
  animation: cover-card-from-center-to-left 820ms cubic-bezier(0.12, 0.92, 0.24, 1);
}

.cover-card--from-center-to-right {
  animation: cover-card-from-center-to-right 820ms cubic-bezier(0.12, 0.92, 0.24, 1);
}

.cover-card--side {
  box-shadow:
    0 24px 64px rgba(0, 0, 0, 0.48),
    0 0 18px rgba(255, 255, 255, 0.03);
}

.cover-card--near,
.cover-card--far,
.cover-frame--near,
.cover-frame--far {
  --card-reflection-gap: var(--reflection-gap-side);
  --card-reflection-start: var(--reflection-side-start);
  --card-reflection-secondary: 0;
  --card-reflection-black-1: var(--reflection-side-black-1);
  --card-reflection-black-2: var(--reflection-side-black-2);
}

.cover-card--near,
.cover-frame--near {
  --card-reflection-opacity: var(--reflection-opacity-near);
  --card-reflection-blur: var(--reflection-blur-near);
  --card-reflection-glow-opacity: var(--reflection-glow-opacity-near);
}

.cover-card--far,
.cover-frame--far {
  --card-reflection-opacity: var(--reflection-opacity-far);
  --card-reflection-blur: var(--reflection-blur-far);
  --card-reflection-glow-opacity: var(--reflection-glow-opacity-far);
}

.cover-card__image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  background: #0f0f0f;
}

.cover-card__placeholder {
  position: absolute;
  inset: 0;
  display: grid;
  align-content: end;
  gap: 0.35rem;
  padding: 1rem;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.015)),
    linear-gradient(135deg, #515151, #1b1b1b 70%);
}

.cover-card__genre {
  color: rgba(243, 237, 227, 0.64);
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.cover-card__title {
  color: white;
  font-family: "Geist Mono", "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: clamp(1rem, 1.35vw, 1.5rem);
  line-height: 0.9;
}

.cover-card__artist {
  color: rgba(243, 237, 227, 0.76);
  font-size: 0.75rem;
  line-height: 1.2;
}

.cover-card--side .cover-card__genre,
.cover-card--side .cover-card__artist {
  opacity: 0;
}

.cover-card--side .cover-card__title {
  font-size: 0.94rem;
  opacity: 0.46;
  line-height: 1.02;
}

.scene-empty {
  position: absolute;
  inset: 0;
  z-index: 5;
  display: grid;
  place-items: center;
  padding: 2rem;
  background: rgba(9, 9, 9, 0.58);
  backdrop-filter: blur(8px);
}

.scene-empty__box {
  max-width: 28rem;
  padding: 1.75rem;
  border-radius: 22px;
  text-align: center;
  background: rgba(255, 255, 255, 0.035);
  border: 1px solid var(--border);
}

.scene-empty__title,
.album-summary__title,
.section-heading h2 {
  margin: 0;
  font-family: var(--font-sans);
  font-weight: 600;
  letter-spacing: 0.01em;
}

.scene-empty__title {
  font-size: 1.8rem;
}

.scene-empty__copy {
  margin: 0.75rem 0 0;
  color: var(--text-soft);
  line-height: 1.6;
  font-family: var(--font-sans);
}

.scene-empty__button {
  margin-top: 1rem;
  min-height: 2.8rem;
  padding: 0.7rem 1rem;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: var(--panel);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 1rem;
  cursor: pointer;
}

.transport {
  width: min(100%, 52rem);
  margin: 0 auto 1.35rem;
  padding-inline: 1rem;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 1rem;
  align-items: center;
}

.transport__button {
  width: 3rem;
  height: 3rem;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: var(--panel);
  color: var(--text);
  font-size: 1.8rem;
  line-height: 1;
  cursor: pointer;
  transition: border-color 180ms ease, background 180ms ease, transform 180ms ease;
}

.transport__button:disabled {
  opacity: 0.28;
  cursor: default;
  transform: none;
}

.transport__slider {
  width: 100%;
  appearance: none;
  height: 0.45rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.07);
}

.transport__slider::-webkit-slider-thumb {
  appearance: none;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: #f3ede3;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.25);
}

.transport__slider::-moz-range-thumb {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: #f3ede3;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.25);
}

.album-panel {
  position: relative;
  display: grid;
  grid-template-columns: minmax(18rem, 0.95fr) minmax(0, 1.05fr);
  gap: 2rem;
  align-items: start;
  padding-top: 1.4rem;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.album-summary,
.tracklist-panel {
  min-height: 0;
}

.tracklist-panel {
  margin-left: clamp(0.35rem, 0.9vw, 0.85rem);
  padding-left: clamp(1.4rem, 2vw, 2.25rem);
  padding-top: clamp(0.9rem, 1.6vw, 1.15rem);
  border-left: 1px solid rgba(255, 255, 255, 0.06);
}

.album-summary__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin: 0.5rem 0 1.5rem;
}

.album-summary__kicker {
  margin: 0;
  color: var(--text-dim);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-family: var(--font-sans);
}

/* Match the kicker's typographic rhythm so the two read as one line. */
.album-summary__head .follow-button {
  flex: none;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  line-height: 1;
  padding: 7px 14px;
}

.album-summary__title {
  font-size: clamp(2rem, 3vw, 3.2rem);
  line-height: 0.94;
}

.album-summary__artist {
  margin: 0.7rem 0 0;
  color: var(--text-soft);
  font-size: 1.02rem;
  font-family: var(--font-sans);
}

.album-summary__meta {
  margin: 0.9rem 0 0;
  color: var(--text-dim);
  font-size: 0.9rem;
  letter-spacing: 0.05em;
  font-family: var(--font-sans);
}

.listen-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: 1.5rem;
}

.listen-link {
  color: var(--text);
  text-decoration: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.14);
  padding-bottom: 0.25rem;
  transition: opacity 180ms ease, border-color 180ms ease;
  font-family: var(--font-sans);
}

.listen-link:hover {
  opacity: 0.7;
  border-color: rgba(255, 255, 255, 0.3);
}

.listen-link.is-disabled {
  opacity: 0.32;
  pointer-events: none;
}

.section-heading {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 0.75rem;
  padding-bottom: 0.95rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

.section-heading h2 {
  font-size: clamp(1.4rem, 2vw, 2rem);
}

.tracklist-panel__status {
  margin: 0;
  color: var(--text-dim);
  font-size: 0.82rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-family: var(--font-sans);
}

.tracklist-list {
  margin: 1rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.65rem;
}

.tracklist-list--empty {
  display: block;
}

.tracklist-list--no-duration .tracklist-list__item {
  grid-template-columns: auto minmax(0, 1fr);
}

.tracklist-list--no-duration .tracklist-list__duration {
  display: none;
}

.tracklist-list__item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 0.8rem;
  align-items: baseline;
  padding-bottom: 0.78rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.tracklist-list__position {
  min-width: 2rem;
  color: var(--text-dim);
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  font-family: var(--font-sans);
}

.tracklist-list__title-wrap {
  min-width: 0;
}

.tracklist-list__heading {
  display: block;
  margin-bottom: 0.12rem;
  color: var(--text-dim);
  font-size: 0.64rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-family: var(--font-sans);
}

.tracklist-list__title {
  color: rgba(243, 237, 227, 0.8);
  font-size: 0.96rem;
  font-family: var(--font-sans);
}

.tracklist-list__duration {
  color: var(--text-soft);
  font-size: 0.86rem;
  font-variant-numeric: tabular-nums;
  font-family: var(--font-sans);
}

.tracklist-list__empty-copy {
  color: var(--text-soft);
  line-height: 1.6;
  font-family: var(--font-sans);
}

@media (prefers-reduced-motion: reduce) {
  .cover-card {
    transition: none;
  }
}

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

  .field--search {
    grid-column: 1 / -1;
  }

  .album-panel {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .tracklist-panel {
    margin-left: 0;
    padding-left: 0;
    padding-top: 1.15rem;
    border-left: 0;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
  }
}

@media (max-width: 780px) {
  .app-shell {
    padding: 0.85rem;
    gap: 1rem;
  }

  .control-strip {
    grid-template-columns: 1fr;
  }

  .field--compact {
    min-width: 0;
  }

  .gallery-stage {
    min-height: 22rem;
    border-radius: 22px;
  }

  .cover-frame {
    width: clamp(6.4rem, 20vw, 8.8rem);
  }

  .transport {
    width: 100%;
    margin-bottom: 1rem;
    padding-inline: 0;
  }

  .album-summary__title {
    font-size: clamp(1.8rem, 8vw, 2.5rem);
  }

  .tracklist-list__item {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .tracklist-list__duration {
    grid-column: 2;
  }
}

/* OVERRIDES */
.control-strip { position:fixed!important;top:0;right:0;z-index:200;background:none!important;border:none!important;padding:12px!important;display:flex!important;align-items:center;justify-content:flex-end;gap:10px!important;width:auto!important;grid-template-columns:unset!important; }

/* Etched in the run-out groove, like on the record it comes from. The
   faint base text carries a shine that sweeps across it — driven by the
   gyroscope on phones and the mouse on desktop, like tilting the vinyl
   against the light. */
.deadwax-etching {
  text-align: center;
  font-family: var(--font-mono);
  font-size: 0.625rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin: 0;
  padding: 3.5rem 1rem 1.75rem;
  color: rgba(243, 237, 227, 0.09);
  background-image: linear-gradient(
    100deg,
    rgba(243, 237, 227, 0) 25%,
    rgba(243, 237, 227, 0.35) 50%,
    rgba(243, 237, 227, 0) 75%
  );
  background-repeat: no-repeat;
  background-size: 55% 100%;
  background-position-y: 0;
  background-position-x: var(--shine, -80%);
  -webkit-background-clip: text;
  background-clip: text;
  transition: background-position-x 1.1s cubic-bezier(0.22, 1, 0.36, 1);
}

@keyframes deadwax-sweep {
  from { background-position-x: -80%; }
  to { background-position-x: 180%; }
}

.deadwax-etching--sweep {
  animation: deadwax-sweep 5s ease-in-out;
}

.deadwax-etching::selection {
  background: var(--text);
  color: #000;
}

/* The chrome (brand + controls) hides as soon as you scroll down and
   comes back on any scroll up. */
.brand,
.control-strip {
  transition: opacity 0.25s ease, transform 0.25s ease;
}

body.chrome-hidden .brand,
body.chrome-hidden .control-strip {
  opacity: 0;
  transform: translateY(-10px);
  pointer-events: none;
}

.search-toggle { background:rgba(0,0,0,0.5);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.12);color:rgba(255,255,255,0.7);width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center; }
.search-overlay { position:fixed;top:0;left:0;right:0;z-index:300;background:rgba(0,0,0,0.92);backdrop-filter:blur(16px);padding:12px 16px;display:flex;align-items:center;gap:12px; }
.search-overlay input { flex:1;background:none;border:none;border-bottom:1px solid rgba(255,255,255,0.2);color:#fff;font-family:var(--font-sans);font-size:1rem;padding:8px 0;outline:none; }
.search-overlay input::placeholder { color:rgba(255,255,255,0.3); }
.search-close { background:none;border:none;color:rgba(255,255,255,0.5);font-size:1rem;cursor:pointer;padding:8px; }
.player-shell { grid-column:1/-1;padding-top:1.5rem;border-top:1px solid var(--border);margin-top:2rem; }
.player-label { font-size:0.6875rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-soft);margin-bottom:0.75rem;display:flex;align-items:center;gap:0.5rem; }
.player-label::before { content:'';width:6px;height:6px;border-radius:50%;background:#ff0000; }
.player-iframe-wrap { width:100%;aspect-ratio:16/9;max-height:240px;border-radius:6px;overflow:hidden; }
.player-iframe-wrap iframe { width:100%;height:100%;border:none;display:block; }
.player-searching { display:flex;align-items:center;justify-content:center;height:60px;color:var(--text-soft);font-size:0.75rem; }
.player-not-found { display:flex;align-items:center;justify-content:center;height:44px;color:var(--text-soft);font-size:0.7rem;opacity:0.5; }
.tuning-panel { position:fixed;left:16px;bottom:16px;z-index:420;width:min(360px,calc(100vw - 32px));padding:0.9rem 1rem 1rem;border:1px solid rgba(255,255,255,0.1);border-radius:16px;background:rgba(0,0,0,0.82);backdrop-filter:blur(14px);box-shadow:0 24px 64px rgba(0,0,0,0.45);font-family:var(--font-sans); }
.tuning-panel { max-height:calc(100vh - 32px);overflow-y:auto;overscroll-behavior:contain;scrollbar-width:thin; }
.tuning-panel summary { position:sticky;top:-0.9rem;z-index:2;margin:-0.9rem -1rem 0;padding:0.9rem 1rem 0.8rem;background:rgba(0,0,0,0.92);cursor:pointer;color:var(--text);font-size:0.8rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;list-style:none;backdrop-filter:blur(14px); }
.tuning-panel summary::-webkit-details-marker { display:none; }
.tuning-grid { display:grid;gap:0.7rem;margin-top:0.9rem; }
.tuning-field { display:grid;grid-template-columns:minmax(0,1fr) auto;gap:0.3rem 0.75rem;align-items:center; }
.tuning-field span,.tuning-field output { color:var(--text-soft);font-size:0.72rem; }
.tuning-field span { letter-spacing:0.06em;text-transform:uppercase; }
.tuning-field output { font-family:var(--font-mono); }
.tuning-field input[type="range"] { grid-column:1 / -1;width:100%;appearance:none;height:0.35rem;border-radius:999px;background:rgba(255,255,255,0.12); }
.tuning-field input[type="range"]::-webkit-slider-thumb { appearance:none;width:1rem;height:1rem;border-radius:50%;background:#f3ede3;border:1px solid rgba(255,255,255,0.18); }
.tuning-field input[type="range"]::-moz-range-thumb { width:1rem;height:1rem;border-radius:50%;background:#f3ede3;border:1px solid rgba(255,255,255,0.18); }
.tuning-field input[type="color"] { grid-column:1 / -1;width:100%;min-height:2.5rem;padding:0.2rem;border-radius:12px;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.04);cursor:pointer; }
.tuning-field input[type="color"]::-webkit-color-swatch-wrapper { padding:0; }
.tuning-field input[type="color"]::-webkit-color-swatch { border:0;border-radius:8px; }
.tuning-field input[type="color"]::-moz-color-swatch { border:0;border-radius:8px; }
.tuning-output { width:100%;min-height:7rem;margin-top:0.9rem;padding:0.7rem 0.8rem;border-radius:12px;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.03);color:var(--text-soft);font:0.72rem/1.5 var(--font-mono);resize:vertical; }
.tuning-actions { display:flex;gap:0.65rem;margin-top:0.8rem; }
.tuning-button { min-height:2.4rem;padding:0.55rem 0.8rem;border-radius:12px;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.06);color:var(--text);font-family:var(--font-sans);font-size:0.82rem;cursor:pointer; }
.tuning-button--ghost { background:transparent;color:var(--text-soft); }
@media (prefers-reduced-motion:reduce) {
  .cover-frame,
  .cover-card,
  .cover-reflection,
  .cover-reflection__image {
    transition-duration: 0ms !important;
    animation: none !important;
  }
}

@keyframes cover-card-to-center-from-left {
  0% { transform: rotateY(18deg) scale(0.982); }
  56% { transform: rotateY(-5deg) scale(1.008); }
  100% { transform: rotateY(0deg) scale(1); }
}

@keyframes cover-card-to-center-from-right {
  0% { transform: rotateY(-18deg) scale(0.982); }
  56% { transform: rotateY(5deg) scale(1.008); }
  100% { transform: rotateY(0deg) scale(1); }
}

@keyframes cover-card-from-center-to-left {
  0% { transform: rotateY(0deg) scale(1); }
  100% { transform: rotateY(9deg) scale(0.988); }
}

@keyframes cover-card-from-center-to-right {
  0% { transform: rotateY(0deg) scale(1); }
  100% { transform: rotateY(-9deg) scale(0.988); }
}
@media (max-width:768px) {
  .app-shell { min-height:100svh;padding:0.7rem 1.2rem 1rem; }
  .experience-shell { display:grid!important;gap:0.9rem;height:auto;overflow:visible; }
  .gallery-shell { min-height:0;gap:0.55rem; }
  .gallery-stage { min-height:clamp(24.5rem,64svh,33rem);height:auto!important;border-radius:18px; }
  .gallery-ambience { inset:clamp(-4.5rem,-10svh,-2rem) -3rem 5.6rem; }
  .cover-layer { perspective:2200px; perspective-origin:50% 50%; }
  .cover-frame { top:50%;width:clamp(9.9rem,33vw,12rem); }
  .transport { margin:-1.45rem auto 0.8rem;padding-inline:0.1rem;gap:0.75rem; }
  .transport__button { width:2.75rem;height:2.75rem;font-size:1.65rem; }
  .album-panel { display:grid!important;grid-template-columns:1fr;overflow:visible;padding:1rem 0 0!important;gap:1.15rem!important;min-height:0;border-top:1px solid rgba(255,255,255,0.05); }
  .album-summary,.tracklist-panel,#player-shell { flex-shrink:initial; }
  .album-summary__title { font-size:clamp(1.8rem,9vw,2.8rem);line-height:0.96; }
  .album-summary__artist { font-size:0.92rem; }
  .album-summary__meta { font-size:0.82rem;line-height:1.45; }
  .listen-strip { margin-top:1.15rem;gap:0.85rem; }
  .tracklist-panel { padding-top:0.9rem; }
  .section-heading { align-items:start;flex-wrap:wrap; }
  .tracklist-panel__status { font-size:0.72rem; }
  .player-iframe-wrap { max-height:180px; }
  .tuning-panel { left:10px;right:10px;bottom:10px;width:auto; }
}

/* Transport siempre por encima de las tapas */
.transport {
  position: relative;
  z-index: 50;
}

/* Prevenir zoom por doble tap en iOS */
* {
  touch-action: manipulation;
}

/* Bloquear scroll horizontal */
html, body {
  overflow-x: hidden;
  max-width: 100vw;
}

/* --- Grid view ------------------------------------------------------------ */
.grid-layer {
  position: absolute;
  inset: 0;
  z-index: 3;
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  /* Scroll works, the bar is just visual noise here. */
  scrollbar-width: none;
  /* auto rows mis-size to fractions of the container with these children
     (Chrome); max-content measures the square images correctly. */
  grid-auto-rows: max-content;
  gap: 10px;
  /* Top padding clears the fixed control buttons (12px + 36px + breathing
     room), mirroring the search-bar band. */
  padding: 72px 14px 14px;
  overflow-y: auto;
  align-content: start;
  -webkit-overflow-scrolling: touch;
}

.grid-layer::-webkit-scrollbar {
  display: none;
}

.grid-layer[hidden],
.cover-layer[hidden],
.transport[hidden] {
  display: none !important;
}

.gallery-stage--grid::before,
.gallery-stage--grid::after {
  display: none;
}

.grid-cell {
  position: relative;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 2px;
  background: rgba(255, 255, 255, 0.03);
  overflow: hidden;
  cursor: pointer;
}

/* The image is the in-flow child that sizes the cell (and the grid row
   track): replaced elements contribute their natural size during track
   sizing, where percentage/aspect-ratio tricks on the cell itself resolve
   to zero. Coverless cells get a 1x1 transparent GIF for the same reason. */
.grid-cell__image {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.grid-cell:hover .grid-cell__image {
  opacity: 0.85;
}

.grid-cell.is-active {
  outline: 2px solid var(--text);
  outline-offset: -2px;
}

.grid-cell__label {
  position: absolute;
  inset: 0;
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  padding: 8px;
  text-align: center;
}

.grid-cell--placeholder .grid-cell__label {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  padding: 8px;
  text-align: center;
}

.grid-cell__label-title {
  font-family: var(--font-sans);
  font-size: 0.7rem;
  font-weight: 600;
  line-height: 1.25;
  color: var(--text);
}

.grid-cell__label-artist {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-dim);
}

.view-in-flow {
  background: none;
  border: none;
  padding: 0;
  margin: 0 0 0.4rem;
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-dim);
}

.view-in-flow:hover {
  color: var(--text);
}

@media (max-width: 768px) {
  .grid-layer {
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    padding: 64px 10px 10px;
  }
}

/* --- Full-screen grid mode -------------------------------------------------- */
.app-shell.view-grid .experience-shell .album-panel {
  display: none !important;
}

.app-shell.view-grid .gallery-stage {
  min-height: calc(100dvh - 3.5rem);
}

/* --- Record detail overlay --------------------------------------------------- */
.record-overlay {
  position: fixed;
  inset: 0;
  z-index: 500;
  /* Opaque: a translucent background + backdrop-filter lets the grid behind
     flash through while compositing during scroll. */
  background: #000;
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  padding: 48px 48px 40px;
}

/* Freeze the page behind the overlay so scroll can't chain into the grid. */
body.overlay-open {
  overflow: hidden;
}

.record-overlay[hidden] {
  display: none !important;
}

.record-overlay__inner {
  display: grid;
  /* The media column is exactly as wide as the artwork, and the pair is
     centered as a unit on the screen. */
  grid-template-columns: auto minmax(340px, 640px);
  gap: 72px;
  align-items: start;
  justify-content: center;
}

.record-overlay__media {
  margin: 0;
  position: sticky;
  top: 0;
  width: min(44vw, calc(100dvh - 160px));
}

.record-overlay__image {
  width: 100%;
  display: block;
  border: 1px solid var(--border);
  box-shadow: 0 32px 90px rgba(0, 0, 0, 0.7);
}

.record-overlay__caption {
  margin: 14px 0 0;
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-dim);
  text-align: center;
}

.record-overlay__close {
  position: fixed;
  top: 16px;
  right: 16px;
  z-index: 510;
  width: 38px;
  height: 38px;
  border: 1px solid var(--border);
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.5);
  color: var(--text-soft);
  font-size: 0.9rem;
  cursor: pointer;
}

/* The album panel keeps its own internals; strip its page-layout chrome
   (two-column grid, indents, separators) when it lives inside the overlay. */
.record-overlay .album-panel {
  display: block !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
  overflow: visible !important;
  min-height: 0 !important;
}

.record-overlay .tracklist-panel {
  margin-left: 0 !important;
  padding-left: 0 !important;
  border-left: none !important;
  margin-top: 2rem;
}

.record-overlay .player-shell {
  margin-top: 2.2rem;
}

@media (max-width: 768px) {
  .record-overlay {
    padding: 60px 18px 40px;
  }

  .record-overlay__inner {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .record-overlay__media {
    position: static;
    max-width: 420px;
    margin: 0 auto;
    width: 100%;
  }
}

/* --- Brand ------------------------------------------------------------------ */
.brand {
  position: fixed;
  top: 22px;
  left: 18px;
  z-index: 200;
  opacity: 0.9;
  transition: opacity 0.2s ease;
}

.brand:hover {
  opacity: 1;
}

.brand img {
  height: 16px;
  width: auto;
  display: block;
}

/* --- Social: likes, follows, comments ---------------------------------------- */
.social-strip {
  display: flex;
  gap: 10px;
  margin-top: 1rem;
}

.social-like {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  color: var(--text-soft);
  padding: 9px 14px;
  cursor: pointer;
}

.social-like.is-liked {
  background: var(--text);
  border-color: var(--text);
  color: #000;
}

.follow-button {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: var(--text);
  border: 1px solid var(--text);
  color: #000;
  padding: 8px 14px;
  cursor: pointer;
}

.follow-button.is-following {
  background: none;
  color: var(--text-dim);
  border-color: var(--border);
}

.owner-edit-toggle {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: none;
  border: 1px solid var(--border);
  color: var(--text-dim);
  padding: 9px 14px;
  cursor: pointer;
}

.owner-edit-toggle:hover { color: var(--text); border-color: var(--border-strong); }

.owner-edit-panel {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 0.9rem;
  border: 1px solid var(--border);
  padding: 12px;
}

.owner-replace {
  display: flex;
  gap: 8px;
}

.owner-replace input {
  flex: 1;
  min-width: 0;
  background: none;
  border: none;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  padding: 6px 0;
  outline: none;
}

.owner-replace button,
.owner-delete {
  font-family: var(--font-mono);
  font-size: 0.625rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border);
  color: var(--text-soft);
  padding: 8px 12px;
  cursor: pointer;
  flex: none;
}

.owner-delete { align-self: flex-start; }

.owner-delete:hover {
  background: var(--text);
  border-color: var(--text);
  color: #000;
}

.owner-replace button:disabled,
.owner-delete:disabled { opacity: 0.5; cursor: wait; }

.social-note {
  margin: 0;
  font-size: 0.75rem;
  color: var(--text-dim);
}

.social-note a {
  color: var(--text-soft);
}

.comments-panel {
  grid-column: 1 / -1;
  border-top: 1px solid var(--border);
  margin-top: 1.6rem;
  padding-top: 1.2rem;
}

.comments-list {
  list-style: none;
  margin: 0.8rem 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.comment {
  display: flex;
  gap: 10px;
  align-items: baseline;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  padding-bottom: 8px;
}

.comment__author {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--text-dim);
  text-decoration: none;
  flex: none;
}

.comment__author:hover { color: var(--text); }

.comment__body {
  margin: 0;
  font-size: 0.875rem;
  color: var(--text-soft);
  line-height: 1.5;
  overflow-wrap: anywhere;
}

.comment__delete {
  margin-left: auto;
  background: none;
  border: none;
  color: var(--text-dim);
  cursor: pointer;
  font-size: 0.7rem;
  flex: none;
}

.comment-form {
  display: flex;
  gap: 8px;
  margin-top: 1rem;
}

.comment-form input {
  flex: 1;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 16px;
  padding: 10px 12px;
  outline: none;
}

.comment-form button {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: var(--text);
  border: 1px solid var(--text);
  color: #000;
  padding: 0 16px;
  cursor: pointer;
}
