:root {
  --radius-xs: .7rem;
  --radius-sm: 1rem;
  --radius-md: 1.4rem;
  --radius-lg: 2rem;
  --radius-xl: 2.6rem;
  --radius-full: 999px;

  --gutter: clamp(1rem, 3vw, 4rem);
  --wrap: 1180px;
  --wrap-wide: 1520px;
  --wrap-reading: 820px;

  --font-sans: Inter, Manrope, "Segoe UI", Roboto, Arial, sans-serif;
  --font-display: Manrope, Inter, "Segoe UI", Roboto, Arial, sans-serif;

  --header-height: 84px;
  --ease-out: cubic-bezier(.16, 1, .3, 1);
  --ease-spring: cubic-bezier(.2, .9, .2, 1.2);
}


* { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  text-size-adjust: 100%;
}

body {
  margin: 0;
  min-width: 320px;
  font-family: var(--font-sans);
  color: var(--ink);
  background: var(--body-bg);
  overflow-x: clip;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  background-image: var(--body-grid-bg);
  background-size: 72px 72px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.65), transparent 72%);
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: .42;
  background-image: var(--body-dots-bg);
  background-size: 18px 18px;
  mask-image: linear-gradient(180deg, transparent, rgba(0,0,0,.7) 22%, transparent 82%);
}

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

img { height: auto; }

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

button, input, textarea, select { font: inherit; }

button { border: 0; cursor: pointer; }

::selection { background: var(--pink-500); color: #fff; }

:focus-visible {
  outline: 3px solid rgba(255, 46, 154, .58);
  outline-offset: 4px;
  border-radius: .45rem;
}

.skip-link {
  position: fixed;
  left: 1rem;
  top: .75rem;
  z-index: 1000;
  transform: translateY(-180%);
  padding: .8rem 1rem;
  border-radius: var(--radius-full);
  color: #fff;
  background: var(--pink-700);
  transition: transform .2s ease;
}

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

.content-wrap {
  width: min(calc(100% - var(--gutter) - var(--gutter)), var(--wrap));
  margin-inline: auto;
}

.content-wrap--wide { --wrap: var(--wrap-wide); }
.content-wrap--reading { --wrap: var(--wrap-reading); }

.section-shell {
  position: relative;
  width: 100%;
  padding-block: clamp(3.8rem, 8vw, 8rem);
  overflow: clip;
}

.section-shell--tight { padding-block: clamp(2.4rem, 6vw, 5rem); }

.section-shell--gradient {
  background: var(--section-gradient-bg);
}

.section-shell--deep {
  color: var(--section-deep-color);
  background: var(--section-deep-bg);
}

.section-shell--split {
  background: var(--section-split-bg);
}

.page-main { padding-top: var(--header-height); }

.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 900;
  height: var(--header-height);
  display: flex;
  align-items: center;
  background: var(--header-bg);
  border-bottom: 1px solid var(--header-border);
  backdrop-filter: blur(18px) saturate(1.35);
}

.site-header.is-scrolled {
  box-shadow: var(--header-shadow);
  background: var(--header-bg-scrolled);
}

.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(.9rem, 2vw, 1.8rem);
}

.logo {
  display: inline-flex;
  align-items: center;
  gap: .75rem;
  min-width: max-content;
}

.logo__image {
  width: clamp(8.2rem, 12vw, 11.5rem);
  height: auto;
  filter: drop-shadow(0 10px 18px rgba(241, 15, 136, .16));
}

.logo__caption {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

.primary-nav {
  position: fixed;
  inset: var(--header-height) var(--gutter) auto var(--gutter);
  display: grid;
  gap: .7rem;
  padding: 1rem;
  border: 1px solid var(--panel-border);
  border-radius: var(--radius-lg);
  background: var(--nav-panel-bg);
  box-shadow: var(--shadow-card);
  transform: translateY(-1rem) scale(.98);
  opacity: 0;
  visibility: hidden;
  transition: opacity .22s ease, transform .22s var(--ease-out), visibility .22s ease;
}

body.nav-open .primary-nav {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
}

.nav-list {
  display: grid;
  gap: .4rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.nav-link {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 2.9rem;
  padding: .75rem 1rem;
  border-radius: var(--radius-full);
  color: var(--ink-soft);
  font-weight: 750;
  letter-spacing: -.01em;
  transition: color .2s ease, background-color .2s ease, transform .2s ease;
}

.nav-link:hover,
.nav-link[aria-current="page"] {
  color: var(--pink-700);
  background: var(--nav-active-bg);
}

.nav-link:hover { transform: translateY(-1px); }

.header-actions {
  display: flex;
  align-items: center;
  gap: .55rem;
}

.social-mini {
  display: none;
  align-items: center;
  gap: .42rem;
}

.social-mini__link,
.icon-button {
  display: inline-grid;
  place-items: center;
  width: 2.65rem;
  height: 2.65rem;
  border-radius: 50%;
  border: 1px solid var(--control-border);
  background: var(--control-bg);
  color: var(--pink-700);
  font-weight: 850;
  box-shadow: var(--control-shadow);
  transition: transform .2s ease, background-color .2s ease, color .2s ease;
}

.social-mini__link:hover,
.icon-button:hover {
  transform: translateY(-2px);
  color: #fff;
  background: var(--pink-600);
}

.nav-toggle {
  position: relative;
  background: var(--pink-600);
  color: #fff;
}

.nav-toggle__bar,
.nav-toggle::before,
.nav-toggle::after {
  content: "";
  width: 1.05rem;
  height: 2px;
  border-radius: 1px;
  background: currentColor;
  transition: transform .22s ease, opacity .22s ease;
}

.nav-toggle {
  gap: .24rem;
}

body.nav-open .nav-toggle::before { transform: translateY(6px) rotate(45deg); }
body.nav-open .nav-toggle::after { transform: translateY(-6px) rotate(-45deg); }
body.nav-open .nav-toggle__bar { opacity: 0; }

.hero {
  min-height: calc(100svh - var(--header-height));
  display: grid;
  align-items: center;
  padding-block: clamp(3rem, 8vw, 8rem);
  background: var(--hero-bg);
}

.hero--inner {
  min-height: auto;
  padding-block: clamp(3.4rem, 8vw, 6.4rem);
}

.hero__grid {
  display: grid;
  align-items: center;
  gap: clamp(2rem, 6vw, 6rem);
}

.hero__content { max-width: 780px; }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  margin: 0 0 1rem;
  padding: .45rem .78rem;
  border: 1px solid rgba(255, 46, 154, .20);
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, .64);
  color: var(--pink-700);
  font-size: .78rem;
  font-weight: 850;
  letter-spacing: .08em;
  text-transform: uppercase;
  box-shadow: 0 12px 32px rgba(155, 7, 87, .08);
}

.eyebrow::before {
  content: "";
  width: .5rem;
  height: .5rem;
  border-radius: 50%;
  background: var(--pink-500);
  box-shadow: 0 0 20px rgba(255, 46, 154, .70);
}

h1, h2, h3, h4, p { margin-top: 0; }

h1, h2, h3, .display-title {
  font-family: var(--font-display);
  letter-spacing: -.055em;
  line-height: .98;
}

.hero__title {
  max-width: 920px;
  margin-bottom: clamp(1rem, 2vw, 1.4rem);
  font-size: clamp(3rem, 10vw, 8.4rem);
  font-weight: 930;
}

.hero__title span,
.text-gradient {
  color: transparent;
  background: linear-gradient(100deg, var(--pink-700), var(--pink-450) 52%, var(--pink-800));
  -webkit-background-clip: text;
  background-clip: text;
}

.hero__lead {
  max-width: 680px;
  margin-bottom: 1.8rem;
  color: var(--ink-soft);
  font-size: clamp(1.02rem, 2vw, 1.28rem);
  line-height: 1.72;
}

.hero__actions,
.button-row {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem;
  align-items: center;
}

.button {
  --btn-bg: var(--pink-650);
  --btn-color: #fff;
  --btn-border: rgba(255, 255, 255, .16);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  min-height: 3.15rem;
  padding: .85rem 1.25rem;
  border: 1px solid var(--btn-border);
  border-radius: var(--radius-full);
  background: var(--btn-bg);
  color: var(--btn-color);
  font-weight: 850;
  box-shadow: 0 18px 46px rgba(213, 11, 120, .22);
  transition: transform .2s ease, box-shadow .2s ease, background-color .2s ease;
}

.button:hover {
  transform: translateY(-2px);
  box-shadow: 0 24px 60px rgba(213, 11, 120, .30);
}

.button--ghost {
  --btn-bg: var(--button-ghost-bg);
  --btn-color: var(--pink-700);
  --btn-border: var(--button-ghost-border);
  box-shadow: var(--button-ghost-shadow);
}

.button--small {
  min-height: 2.65rem;
  padding: .65rem .9rem;
  font-size: .92rem;
}

.button--light {
  --btn-bg: rgba(255, 255, 255, .92);
  --btn-color: var(--pink-700);
  --btn-border: rgba(255, 255, 255, .32);
}

.hero__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
  max-width: 640px;
  margin-top: clamp(1.5rem, 4vw, 2.6rem);
}

.stat-card {
  padding: 1rem;
  border: 1px solid var(--card-border);
  border-radius: var(--radius-md);
  background: var(--surface-soft);
  box-shadow: var(--surface-shadow);
}

.stat-card strong {
  display: block;
  color: var(--pink-700);
  font-size: clamp(1.25rem, 3vw, 2rem);
  line-height: 1;
}

.stat-card span {
  display: block;
  margin-top: .35rem;
  color: var(--muted);
  font-size: .86rem;
  line-height: 1.35;
}

.hero-visual {
  position: relative;
  width: min(100%, 600px);
  justify-self: center;
}

.hero-visual::before,
.hero-visual::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  filter: blur(8px);
  pointer-events: none;
}

.hero-visual::before {
  inset: 7% -9% auto auto;
  width: 42%;
  aspect-ratio: 1;
  background: rgba(255, 46, 154, .22);
}

.hero-visual::after {
  inset: auto auto 2% -7%;
  width: 35%;
  aspect-ratio: 1;
  background: rgba(255, 192, 221, .50);
}

.release-showcase {
  position: relative;
  isolation: isolate;
  padding: clamp(1rem, 2vw, 1.5rem);
}

.release-showcase__disc {
  position: absolute;
  z-index: 0;
  top: 10%;
  right: -7%;
  width: min(64%, 360px);
  aspect-ratio: 1;
  animation: disc-spin 16s linear infinite;
}

.release-showcase__cover {
  position: relative;
  z-index: 2;
  width: min(82vw, 440px);
  margin-inline: auto;
  border-radius: clamp(1.8rem, 4vw, 3rem);
  overflow: hidden;
  transform: rotate(-2deg);
  box-shadow: var(--shadow-deep), var(--glow);
}

.release-showcase__cover img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
}

.release-showcase__badge {
  position: absolute;
  z-index: 4;
  right: 4%;
  bottom: 10%;
  display: grid;
  gap: .2rem;
  min-width: 11.5rem;
  padding: .9rem 1rem;
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  background: var(--glass-strong);
  backdrop-filter: blur(18px);
  box-shadow: 0 18px 48px rgba(91, 0, 50, .20);
}

.release-showcase__badge small {
  color: var(--pink-700);
  font-weight: 850;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.release-showcase__badge strong { font-size: 1.25rem; }

.disc-graphic,
.release-card__disc,
.release-page__disc {
  border-radius: 50%;
  background:
    radial-gradient(circle at center, #14000b 0 9%, #f9f2f6 9.5% 11.5%, #56545c 12% 16%, #dedfe3 16.5% 20%, transparent 20.5%),
    repeating-radial-gradient(circle at center, rgba(255,255,255,.22) 0 1px, rgba(130,127,138,.13) 2px 4px, transparent 5px 8px),
    conic-gradient(from 20deg, #f7f8fb, #bfc3cb, #fff, #d6d9df, #a9adb7, #f7f8fb);
  box-shadow:
    inset -18px -12px 34px rgba(21, 9, 18, .20),
    inset 14px 12px 28px rgba(255, 255, 255, .60),
    0 24px 70px rgba(54, 0, 30, .26);
}

.disc-graphic::before,
.release-card__disc::before,
.release-page__disc::before {
  content: "";
  position: absolute;
  inset: 8%;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, .42);
  background: conic-gradient(from 180deg, rgba(255, 46, 154, .16), transparent 25%, rgba(255, 46, 154, .09), transparent 60%, rgba(255, 255, 255, .22));
  mix-blend-mode: screen;
}

.disc-graphic::after,
.release-card__disc::after,
.release-page__disc::after {
  content: "";
  position: absolute;
  inset: 43%;
  border-radius: 50%;
  background: #0f0710;
  box-shadow: 0 0 0 .42rem rgba(255,255,255,.40), 0 0 0 .75rem rgba(55,55,65,.36);
}

.breadcrumbs {
  color: var(--muted);
  font-size: .92rem;
}

.breadcrumbs__list {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem .55rem;
  align-items: center;
  padding: 0;
  margin: 0;
  list-style: none;
}

.breadcrumbs__item { display: inline-flex; align-items: center; gap: .55rem; }
.breadcrumbs__item:not(:last-child)::after { content: "/"; color: rgba(122, 91, 112, .55); }
.breadcrumbs a { color: var(--pink-700); font-weight: 750; }

.section-heading {
  display: grid;
  gap: .85rem;
  margin-bottom: clamp(1.5rem, 4vw, 2.8rem);
}

.section-heading--row {
  align-items: end;
}

.section-heading__title {
  margin-bottom: 0;
  font-size: clamp(2rem, 5vw, 4.8rem);
  font-weight: 930;
}

.section-heading__lead {
  max-width: 720px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(1rem, 1.7vw, 1.15rem);
  line-height: 1.7;
}

.section-shell--deep .section-heading__lead { color: rgba(255, 255, 255, .72); }

.filter-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .65rem;
  margin-bottom: clamp(1.4rem, 4vw, 2.4rem);
}

.filter-button {
  flex: 0 0 auto;
  min-height: 2.65rem;
  padding: .65rem 1rem;
  border-radius: var(--radius-full);
  color: var(--pink-700);
  background: rgba(255, 255, 255, .68);
  border: 1px solid rgba(178, 0, 102, .14);
  font-weight: 800;
  box-shadow: 0 10px 30px rgba(155, 7, 87, .08);
  transition: transform .2s ease, background-color .2s ease, color .2s ease;
}

.filter-button:hover,
.filter-button[aria-pressed="true"] {
  color: #fff;
  background: var(--pink-650);
  transform: translateY(-1px);
}

.release-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 255px), 1fr));
  gap: clamp(1rem, 2vw, 1.6rem);
}

.release-grid--featured {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 285px), 1fr));
}

.release-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  min-height: 100%;
  padding: clamp(1rem, 2vw, 1.25rem);
  border: 1px solid var(--card-border);
  border-radius: var(--radius-xl);
  background: var(--card-bg);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(14px) saturate(1.12);
  isolation: isolate;
  transition: transform .28s var(--ease-out), box-shadow .28s ease, border-color .28s ease;
}

.release-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  border-radius: inherit;
  background: var(--card-accent-bg);
  opacity: .75;
  transition: opacity .28s ease;
}

.release-card:hover {
  transform: translateY(-7px);
  border-color: rgba(255, 46, 154, .26);
  box-shadow: var(--shadow-card);
}

.release-card:hover::before { opacity: 1; }

.release-card[hidden] { display: none; }

.release-card--featured {
  overflow: hidden;
  background: var(--card-featured-bg);
}

.release-card__media {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 1;
  border-radius: calc(var(--radius-xl) - .45rem);
  isolation: isolate;
}

.release-card__cover,
.cover-art {
  position: absolute;
  inset: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: inherit;
  box-shadow: 0 18px 44px rgba(64, 0, 35, .24);
  transform: translateZ(0);
  transition: transform .32s var(--ease-out), filter .32s ease;
}

.release-card__cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.release-card:hover .release-card__cover,
.release-card:hover .cover-art {
  transform: translateX(-4%) rotate(-1.8deg) scale(.985);
  filter: saturate(1.08) contrast(1.04);
}

.release-card__disc {
  position: absolute;
  inset: 7% -2% 7% auto;
  z-index: 1;
  width: 86%;
  opacity: .02;
  transform: translateX(-15%) rotate(-8deg) scale(.94);
  transition: opacity .34s ease, transform .38s var(--ease-out);
}

.release-card:hover .release-card__disc,
.release-card:focus-within .release-card__disc {
  opacity: 1;
  transform: translateX(23%) rotate(16deg) scale(.98);
}

.release-card__body {
  position: relative;
  z-index: 4;
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: .8rem;
}

.release-card__topline {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  align-items: center;
  color: var(--pink-700);
  font-size: .78rem;
  font-weight: 850;
  letter-spacing: .07em;
  text-transform: uppercase;
}

.release-card__title {
  margin: 0;
  font-size: clamp(1.28rem, 2vw, 1.65rem);
  font-weight: 900;
  letter-spacing: -.04em;
  line-height: 1.05;
}

.release-card__title a { transition: color .2s ease; }
.release-card__title a:hover { color: var(--pink-650); }

.release-card__date {
  color: var(--muted);
  font-weight: 780;
}

.release-card__desc {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.62;
  font-size: .96rem;
}

.release-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: auto;
}

.platform-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.35rem;
  padding: .52rem .75rem;
  border: 1px solid var(--control-border);
  border-radius: var(--radius-full);
  background: var(--control-bg);
  color: var(--pink-700);
  font-size: .86rem;
  font-weight: 820;
  transition: transform .18s ease, background-color .18s ease, color .18s ease;
}

.platform-link:hover {
  transform: translateY(-2px);
  background: var(--pink-600);
  color: #fff;
}

.cover-art {
  display: grid;
  place-items: end start;
  padding: 1.1rem;
  color: #fff;
  background:
    radial-gradient(circle at 22% 18%, rgba(255,255,255,.30), transparent 22%),
    linear-gradient(135deg, var(--pink-900), var(--pink-600) 52%, var(--pink-300));
}

.cover-art span {
  max-width: 85%;
  font-size: clamp(1.8rem, 8vw, 4rem);
  font-weight: 930;
  line-height: .92;
  letter-spacing: -.08em;
  text-shadow: 0 10px 30px rgba(0,0,0,.28);
}

.cover-art--deep {
  background:
    radial-gradient(circle at 78% 12%, rgba(255,255,255,.24), transparent 18%),
    linear-gradient(145deg, #16000c, #5c0030 52%, #ff2e9a);
}

.cover-art--soft {
  color: var(--pink-900);
  background:
    radial-gradient(circle at 80% 24%, rgba(255, 46, 154, .30), transparent 24%),
    linear-gradient(145deg, #fff, var(--pink-100), var(--pink-300));
}

.feed-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 270px), 1fr));
  gap: clamp(1rem, 2vw, 1.4rem);
}

.feed-card {
  position: relative;
  min-height: 100%;
  padding: clamp(1.1rem, 2vw, 1.45rem);
  border: 1px solid rgba(255, 255, 255, .24);
  border-radius: var(--radius-xl);
  background: rgba(255, 255, 255, .10);
  box-shadow: 0 24px 70px rgba(24, 0, 14, .18);
  backdrop-filter: blur(16px);
}

.feed-card__source {
  display: inline-flex;
  margin-bottom: 1rem;
  padding: .36rem .7rem;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,.16);
  color: #fff;
  font-size: .78rem;
  font-weight: 850;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.feed-card h3 {
  margin-bottom: .7rem;
  font-size: clamp(1.3rem, 2vw, 1.8rem);
  font-weight: 900;
}

.feed-card p {
  margin-bottom: 1rem;
  color: rgba(255, 255, 255, .76);
  line-height: 1.7;
}

.feed-card time { color: rgba(255, 255, 255, .62); font-weight: 760; }

.cta-panel {
  display: grid;
  gap: 1.5rem;
  align-items: center;
  padding: clamp(1.5rem, 4vw, 3rem);
  border: 1px solid var(--card-border);
  border-radius: var(--radius-xl);
  background: var(--cta-bg);
  box-shadow: var(--shadow-card);
}

.cta-panel h2 {
  margin-bottom: .75rem;
  font-size: clamp(2rem, 5vw, 4rem);
  font-weight: 930;
}

.cta-panel p {
  max-width: 720px;
  margin-bottom: 0;
  color: var(--ink-soft);
  line-height: 1.72;
}

.site-footer {
  position: relative;
  color: rgba(255,255,255,.82);
  background:
    radial-gradient(circle at 15% 0%, rgba(255, 46, 154, .28), transparent 28rem),
    linear-gradient(135deg, var(--pink-950), #120008 68%, var(--pink-900));
  overflow: clip;
}

.footer__inner {
  display: grid;
  gap: 2rem;
  padding-block: clamp(2.8rem, 7vw, 5.5rem);
}

.footer__brand {
  display: grid;
  gap: 1rem;
  max-width: 530px;
}

.footer__brand img { width: 12rem; filter: drop-shadow(0 12px 26px rgba(255, 46, 154, .20)); }
.footer__brand p { margin: 0; line-height: 1.7; color: rgba(255,255,255,.72); }

.footer__columns {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 1.6rem;
}

.footer-block h2,
.footer-block h3 {
  margin-bottom: .9rem;
  font-size: .85rem;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: rgba(255, 192, 221, .95);
}

.footer-list {
  display: grid;
  gap: .65rem;
  padding: 0;
  margin: 0;
  list-style: none;
}

.footer-list a { color: rgba(255,255,255,.75); transition: color .18s ease; }
.footer-list a:hover { color: #fff; }

.footer__bottom {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.3rem 0;
  border-top: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.58);
  font-size: .92rem;
}

.release-page-grid {
  display: grid;
  align-items: center;
  gap: clamp(2rem, 6vw, 5rem);
}

.release-page-visual {
  position: relative;
  isolation: isolate;
  width: min(100%, 560px);
  justify-self: center;
}

.release-page__disc {
  position: absolute;
  z-index: 0;
  top: 7%;
  right: -12%;
  width: 76%;
  aspect-ratio: 1;
  animation: disc-spin 19s linear infinite;
}

.release-page__cover {
  position: relative;
  z-index: 2;
  width: 84%;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-deep), var(--glow);
}

.release-page__cover img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
}

.meta-list {
  display: grid;
  gap: .8rem;
  margin: 1.3rem 0 0;
}

.meta-row {
  display: grid;
  grid-template-columns: minmax(110px, .7fr) 1fr;
  gap: 1rem;
  padding: .95rem 1rem;
  border: 1px solid rgba(178, 0, 102, .12);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, .62);
}

.meta-row dt {
  color: var(--muted);
  font-weight: 760;
}

.meta-row dd {
  margin: 0;
  font-weight: 850;
}

.content-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1.4rem, 3vw, 2rem);
}

.prose-card,
.info-card {
  padding: clamp(1.2rem, 3vw, 2rem);
  border: 1px solid var(--card-border);
  border-radius: var(--radius-xl);
  background: var(--surface-card);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(14px);
}

.prose-card h2,
.info-card h2,
.prose-card h3,
.info-card h3 {
  margin-bottom: .85rem;
  font-size: clamp(1.55rem, 3vw, 2.35rem);
  font-weight: 930;
}

.prose-card p,
.info-card p,
.prose-card li {
  color: var(--ink-soft);
  line-height: 1.78;
}

.prose-card p:last-child,
.info-card p:last-child { margin-bottom: 0; }

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

.track-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: .8rem;
  align-items: center;
  padding: .9rem 1rem;
  border-radius: var(--radius-md);
  background: var(--track-item-bg);
}

.track-item__num,
.track-item__duration {
  color: var(--pink-700);
  font-weight: 850;
}

.lyrics-note {
  display: grid;
  gap: .35rem;
  margin-top: 1rem;
  padding: 1rem;
  border: 1px solid var(--card-border);
  border-radius: var(--radius-md);
  color: var(--muted);
  background: var(--surface-soft);
}

.lyrics-note strong {
  color: var(--pink-700);
}

.lyrics-note span {
  line-height: 1.65;
}

.bio-grid {
  display: grid;
  align-items: center;
  gap: clamp(2rem, 6vw, 5rem);
}

.bio-photo {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-deep);
}

.bio-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(56, 0, 27, .38));
}

.bio-photo img { width: 100%; object-fit: cover; }

.timeline {
  display: grid;
  gap: 1rem;
  margin-top: 1.2rem;
}

.timeline-item {
  position: relative;
  display: grid;
  gap: .25rem;
  padding: 1rem 1rem 1rem 3rem;
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.66);
  border: 1px solid rgba(178, 0, 102, .12);
}

.timeline-item::before {
  content: "";
  position: absolute;
  left: 1.05rem;
  top: 1.15rem;
  width: .7rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--pink-500);
  box-shadow: 0 0 0 .5rem rgba(255, 46, 154, .12);
}

.timeline-item strong { color: var(--pink-700); }
.timeline-item span { color: var(--ink-soft); line-height: 1.6; }


.blog-layout {
  display: grid;
  gap: clamp(1.2rem, 3vw, 2rem);
}

.blog-main {
  display: grid;
  gap: clamp(1rem, 2vw, 1.4rem);
}

.blog-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  align-items: center;
}

.blog-pill,
.tag-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.35rem;
  padding: .55rem .82rem;
  border: 1px solid var(--control-border);
  border-radius: var(--radius-full);
  background: var(--control-bg);
  color: var(--pink-700);
  font-size: .86rem;
  font-weight: 850;
  transition: transform .18s ease, background-color .18s ease, color .18s ease;
}

.blog-pill:hover,
.tag-link:hover {
  transform: translateY(-2px);
  background: var(--pink-600);
  color: #fff;
}

.blog-featured,
.blog-card,
.sidebar-card {
  border: 1px solid var(--card-border);
  border-radius: var(--radius-xl);
  background: var(--surface-card);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(14px);
}

.blog-featured {
  display: grid;
  overflow: hidden;
}

.blog-featured__media {
  position: relative;
  min-height: 260px;
  background: var(--pink-100);
}

.blog-featured__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.blog-featured__content,
.blog-card,
.sidebar-card {
  display: grid;
  gap: .9rem;
  padding: clamp(1.15rem, 3vw, 1.8rem);
}

.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 270px), 1fr));
  gap: clamp(1rem, 2vw, 1.25rem);
}

.blog-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  color: var(--pink-700);
  font-size: .82rem;
  font-weight: 850;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.blog-featured h2,
.blog-card h2,
.sidebar-card h2 {
  margin: 0;
  font-size: clamp(1.4rem, 3vw, 2.35rem);
  font-weight: 930;
  letter-spacing: -.045em;
  line-height: 1.04;
}

.blog-card p,
.blog-featured p,
.sidebar-card p {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.72;
}

.blog-sidebar {
  display: grid;
  gap: 1rem;
  align-content: start;
}

.sidebar-card--accent {
  background: var(--accent-card-bg);
}

.tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.archive-list {
  display: grid;
  gap: .7rem;
  padding: 0;
  margin: 0;
  list-style: none;
}

.archive-list li {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: .85rem 0;
  border-bottom: 1px solid rgba(178, 0, 102, .12);
}

.archive-list li:last-child { border-bottom: 0; }
.archive-list a { color: var(--pink-700); font-weight: 850; }
.archive-list span { color: var(--muted); }

.reveal {
  opacity: 0;
  transform: translateY(26px);
  transition: opacity .55s ease, transform .65s var(--ease-out);
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@keyframes disc-spin {
  to { transform: rotate(360deg); }
}

@media (min-width: 720px) {
  .hero__grid,
  .release-page-grid,
  .bio-grid {
    grid-template-columns: minmax(0, 1.03fr) minmax(300px, .82fr);
  }

  .hero-visual,
  .release-page-visual { justify-self: end; }

  .section-heading--row {
    grid-template-columns: 1fr auto;
  }

  .cta-panel {
    grid-template-columns: 1fr auto;
  }

  .content-grid {
    grid-template-columns: minmax(0, 1fr) minmax(280px, 380px);
  }

  .blog-layout {
    grid-template-columns: minmax(0, 1fr) minmax(280px, 390px);
    align-items: start;
  }

  .blog-featured {
    grid-template-columns: minmax(240px, .72fr) minmax(0, 1fr);
  }
}

@media (min-width: 920px) {
  .primary-nav {
    position: static;
    display: flex;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    transform: none;
    opacity: 1;
    visibility: visible;
  }

  .nav-list {
    display: flex;
    align-items: center;
    gap: .15rem;
  }

  .nav-link { min-height: 2.65rem; padding: .55rem .82rem; }

  .nav-toggle { display: none; }

  .social-mini { display: flex; }
}

@media (min-width: 1180px) {
  .release-grid--featured .release-card--featured {
    grid-column: span 2;
    display: grid;
    grid-template-columns: minmax(280px, 410px) minmax(0, 1fr);
    align-items: center;
    gap: clamp(1.4rem, 3vw, 3.3rem);
    min-height: 0;
    padding: clamp(1.05rem, 1.6vw, 1.45rem);
  }

  .release-card--featured .release-card__media {
    width: min(100%, 390px);
    aspect-ratio: 1;
    min-height: auto;
    justify-self: center;
  }

  .release-card--featured .release-card__cover {
    inset: 0 auto 0 0;
    width: 78%;
    height: 100%;
  }

  .release-card--featured .release-card__disc {
    inset: 9% 0 9% auto;
    width: 74%;
    opacity: .74;
    transform: translateX(0) rotate(10deg) scale(.97);
  }

  .release-card--featured:hover .release-card__disc,
  .release-card--featured:focus-within .release-card__disc {
    opacity: .98;
    transform: translateX(4%) rotate(22deg) scale(1);
  }

  .release-card--featured:hover .release-card__cover {
    transform: translateX(-2.5%) rotate(-1deg) scale(.99);
  }

  .release-card--featured .release-card__body {
    align-self: center;
    max-width: 560px;
    padding: clamp(.5rem, 1.4vw, 1.15rem);
    border-radius: var(--radius-lg);
    background: linear-gradient(90deg, rgba(255, 255, 255, .78), rgba(255, 244, 250, .34));
    backdrop-filter: blur(8px) saturate(1.05);
  }

  .release-card--featured .release-card__actions {
    margin-top: .35rem;
  }
}

@media (max-width: 719px) {
  :root { --header-height: 74px; }

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

  .release-showcase__disc { right: -2%; opacity: .85; }

  .release-card__disc {
    opacity: .9;
    transform: translateX(13%) rotate(10deg) scale(.96);
  }

  .release-card:hover .release-card__disc,
  .release-card:focus-within .release-card__disc {
    transform: translateX(16%) rotate(18deg) scale(.98);
  }

  .meta-row { grid-template-columns: 1fr; gap: .3rem; }

  .track-item { grid-template-columns: auto 1fr; }
  .track-item__duration { grid-column: 2; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    scroll-behavior: auto !important;
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
  }

  .reveal { opacity: 1; transform: none; }
}


.blog-hero__grid,
.article-hero__grid {
  display: grid;
  align-items: center;
  gap: clamp(2rem, 6vw, 5rem);
}

.blog-featured-card,
.blog-card,
.blog-sidebar__block {
  border: 1px solid var(--card-border);
  border-radius: var(--radius-xl);
  background: var(--surface-card);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(14px);
}

.blog-featured-card {
  overflow: hidden;
  justify-self: center;
  width: min(100%, 560px);
}

.blog-featured-card__media,
.blog-card__media,
.article-hero__cover {
  position: relative;
  overflow: hidden;
  display: block;
}

.blog-featured-card__media img,
.blog-card__media img,
.article-hero__cover img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  transition: transform .42s var(--ease-out), filter .42s ease;
}

.blog-featured-card:hover img,
.blog-card:hover img {
  transform: scale(1.045);
  filter: saturate(1.06) contrast(1.03);
}

.blog-featured-card__body,
.blog-card__body {
  display: grid;
  gap: .85rem;
  padding: clamp(1.1rem, 3vw, 1.65rem);
}

.blog-featured-card h2,
.blog-card h3 {
  margin: 0;
  font-weight: 930;
  letter-spacing: -.045em;
  line-height: 1.04;
}

.blog-featured-card h2 { font-size: clamp(1.7rem, 4vw, 3rem); }
.blog-card h3 { font-size: clamp(1.35rem, 3vw, 1.9rem); }

.blog-featured-card a:hover,
.blog-card a:hover { color: var(--pink-650); }

.blog-featured-card p,
.blog-card p {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.7;
}

.blog-card__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .5rem;
  color: var(--pink-700);
  font-size: .78rem;
  font-weight: 850;
  letter-spacing: .075em;
  text-transform: uppercase;
}

.blog-card__meta span {
  display: inline-flex;
  padding: .34rem .62rem;
  border-radius: var(--radius-full);
  background: var(--pill-bg);
}

.blog-layout,
.article-layout {
  display: grid;
  gap: clamp(1.2rem, 3vw, 2rem);
  align-items: start;
}

.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 270px), 1fr));
  gap: clamp(1rem, 2vw, 1.45rem);
}

.blog-card {
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  transition: transform .28s var(--ease-out), box-shadow .28s ease, border-color .28s ease;
}

.blog-card:hover {
  transform: translateY(-6px);
  border-color: rgba(255, 46, 154, .24);
  box-shadow: var(--shadow-card);
}

.blog-card[hidden] { display: none; }

.blog-card__media--text {
  display: grid;
  min-height: 260px;
  place-items: end start;
  padding: 1.4rem;
  color: #fff;
  background:
    radial-gradient(circle at 80% 15%, rgba(255,255,255,.22), transparent 18rem),
    linear-gradient(145deg, var(--pink-950), var(--pink-700) 58%, var(--pink-400));
}

.blog-card__media--text span {
  max-width: 80%;
  font-size: clamp(2.2rem, 7vw, 4rem);
  font-weight: 930;
  letter-spacing: -.08em;
  line-height: .9;
}

.blog-card__footer {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  margin-top: auto;
  padding-top: .55rem;
  color: var(--muted);
  font-weight: 800;
}

.blog-card__footer a { color: var(--pink-700); }

.blog-sidebar {
  display: grid;
  gap: 1rem;
}

.blog-sidebar__block {
  display: grid;
  gap: 1rem;
  padding: clamp(1.1rem, 3vw, 1.55rem);
}

.blog-sidebar__block h2 {
  margin: 0;
  font-size: 1.05rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--pink-700);
}

.blog-sidebar__block p {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.7;
}

.blog-sidebar__block--accent {
  background: linear-gradient(135deg, rgba(255, 227, 241, .88), rgba(255,255,255,.78));
}

.tag-list,
.compact-list {
  display: grid;
  gap: .7rem;
  padding: 0;
  margin: 0;
  list-style: none;
}

.tag-list a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 2.55rem;
  padding: .6rem .8rem;
  border: 1px solid rgba(178, 0, 102, .12);
  border-radius: var(--radius-full);
  background: rgba(255,255,255,.60);
  color: var(--pink-700);
  font-weight: 820;
}

.compact-list li {
  display: grid;
  gap: .15rem;
  padding-bottom: .75rem;
  border-bottom: 1px solid rgba(178, 0, 102, .12);
}

.compact-list a { color: var(--ink); font-weight: 880; }
.compact-list span { color: var(--muted); font-size: .88rem; }

.article-hero__cover {
  width: min(100%, 520px);
  justify-self: center;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-deep), var(--glow);
}

.article-content { font-size: 1.04rem; }
.article-content .article-lead {
  color: var(--ink);
  font-size: clamp(1.08rem, 2vw, 1.28rem);
  font-weight: 700;
}

.article-callout {
  display: grid;
  gap: .75rem;
  margin-top: 1.4rem;
  padding: clamp(1.1rem, 3vw, 1.55rem);
  border: 1px solid rgba(255, 46, 154, .18);
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, rgba(255,227,241,.80), rgba(255,255,255,.72));
}
.article-callout strong { color: var(--pink-700); font-size: 1.15rem; }

.track-note {
  margin-top: 1rem;
  padding: 1rem;
  border: 1px solid rgba(178, 0, 102, .16);
  border-radius: var(--radius-md);
  color: var(--ink-soft);
  background: rgba(255, 255, 255, .58);
  line-height: 1.7;
}

@media (min-width: 720px) {
  .blog-hero__grid,
  .article-hero__grid { grid-template-columns: minmax(0, 1.03fr) minmax(300px, .82fr); }
  .blog-featured-card,
  .article-hero__cover { justify-self: end; }
}

@media (min-width: 1040px) {
  .blog-layout,
  .article-layout { grid-template-columns: minmax(0, 1fr) minmax(290px, 360px); }
  .blog-sidebar { position: sticky; top: calc(var(--header-height) + 1.2rem); }
}

.release-grid__message {
  grid-column: 1 / -1;
  margin: 0;
  padding: 1.1rem 1.25rem;
  border: 1px solid rgba(178, 0, 102, .14);
  border-radius: var(--radius-lg);
  color: var(--muted);
  background: rgba(255, 255, 255, .62);
}

[data-release-filters]:empty::before {
  content: "Загружаем релизы…";
  display: inline-flex;
  min-height: 2.65rem;
  align-items: center;
  padding: .65rem 1rem;
  border: 1px solid rgba(178, 0, 102, .12);
  border-radius: var(--radius-full);
  color: var(--muted);
  background: rgba(255, 255, 255, .58);
}

.release-card__body {
  position: relative;
  z-index: 3;
}

.release-card--featured {
  overflow: hidden;
}

.release-card--featured .release-card__media {
  z-index: 2;
}

/* JSON + PHP rebuild refinements */
.breadcrumbs--compact {
  margin-top: clamp(1rem, 2vw, 1.75rem);
  margin-bottom: clamp(1rem, 2vw, 1.75rem);
}

.breadcrumbs--compact .breadcrumbs__list {
  display: inline-flex;
  flex-wrap: wrap;
  gap: .45rem;
  padding: .55rem .8rem;
  border: 1px solid rgba(241, 15, 136, .14);
  border-radius: 999px;
  background: rgba(255, 255, 255, .72);
  box-shadow: 0 12px 30px rgba(58, 8, 38, .06);
}

.breadcrumbs--compact .breadcrumbs__item {
  font-size: .82rem;
}

.hero--compact {
  padding-block: clamp(4.5rem, 10vw, 7rem) clamp(2.5rem, 6vw, 4.5rem);
}

.release-card[hidden] {
  display: none !important;
}

.footer__bottom p:last-child {
  max-width: 58rem;
}

/* Telegram blog import */
.article-cover {
  margin: clamp(1rem, 3vw, 1.6rem) 0;
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(178, 0, 102, .13);
  background: rgba(255, 255, 255, .65);
  box-shadow: var(--shadow-soft);
}

.article-cover img {
  display: block;
  width: 100%;
  max-height: 680px;
  object-fit: cover;
}

.article-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 180px), 1fr));
  gap: .75rem;
  margin-top: clamp(1.2rem, 3vw, 1.8rem);
}

.article-gallery__item {
  display: block;
  overflow: hidden;
  border-radius: var(--radius-md);
  border: 1px solid rgba(178, 0, 102, .13);
  background: rgba(255,255,255,.7);
}

.article-gallery__item img {
  display: block;
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  transition: transform .35s var(--ease-out);
}

.article-gallery__item:hover img { transform: scale(1.04); }

.article-links {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  margin-top: 1.2rem;
}

.article-source {
  margin-top: 1.4rem !important;
  font-size: .84rem;
  color: var(--muted) !important;
}

/* Airy archive/blog/release detail refinements */
.release-grid--catalog,
.release-grid--airy {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 330px), 1fr));
  gap: clamp(1.4rem, 2.8vw, 2.4rem);
  align-items: stretch;
}

.release-grid--catalog .release-card {
  padding: clamp(1.15rem, 2.4vw, 1.55rem);
  min-height: 100%;
}

@media (min-width: 1040px) {
  .release-grid--catalog .release-card--featured {
    grid-column: span 2;
    display: grid;
    grid-template-columns: minmax(300px, .92fr) minmax(280px, 1fr);
    align-items: center;
    gap: clamp(1.4rem, 3vw, 2.8rem);
    min-height: 330px;
    padding: clamp(1.4rem, 3vw, 2.2rem);
  }

  .release-grid--catalog .release-card--featured .release-card__media {
    width: min(100%, 430px);
    aspect-ratio: 1;
  }

  .release-grid--catalog .release-card--featured .release-card__body {
    max-width: 560px;
    background: transparent;
    backdrop-filter: none;
  }
}

.blog-index {
  padding-top: clamp(2.4rem, 6vw, 5rem);
}

.blog-layout--magazine {
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(1.6rem, 3vw, 2.4rem);
}

.blog-layout--magazine .blog-main {
  display: grid;
  gap: clamp(1.4rem, 3vw, 2rem);
}

.blog-layout--magazine .blog-toolbar {
  margin-bottom: clamp(1.3rem, 3vw, 2rem);
}

.blog-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
}

.blog-pill {
  border: 1px solid rgba(178, 0, 102, .14);
  border-radius: var(--radius-full);
  padding: .78rem 1.2rem;
  background: rgba(255, 255, 255, .70);
  color: var(--ink-soft);
  font-weight: 850;
  box-shadow: 0 12px 34px rgba(155, 7, 87, .08);
  transition: transform .2s ease, background-color .2s ease, color .2s ease, border-color .2s ease;
}

.blog-pill:hover,
.blog-pill[aria-pressed="true"] {
  transform: translateY(-1px);
  border-color: rgba(241, 15, 136, .34);
  background: var(--pink-650);
  color: #fff;
}

.blog-featured {
  overflow: hidden;
  border: 1px solid rgba(178, 0, 102, .13);
  border-radius: var(--radius-xl);
  background: linear-gradient(135deg, rgba(255,255,255,.86), rgba(255,244,250,.62));
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(14px) saturate(1.08);
}

.blog-featured__media {
  display: block;
  min-height: 100%;
  overflow: hidden;
}

.blog-featured__media img {
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
}

.blog-featured__content {
  display: grid;
  align-content: center;
  gap: clamp(.9rem, 2vw, 1.3rem);
  padding: clamp(1.5rem, 4vw, 3.2rem);
}

.blog-featured__content h2 {
  margin: 0;
  font-size: clamp(2.1rem, 4.4vw, 4.6rem);
  font-weight: 930;
  letter-spacing: -.065em;
  line-height: .98;
}

.blog-featured__content p:not(.eyebrow) {
  max-width: 620px;
  color: var(--ink-soft);
  line-height: 1.75;
}

.blog-grid--magazine {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr));
  gap: clamp(1.1rem, 2.4vw, 1.8rem);
}

.blog-grid--magazine .blog-card {
  border-radius: var(--radius-xl);
}

.blog-grid--magazine .blog-card__media img {
  aspect-ratio: 16 / 10;
}

.blog-grid--magazine .blog-card__media--text {
  min-height: 235px;
}

.blog-grid--magazine .blog-card__body {
  padding: clamp(1.1rem, 2.6vw, 1.55rem);
}

.blog-grid--magazine .blog-card p:not(.blog-card__meta) {
  min-height: 4.2em;
}

.tag-list button,
.tag-list a,
.archive-list a {
  font: inherit;
}

.tag-list button,
.tag-list a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  min-height: 2.7rem;
  padding: .65rem .9rem;
  border: 1px solid rgba(178, 0, 102, .12);
  border-radius: var(--radius-full);
  background: rgba(255,255,255,.64);
  color: var(--pink-700);
  font-weight: 820;
  cursor: pointer;
  transition: transform .18s ease, background-color .18s ease, color .18s ease;
}

.tag-list button:hover,
.tag-list button[aria-pressed="true"],
.tag-list a:hover {
  transform: translateY(-1px);
  background: var(--pink-650);
  color: #fff;
}

.latest-release-mini {
  display: grid;
  grid-template-columns: 72px 1fr;
  align-items: center;
  gap: .85rem;
}

.latest-release-mini img {
  width: 72px;
  height: 72px;
  border-radius: var(--radius-md);
  object-fit: cover;
  box-shadow: 0 12px 28px rgba(91, 0, 50, .18);
}

.latest-release-mini strong,
.latest-release-mini span {
  display: block;
}

.latest-release-mini strong {
  color: var(--ink);
  font-size: 1.05rem;
  font-weight: 900;
}

.latest-release-mini span {
  margin-top: .2rem;
  color: var(--muted);
  font-size: .92rem;
  line-height: 1.45;
}

.release-detail .breadcrumbs--compact {
  margin-top: clamp(1.2rem, 3vw, 2rem);
  margin-bottom: 0;
}

.release-detail-hero {
  padding-top: clamp(2rem, 4vw, 3.5rem);
}

.release-detail-hero__grid {
  display: grid;
  align-items: center;
  gap: clamp(2rem, 6vw, 5rem);
}

.release-page-copy {
  display: grid;
  gap: .95rem;
  max-width: 680px;
}

.release-page-title {
  margin: 0;
  font-size: clamp(3.3rem, 8vw, 7.8rem);
  font-weight: 940;
  letter-spacing: -.075em;
  line-height: .86;
}

.release-page-date {
  margin: 0;
  color: var(--muted);
  font-weight: 850;
  font-size: clamp(1rem, 1.8vw, 1.2rem);
}

.release-page-lead {
  max-width: 600px;
  margin: 0;
  color: var(--ink-soft);
  font-size: clamp(1.05rem, 2vw, 1.25rem);
  line-height: 1.72;
}

.release-hero-actions,
.release-platform-buttons,
.release-story-links,
.button-row {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  align-items: center;
}

.release-media-section {
  padding-top: clamp(1.2rem, 3vw, 2.4rem);
}

.release-media-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1rem, 2.6vw, 1.8rem);
}

.release-media-card,
.release-info-card {
  overflow: hidden;
  border: 1px solid var(--card-border);
  border-radius: var(--radius-xl);
  background: var(--media-card-bg);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(14px) saturate(1.08);
}

.release-media-card {
  display: grid;
  gap: 1rem;
  min-height: 255px;
  padding: clamp(1rem, 2.5vw, 1.45rem);
}

.release-media-card--player,
.release-media-card--video {
  padding: clamp(.85rem, 2vw, 1.1rem);
}

.release-media-card__heading {
  display: grid;
  gap: .35rem;
  padding-inline: .35rem;
}

.release-media-card__heading h2 {
  margin: 0;
  font-size: clamp(1.35rem, 2.6vw, 2.1rem);
  font-weight: 930;
  letter-spacing: -.045em;
}

.release-media-card__heading--inline {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

.release-embed {
  display: block;
  width: 100%;
  border: 0;
  border-radius: calc(var(--radius-xl) - .55rem);
  background: var(--embed-bg);
  box-shadow: inset 0 0 0 1px var(--embed-border);
}

.release-embed--yandex {
  min-height: 214px;
}

.release-embed--youtube {
  aspect-ratio: 16 / 9;
  min-height: 255px;
}

.release-media-card--fallback p,
.release-media-card--story p,
.release-info-card p,
.release-muted {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.72;
}

.release-story-fallback {
  display: grid;
  grid-template-columns: 96px 1fr;
  align-items: start;
  gap: 1rem;
}

.release-story-fallback img {
  width: 96px;
  height: 96px;
  border-radius: var(--radius-md);
  object-fit: cover;
  box-shadow: 0 14px 34px rgba(91, 0, 50, .18);
}

.release-info-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1rem, 2.4vw, 1.5rem);
}

.release-info-card {
  display: grid;
  align-content: start;
  gap: .95rem;
  padding: clamp(1.1rem, 2.8vw, 1.75rem);
}

.release-info-card h2 {
  margin: 0;
  font-size: clamp(1.55rem, 3vw, 2.35rem);
  font-weight: 930;
  letter-spacing: -.045em;
}

.release-facts {
  display: grid;
  gap: .65rem;
  margin: .4rem 0 0;
}

.release-facts div {
  display: grid;
  grid-template-columns: minmax(84px, .45fr) 1fr;
  gap: .8rem;
  padding-top: .65rem;
  border-top: 1px solid var(--card-border);
}

.release-facts dt {
  color: var(--muted);
  font-weight: 780;
}

.release-facts dd {
  margin: 0;
  color: var(--pink-700);
  font-weight: 850;
}

.track-list--compact {
  margin-top: 0;
}

.release-platform-list {
  display: grid;
  gap: .45rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.release-platform-list a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 2.75rem;
  padding: .72rem .85rem;
  border: 1px solid var(--control-border);
  border-radius: var(--radius-md);
  background: var(--control-bg);
  color: var(--ink-soft);
  font-weight: 820;
  transition: transform .18s ease, background-color .18s ease, color .18s ease;
}

.release-platform-list a:hover {
  transform: translateX(4px);
  background: var(--pink-650);
  color: #fff;
}

.platform-link--accent {
  background: var(--pink-650);
  color: #fff;
  border-color: var(--pink-650);
}

.release-platform-item--yandex { order: 10; }
.release-platform-item--vk { order: 20; }
.release-platform-item--zvuk { order: 30; }
.release-platform-item--mts { order: 40; }
.release-platform-item--spotify { order: 50; }
.release-platform-item--apple { order: 60; }
.release-platform-item--youtube { order: 70; }
.release-platform-item--telegram { order: 80; }
.release-platform-item--other { order: 90; }

.release-platform-item--yandex .platform-icon { background: linear-gradient(135deg, #ffcf33, #f10f88); }
.release-platform-item--vk .platform-icon { background: #4c75a3; }
.release-platform-item--zvuk .platform-icon { background: linear-gradient(135deg, #7b2cff, #f10f88); }
.release-platform-item--mts .platform-icon { background: #d5001c; }
.release-platform-item--spotify .platform-icon { background: #1db954; }
.release-platform-item--apple .platform-icon { background: #202024; }
.release-platform-item--youtube .platform-icon { background: #ff0000; }
.release-platform-item--telegram .platform-icon { background: #229ed9; }


@media (min-width: 640px) {
  .release-platform-list--icons {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .65rem;
  }

  .release-platform-list--icons .release-platform-item--youtube,
  .release-platform-list--icons .release-platform-item--telegram,
  .release-platform-list--icons .release-platform-item--other {
    grid-column: 1 / -1;
  }
}

@media (min-width: 760px) {
  .blog-featured {
    display: grid;
    grid-template-columns: minmax(300px, .78fr) minmax(0, 1fr);
  }

  .release-detail-hero__grid {
    grid-template-columns: minmax(320px, .82fr) minmax(0, 1fr);
  }

  .release-page-visual {
    justify-self: start;
  }

  .release-media-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .release-info-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1080px) {
  .blog-layout--magazine {
    grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  }

  .blog-sidebar {
    position: sticky;
    top: calc(var(--header-height) + 1.2rem);
  }

  .release-info-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .release-info-card--platforms {
    min-width: 0;
  }
}

@media (max-width: 759px) {
  .release-story-fallback {
    grid-template-columns: 1fr;
  }

  .release-story-fallback img {
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 10;
  }
}


/* 2026-06 layout pass: calmer hierarchy, fixed card bottoms, image modal */
.section-heading__title {
  font-size: clamp(2.25rem, 5.2vw, 5.2rem);
  line-height: .95;
}

.release-grid--catalog,
.release-grid--airy {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 340px), 1fr));
  align-items: stretch;
}

.release-grid--catalog .release-card--featured,
.release-grid--airy .release-card--featured {
  grid-column: auto;
  display: flex;
  grid-template-columns: none;
}

.release-card {
  height: 100%;
  padding-bottom: clamp(1.35rem, 2.5vw, 1.8rem);
}

.release-card__body {
  min-height: 0;
}

.release-card__title {
  font-size: clamp(1.18rem, 1.55vw, 1.48rem);
  line-height: 1.08;
}

.release-card__desc {
  flex: 1 0 auto;
  min-height: 4.8em;
  font-size: .93rem;
}

.release-card__actions,
.blog-card__footer,
.button-row {
  margin-top: auto;
  padding-top: .85rem;
}

.blog-featured__content h2 {
  font-size: clamp(2rem, 3.35vw, 3.65rem);
  line-height: 1.02;
  letter-spacing: -.058em;
}

.blog-grid--magazine {
  align-items: stretch;
}

.blog-grid--magazine .blog-card {
  height: 100%;
}

.blog-card__media {
  display: block;
  overflow: hidden;
  background: rgba(255,255,255,.62);
}

.blog-card__media img {
  width: 100%;
  aspect-ratio: 16 / 10;
  height: auto;
  object-fit: cover;
}

.blog-card__body {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: .9rem;
  padding-bottom: clamp(1.35rem, 2.6vw, 1.9rem);
}

.blog-card h3,
.blog-grid--magazine .blog-card h3 {
  margin: 0;
  font-size: clamp(1.22rem, 2.1vw, 1.72rem);
  line-height: 1.08;
  letter-spacing: -.045em;
}

.blog-grid--magazine .blog-card p:not(.blog-card__meta) {
  min-height: 5.2em;
  font-size: .94rem;
}

.release-page-title {
  font-size: clamp(3rem, 6vw, 5.8rem);
  line-height: .92;
  letter-spacing: -.068em;
}

.release-page-lead {
  font-size: clamp(1rem, 1.45vw, 1.15rem);
}

.release-media-card,
.release-info-card {
  padding-bottom: clamp(1.35rem, 2.8vw, 2rem);
}

.release-info-card h2,
.release-media-card__heading h2 {
  font-size: clamp(1.3rem, 2vw, 1.85rem);
}

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

  .release-info-card--lyrics {
    grid-column: span 1;
  }
}

@media (min-width: 1420px) {
  .release-info-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .release-info-card--lyrics {
    grid-column: span 2;
  }
}

.lyrics-block {
  display: grid;
  gap: 1.05rem;
}

.lyrics-block__section {
  display: grid;
  gap: .45rem;
  padding: .9rem 1rem;
  border: 1px solid rgba(178, 0, 102, .12);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, .58);
}

.lyrics-block__section h3 {
  margin: 0;
  color: var(--pink-700);
  font-size: .88rem;
  font-weight: 900;
  letter-spacing: .075em;
  text-transform: uppercase;
}

.lyrics-block__section p {
  margin: 0;
  white-space: normal;
}

.article-cover a,
.article-gallery__item {
  position: relative;
  cursor: zoom-in;
}

.article-cover a::after,
.article-gallery__item::after {
  content: "Увеличить";
  position: absolute;
  right: .9rem;
  bottom: .9rem;
  padding: .42rem .7rem;
  border-radius: var(--radius-full);
  color: #fff;
  background: rgba(37, 0, 18, .64);
  font-size: .78rem;
  font-weight: 850;
  opacity: 0;
  transform: translateY(.35rem);
  transition: opacity .2s ease, transform .2s ease;
  backdrop-filter: blur(10px);
}

.article-cover a:hover::after,
.article-gallery__item:hover::after {
  opacity: 1;
  transform: translateY(0);
}

body.modal-open {
  overflow: hidden;
}

.image-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: grid;
  place-items: center;
  padding: clamp(1rem, 4vw, 3rem);
  opacity: 0;
  transition: opacity .18s ease;
}

.image-modal.is-open {
  opacity: 1;
}

.image-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(37, 0, 18, .72);
  backdrop-filter: blur(16px) saturate(1.1);
}

.image-modal__figure {
  position: relative;
  z-index: 1;
  display: grid;
  gap: .85rem;
  width: min(100%, 1120px);
  max-height: min(88vh, 880px);
  margin: 0;
  padding: clamp(.8rem, 2vw, 1.15rem);
  border: 1px solid rgba(255, 255, 255, .22);
  border-radius: var(--radius-xl);
  background: linear-gradient(145deg, rgba(255,255,255,.92), rgba(255,227,241,.78));
  box-shadow: 0 38px 120px rgba(0, 0, 0, .36);
  transform: scale(.985) translateY(.6rem);
  transition: transform .22s var(--ease-out);
}

.image-modal.is-open .image-modal__figure {
  transform: scale(1) translateY(0);
}

.image-modal__img {
  width: 100%;
  max-height: calc(88vh - 6.5rem);
  object-fit: contain;
  border-radius: calc(var(--radius-xl) - .65rem);
  background: rgba(255,255,255,.55);
}

.image-modal__caption {
  color: var(--ink-soft);
  font-size: .94rem;
  font-weight: 750;
  text-align: center;
}

.image-modal__close {
  position: absolute;
  top: .8rem;
  right: .8rem;
  z-index: 2;
  width: 2.6rem;
  height: 2.6rem;
  border-radius: var(--radius-full);
  color: #fff;
  background: var(--pink-650);
  font-size: 1.6rem;
  line-height: 1;
  box-shadow: 0 12px 36px rgba(155, 7, 87, .25);
}

@media (max-width: 760px) {
  .blog-featured__content h2,
  .release-page-title,
  .section-heading__title {
    word-break: normal;
    overflow-wrap: anywhere;
  }
}

/* 2026-06-30 polish pass: release detail, one-row blog cards, footer, modal robustness */
.image-modal[hidden] {
  display: none !important;
}

.release-detail-hero {
  padding-top: clamp(1.8rem, 3.5vw, 3rem);
  padding-bottom: clamp(2rem, 4.2vw, 3.4rem);
}

.release-detail-hero__grid {
  gap: clamp(2.6rem, 7vw, 7rem);
}

.release-page-visual {
  width: min(100%, 480px);
}

.release-page-copy {
  gap: 1.1rem;
}

.release-page-title {
  font-size: clamp(3.1rem, 5.2vw, 5.65rem);
  line-height: .94;
  letter-spacing: -.065em;
}

.release-page-lead {
  max-width: 620px;
  font-size: clamp(1rem, 1.35vw, 1.16rem);
  line-height: 1.74;
}

.release-hero-actions {
  padding-top: .65rem;
}

.release-media-grid {
  align-items: start;
}

.release-media-card {
  min-height: 0;
}

.release-media-card--player,
.release-media-card--video,
.release-media-card--story,
.release-media-card--fallback {
  padding: clamp(1rem, 2vw, 1.35rem);
}

.release-media-card--youtube-fallback {
  background: var(--youtube-fallback-bg);
}

.release-info-grid {
  align-items: start;
}

.release-info-card {
  height: auto;
  min-height: 0;
}

.release-info-card--lyrics {
  max-width: none;
}

.lyrics-block {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
  align-items: start;
}

.lyrics-block__section p {
  white-space: pre-line;
}

@media (min-width: 1080px) {
  .release-info-grid {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }
  .release-info-card {
    grid-column: span 4;
  }
  .release-info-card--lyrics {
    grid-column: 1 / -1;
  }
  .release-grid--airy {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (min-width: 1420px) {
  .release-info-grid {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }
  .release-info-card--lyrics {
    grid-column: 1 / -1;
  }
}

.blog-page .section-heading {
  margin-bottom: clamp(2rem, 4vw, 3.5rem);
}

.blog-page .section-heading__title {
  max-width: 1180px;
  font-size: clamp(3.1rem, 5.3vw, 6rem);
  line-height: .92;
}

.blog-toolbar {
  margin-top: clamp(1.25rem, 2.6vw, 2rem);
  margin-bottom: clamp(1.4rem, 2.8vw, 2.2rem);
}

.blog-page .blog-layout--magazine {
  display: block;
}

.blog-page .blog-sidebar {
  display: none;
}

.blog-featured {
  overflow: hidden;
  margin-bottom: clamp(1.6rem, 3vw, 2.4rem);
}

.blog-featured__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: clamp(1rem, 2.1vw, 1.55rem);
  padding: clamp(1.7rem, 4vw, 3rem);
}

.blog-featured__content h2 {
  font-size: clamp(2.1rem, 3.6vw, 4.25rem);
}

.blog-featured__content .button-row {
  padding-top: .7rem;
}

.blog-grid--magazine {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1.15rem, 2.4vw, 1.8rem);
}

.blog-grid--magazine .blog-card {
  display: grid;
  grid-template-columns: minmax(260px, .42fr) minmax(0, 1fr);
  min-height: 0;
  overflow: hidden;
}

.blog-grid--magazine .blog-card:nth-child(even) {
  grid-template-columns: minmax(0, 1fr) minmax(260px, .42fr);
}

.blog-grid--magazine .blog-card:nth-child(even) .blog-card__media {
  order: 2;
}

.blog-grid--magazine .blog-card:nth-child(even) .blog-card__body {
  order: 1;
}

.blog-grid--magazine .blog-card__media img,
.blog-grid--magazine .blog-card__media--text {
  width: 100%;
  height: 100%;
  min-height: 260px;
  aspect-ratio: auto;
  object-fit: cover;
}

.blog-grid--magazine .blog-card__body {
  justify-content: center;
  gap: 1rem;
  padding: clamp(1.5rem, 3vw, 2.3rem);
}

.blog-grid--magazine .blog-card h3 {
  font-size: clamp(1.6rem, 2.8vw, 3rem);
  max-width: 760px;
}

.blog-grid--magazine .blog-card p:not(.blog-card__meta) {
  min-height: 0;
  max-width: 760px;
}

.blog-card__footer {
  margin-top: .4rem;
  padding-top: .85rem;
}

.site-footer {
  border-top: 1px solid rgba(255, 46, 154, .30);
  background:
    radial-gradient(circle at 18% 5%, rgba(255, 46, 154, .28), transparent 24rem),
    radial-gradient(circle at 85% 20%, rgba(178, 0, 102, .18), transparent 28rem),
    linear-gradient(135deg, #21000f, #120007 62%, #2b0015);
}

.footer__columns--modern {
  grid-template-columns: minmax(260px, 1.4fr) minmax(150px, .55fr) minmax(240px, .8fr);
  align-items: start;
}

.footer-list--columns {
  columns: 2;
  column-gap: 2rem;
}

.footer__bottom--modern {
  align-items: center;
  padding-top: clamp(1.1rem, 2.5vw, 1.5rem);
}

.footer-social-rounds {
  display: flex;
  flex-wrap: wrap;
  gap: .7rem;
  align-items: center;
}

.footer-social-round {
  display: inline-grid;
  place-items: center;
  width: 2.75rem;
  height: 2.75rem;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius-full);
  background: rgba(255,255,255,.08);
  color: #fff;
  font-weight: 900;
  box-shadow: 0 16px 36px rgba(0,0,0,.18);
  transition: transform .18s ease, background-color .18s ease, border-color .18s ease;
}

.footer-social-round:hover {
  transform: translateY(-3px);
  border-color: rgba(255,255,255,.3);
  background: var(--pink-650);
}

@media (max-width: 860px) {
  .blog-grid--magazine .blog-card,
  .blog-grid--magazine .blog-card:nth-child(even) {
    grid-template-columns: 1fr;
  }
  .blog-grid--magazine .blog-card:nth-child(even) .blog-card__media,
  .blog-grid--magazine .blog-card:nth-child(even) .blog-card__body {
    order: initial;
  }
  .footer__columns--modern {
    grid-template-columns: 1fr;
  }
  .footer-list--columns {
    columns: 1;
  }
}

/* 2026-06-30 release media rebuild: equal embeds, ordered facts, platform icons */
.release-media-section {
  padding-top: clamp(1.8rem, 4vw, 3.2rem);
  padding-bottom: clamp(1.5rem, 3vw, 2.4rem);
}

.release-media-grid--paired {
  align-items: stretch;
}

.release-media-grid--paired .release-media-card {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  min-height: clamp(455px, 34vw, 560px);
  padding: clamp(1.1rem, 2vw, 1.45rem);
}

.release-media-grid--paired .release-media-card__heading {
  margin-bottom: .55rem;
}

.release-media-grid--paired .release-media-card__heading h2 {
  font-size: clamp(1.42rem, 2vw, 2.15rem);
}

.release-media-grid--paired .release-embed {
  width: 100%;
  height: clamp(340px, 28vw, 430px);
  min-height: clamp(340px, 28vw, 430px);
  border-radius: calc(var(--radius-xl) - .55rem);
  overflow: hidden;
}

.release-media-grid--paired .release-embed--youtube {
  aspect-ratio: auto;
  background: #111;
}

.release-media-open-link {
  justify-self: start;
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  margin-top: .75rem;
  padding: .65rem .9rem;
  border: 1px solid rgba(178, 0, 102, .14);
  border-radius: var(--radius-full);
  color: var(--pink-700);
  background: rgba(255, 255, 255, .62);
  font-weight: 900;
}

.release-media-fallback {
  display: grid;
  grid-template-columns: minmax(92px, 140px) 1fr;
  gap: 1rem;
  align-items: center;
  min-height: clamp(340px, 28vw, 430px);
  padding: clamp(1rem, 2vw, 1.5rem);
  border-radius: calc(var(--radius-xl) - .55rem);
  background:
    radial-gradient(circle at 100% 0, rgba(255, 46, 154, .16), transparent 22rem),
    linear-gradient(145deg, rgba(255,255,255,.76), rgba(255,240,248,.7));
}

.release-media-fallback img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: var(--radius-md);
  box-shadow: 0 18px 42px rgba(91, 0, 50, .18);
}

.release-media-fallback h3 {
  margin: 0 0 .45rem;
  font-size: clamp(1.25rem, 2vw, 2rem);
  line-height: 1.02;
  letter-spacing: -.05em;
}

.release-media-fallback p {
  margin: 0 0 1rem;
  color: var(--ink-soft);
  line-height: 1.7;
}

.release-information-section {
  padding-top: clamp(1.2rem, 3vw, 2.2rem);
}

.release-info-grid--ordered {
  align-items: start;
}

.release-info-grid--ordered .release-info-card {
  min-height: 0;
}

.release-info-grid--ordered .release-info-card--platforms {
  order: 2;
}

.release-info-grid--ordered .release-info-card--tracks {
  order: 3;
}

.release-info-grid--ordered .release-info-card--lyrics {
  order: 4;
}

.release-platform-list--icons {
  gap: .62rem;
}

.release-platform-list--icons a {
  display: grid;
  grid-template-columns: 2.15rem 1fr auto;
  align-items: center;
  gap: .75rem;
  min-height: 3.15rem;
  padding: .58rem .72rem;
}

.platform-icon {
  display: inline-grid;
  place-items: center;
  width: 2.15rem;
  height: 2.15rem;
  border-radius: var(--radius-full);
  color: #fff;
  background: var(--pink-650);
  box-shadow: 0 12px 30px rgba(178, 0, 102, .22);
}

.platform-arrow {
  color: var(--pink-700);
  font-weight: 950;
}

.release-platform-list--icons a:hover .platform-icon {
  background: #fff;
  color: var(--pink-700);
}

.release-platform-list--icons a:hover .platform-arrow {
  color: #fff;
}

.lyrics-block--wide {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 360px), 1fr));
}

.release-info-card--lyrics .release-story-links,
.release-info-card--lyrics > .platform-link {
  display: none !important;
}

.footer-social-round i,
.platform-icon i,
.release-media-open-link i {
  font-size: 1rem;
  line-height: 1;
}

.footer-social-round .sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.site-footer .footer-social-round:nth-child(1) { background: #e62117; }
.site-footer .footer-social-round:nth-child(2) { background: #229ed9; }
.site-footer .footer-social-round:nth-child(3) { background: #4c75a3; }
.site-footer .footer-social-round:nth-child(4) { background: #1db954; }

@media (min-width: 1080px) {
  .release-info-grid--ordered {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  .release-info-grid--ordered .release-info-card--about {
    grid-column: span 5;
  }

  .release-info-grid--ordered .release-info-card--platforms {
    grid-column: span 4;
  }

  .release-info-grid--ordered .release-info-card--tracks {
    grid-column: span 3;
  }

  .release-info-grid--ordered .release-info-card--lyrics {
    grid-column: 1 / -1;
  }
}

@media (max-width: 860px) {
  .release-media-grid--paired .release-media-card {
    min-height: 0;
  }

  .release-media-grid--paired .release-embed,
  .release-media-fallback {
    height: 330px;
    min-height: 330px;
  }

  .release-media-fallback {
    grid-template-columns: 1fr;
  }

  .release-media-fallback img {
    max-width: 180px;
  }
}

/* 2026-06-30 vinyl release treatment */
.disc-graphic,
.release-card__disc,
.release-page__disc {
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.10) 0 .55%, transparent .7%),
    radial-gradient(circle at center, #07070a 0 6.6%, #f0cd84 6.8% 8.2%, #7d1945 8.5% 15.2%, #15161d 15.6% 18.2%, transparent 18.5%),
    repeating-radial-gradient(circle at center, rgba(255,255,255,.13) 0 1px, rgba(255,255,255,.03) 1.3px 1.85px, rgba(0,0,0,0) 2px 6px),
    radial-gradient(circle at 28% 22%, rgba(255,255,255,.17), transparent 21%),
    radial-gradient(circle at 74% 78%, rgba(0,0,0,.50), transparent 36%),
    linear-gradient(150deg, #242631 0%, #0b0b10 40%, #181922 100%);
  box-shadow:
    inset -22px -18px 36px rgba(0,0,0,.40),
    inset 18px 16px 28px rgba(255,255,255,.07),
    0 24px 68px rgba(52, 0, 27, .22);
}

.disc-graphic::before,
.release-card__disc::before,
.release-page__disc::before {
  content: "";
  position: absolute;
  inset: 7%;
  border-radius: 50%;
  background:
    conic-gradient(from 220deg, rgba(255,255,255,.14), transparent 16%, transparent 50%, rgba(255,255,255,.08) 74%, transparent 88%, rgba(255,255,255,.14)),
    radial-gradient(circle at 34% 24%, rgba(255,255,255,.24), transparent 24%),
    radial-gradient(circle at 66% 72%, rgba(255, 46, 154, .09), transparent 26%);
  mix-blend-mode: screen;
  opacity: .9;
}

.disc-graphic::after,
.release-card__disc::after,
.release-page__disc::after {
  content: "";
  position: absolute;
  inset: 44%;
  border-radius: 50%;
  background: #050507;
  box-shadow:
    0 0 0 .2rem rgba(255,255,255,.48),
    0 0 0 .72rem #e4bf72,
    0 0 0 1.58rem #7d1945,
    0 0 0 2.06rem rgba(255,255,255,.05);
}

.release-showcase__disc {
  top: 10%;
  right: -9%;
  width: min(68%, 370px);
  opacity: .98;
  animation-duration: 20s;
}

.release-showcase__cover {
  width: min(78vw, 430px);
  transform: rotate(-1.4deg);
}

.release-card {
  overflow: visible;
}

.release-card__media {
  overflow: visible;
  margin-bottom: .25rem;
}

.release-card__cover {
  inset: 0 auto 0 0;
  width: 78%;
  height: 100%;
  border-top-right-radius: calc(var(--radius-xl) - .6rem);
  border-bottom-right-radius: calc(var(--radius-xl) - .6rem);
}

.release-card__disc {
  inset: 14% -4% auto auto;
  width: 82%;
  aspect-ratio: 1;
  opacity: .94;
  transform: translateX(0) rotate(0deg);
  animation: disc-spin 22s linear infinite;
}

.release-card:hover .release-card__disc,
.release-card:focus-within .release-card__disc {
  opacity: 1;
  transform: translateX(5%) scale(1.02);
}

.release-card:hover .release-card__cover,
.release-card:focus-within .release-card__cover,
.release-card:hover .cover-art,
.release-card:focus-within .cover-art {
  transform: translateX(-2.8%) rotate(-1deg) scale(.992);
  filter: saturate(1.05) contrast(1.03);
}

.release-card__body {
  padding-top: .25rem;
}

.release-page-visual {
  overflow: visible;
}

.release-page__cover {
  width: 78%;
  border-top-right-radius: calc(var(--radius-xl) - .35rem);
  border-bottom-right-radius: calc(var(--radius-xl) - .35rem);
}

.release-page__disc {
  top: 10%;
  right: -9%;
  width: 88%;
  opacity: .97;
  animation-duration: 24s;
}

@media (min-width: 1180px) {
  .release-card--featured .release-card__cover {
    width: 76%;
  }

  .release-card--featured .release-card__disc {
    inset: 10% -2% auto auto;
    width: 82%;
    opacity: .96;
    transform: translateX(0);
  }

  .release-card--featured:hover .release-card__disc,
  .release-card--featured:focus-within .release-card__disc {
    transform: translateX(4%) scale(1.01);
  }
}

@media (max-width: 719px) {
  .release-showcase__disc {
    right: -3%;
    width: min(74%, 320px);
  }

  .release-card__cover {
    width: 80%;
  }

  .release-card__disc {
    inset: 16% -2% auto auto;
    width: 78%;
    transform: translateX(0);
  }

  .release-card:hover .release-card__disc,
  .release-card:focus-within .release-card__disc {
    transform: translateX(4%) scale(1.01);
  }

  .release-page__cover {
    width: 82%;
  }

  .release-page__disc {
    top: 13%;
    right: -1%;
    width: 84%;
  }
}

@media (prefers-reduced-motion: reduce) {
  .release-showcase__disc,
  .release-card__disc,
  .release-page__disc {
    animation: none !important;
  }

  .release-card__cover,
  .cover-art,
  .release-card__disc {
    transition: none !important;
  }
}

/* 2026-06-30 refined half-exposed vinyl composition */
.release-showcase__visual,
.release-page-visual,
.release-card__media {
  overflow: visible;
}

.release-showcase__cover,
.release-page__cover,
.release-card__cover {
  position: relative;
  z-index: 2;
}

.release-showcase__disc {
  top: auto;
  right: -12%;
  bottom: -5%;
  width: min(64%, 360px);
  opacity: .98;
  animation-duration: 18s;
}

.release-showcase__cover {
  width: min(72vw, 410px);
  transform: rotate(-.7deg);
}

.release-card {
  overflow: hidden;
}

.release-card__media {
  min-height: clamp(220px, 24vw, 300px);
  aspect-ratio: auto;
  margin-bottom: .85rem;
}

.release-card__cover {
  inset: 0 auto auto 0;
  width: 64%;
  height: 76%;
  border-top-right-radius: calc(var(--radius-xl) - .45rem);
  border-bottom-right-radius: calc(var(--radius-xl) - .45rem);
}

.release-card__disc {
  inset: auto -9% -18% auto;
  width: 72%;
  opacity: .96;
  z-index: 1;
  transform: rotate(0deg);
  animation: disc-spin 18s linear infinite;
}

.release-card:hover .release-card__disc,
.release-card:focus-within .release-card__disc {
  opacity: 1;
  transform: scale(1.02);
}

.release-card:hover .release-card__cover,
.release-card:focus-within .release-card__cover,
.release-card:hover .cover-art,
.release-card:focus-within .cover-art {
  transform: translateX(-1.6%) rotate(-.8deg) scale(.995);
}

.release-card__body {
  position: relative;
  z-index: 3;
  padding-top: .35rem;
}

.release-page-visual {
  width: min(100%, 620px);
  padding-bottom: clamp(1rem, 4vw, 2rem);
}

.release-page__cover {
  width: 68%;
  border-top-right-radius: calc(var(--radius-xl) - .35rem);
  border-bottom-right-radius: calc(var(--radius-xl) - .35rem);
}

.release-page__disc {
  top: auto;
  right: -6%;
  bottom: -2%;
  width: 78%;
  opacity: .98;
  animation-duration: 18s;
}

@media (min-width: 1180px) {
  .release-card--featured .release-card__cover {
    width: 62%;
    height: 78%;
  }

  .release-card--featured .release-card__disc {
    inset: auto -6% -16% auto;
    width: 66%;
    opacity: .98;
  }
}

@media (max-width: 719px) {
  .release-showcase__disc {
    right: -8%;
    bottom: -4%;
    width: min(66%, 280px);
  }

  .release-card__media {
    min-height: 230px;
  }

  .release-card__cover {
    width: 68%;
    height: 74%;
  }

  .release-card__disc {
    inset: auto -8% -17% auto;
    width: 74%;
  }

  .release-page__cover {
    width: 72%;
  }

  .release-page__disc {
    right: -2%;
    bottom: -1%;
    width: 80%;
  }
}

@media (prefers-reduced-motion: reduce) {
  .release-showcase__disc,
  .release-card__disc,
  .release-page__disc {
    animation: none !important;
  }
}


/* 2026-06-30 full-width cover with half-hidden vinyl on catalog cards */
.release-card {
  --release-card-pad: clamp(1rem, 2vw, 1.25rem);
  gap: .95rem;
  padding: var(--release-card-pad);
}

.release-card__media {
  width: calc(100% + (var(--release-card-pad) * 2));
  margin: calc(var(--release-card-pad) * -1) calc(var(--release-card-pad) * -1) .2rem;
  min-height: clamp(250px, 26vw, 320px);
  padding-bottom: clamp(1.2rem, 4vw, 2rem);
}

.release-card__cover {
  inset: 0;
  width: 100%;
  height: calc(100% - clamp(1.2rem, 4vw, 2rem));
  border-radius: calc(var(--radius-xl) - .45rem) calc(var(--radius-xl) - .45rem) 0 0;
  border-bottom: 1px solid rgba(178, 0, 102, .14);
  box-shadow: 0 22px 46px rgba(64, 0, 35, .16);
}

.release-card__cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.release-card__disc {
  inset: auto -8% 0 auto;
  width: 54%;
  opacity: .97;
  z-index: 1;
  filter: drop-shadow(0 18px 20px rgba(32, 7, 26, .18));
}

.release-card__media::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: clamp(1rem, 3vw, 1.35rem);
  border-top: 1px solid var(--card-border);
  background: linear-gradient(180deg, rgba(255,255,255,.1), rgba(255,255,255,.78));
  pointer-events: none;
}

.release-card__body {
  border-top: 1px solid rgba(178, 0, 102, .08);
  padding-top: .95rem;
}

.release-card:hover .release-card__cover,
.release-card:focus-within .release-card__cover,
.release-card:hover .cover-art,
.release-card:focus-within .cover-art {
  transform: translateY(-1px) scale(.997);
}

.release-card:hover .release-card__disc,
.release-card:focus-within .release-card__disc {
  transform: translateY(-1px) scale(1.02);
}

@media (min-width: 1180px) {
  .release-card--featured .release-card__media {
    min-height: clamp(270px, 24vw, 340px);
  }

  .release-card--featured .release-card__disc {
    width: 50%;
    inset: auto -5% 0 auto;
  }
}

@media (max-width: 719px) {
  .release-card__media {
    min-height: 250px;
    padding-bottom: 1rem;
  }

  .release-card__cover {
    height: calc(100% - 1rem);
  }

  .release-card__disc {
    width: 56%;
    inset: auto -10% 0 auto;
  }
}


/* 2026-06-30 polish: fully stretched rounded cover on release cards */
.release-card {
  overflow: hidden;
}

.release-card__media {
  width: calc(100% + (var(--release-card-pad) * 2) + 2px);
  margin: calc((var(--release-card-pad) * -1) - 1px) calc((var(--release-card-pad) * -1) - 1px) .35rem;
  min-height: clamp(260px, 26vw, 332px);
}

.release-card__cover {
  inset: 0;
  width: 100%;
  height: calc(100% - clamp(1.15rem, 3.5vw, 1.8rem));
  border-radius: calc(var(--radius-xl) - 1px);
  border-bottom-left-radius: 1.05rem;
  border-bottom-right-radius: 1.05rem;
}

.release-card__cover img,
.release-card__cover picture,
.release-card__cover canvas {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
}

.release-card__disc {
  inset: auto -7% .15rem auto;
  width: 52%;
}

.release-card__media::after {
  height: clamp(1.05rem, 3vw, 1.3rem);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.92));
}

@media (max-width: 719px) {
  .release-card__media {
    width: calc(100% + (var(--release-card-pad) * 2) + 2px);
    margin: calc((var(--release-card-pad) * -1) - 1px) calc((var(--release-card-pad) * -1) - 1px) .35rem;
  }
}


/* 2026-06-30 final polish: cover starts the card edge-to-edge without side gutters */
.release-card {
  padding: 0;
  gap: 0;
  overflow: hidden;
}

.release-card__media {
  width: 100%;
  margin: 0;
  min-height: clamp(260px, 26vw, 332px);
  padding-bottom: clamp(1.15rem, 3.5vw, 1.8rem);
}

.release-card__cover {
  inset: 0;
  width: 100%;
  height: calc(100% - clamp(1.15rem, 3.5vw, 1.8rem));
  border-radius: calc(var(--radius-xl) - 1px) calc(var(--radius-xl) - 1px) 0 0;
  border-bottom: 1px solid rgba(178, 0, 102, .12);
  overflow: hidden;
}

.release-card__cover img,
.release-card__cover picture,
.release-card__cover canvas {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
}

.release-card__disc {
  inset: auto -7% .1rem auto;
  width: 52%;
}

.release-card__media::after {
  left: 0;
  right: 0;
  bottom: 0;
  height: clamp(1rem, 3vw, 1.25rem);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.88));
}

.release-card__body {
  padding: 1.05rem var(--release-card-pad) var(--release-card-pad);
  border-top: 1px solid rgba(178, 0, 102, .08);
}

@media (max-width: 719px) {
  .release-card__media {
    min-height: 250px;
    padding-bottom: 1rem;
  }

  .release-card__cover {
    height: calc(100% - 1rem);
  }
}


/* 2026-06-30 final behavior: vinyl spins only on hover and drops slightly lower */
@keyframes release-card-disc-hover-spin {
  from {
    transform: translateY(var(--disc-hover-drop, .55rem)) rotate(0deg);
  }
  to {
    transform: translateY(var(--disc-hover-drop, .55rem)) rotate(360deg);
  }
}

.release-card__disc {
  --disc-hover-drop: .6rem;
  transform: translateY(0) rotate(0deg);
  animation: none;
  transition: transform .28s ease, opacity .28s ease, filter .28s ease;
}

.release-card:hover .release-card__disc,
.release-card:focus-within .release-card__disc {
  opacity: 1;
  animation: release-card-disc-hover-spin 7.5s linear infinite;
  transform: translateY(var(--disc-hover-drop, .6rem)) rotate(0deg);
}

@media (hover: none) {
  .release-card__disc {
    animation: none !important;
    transform: translateY(0) rotate(0deg);
  }

  .release-card:hover .release-card__disc,
  .release-card:focus-within .release-card__disc {
    animation: none !important;
    transform: translateY(0) rotate(0deg);
  }
}

/* 2026-06-30 catalog card edge fix: remove inherited inner padding */
.release-grid--catalog .release-card {
  padding: 0;
}

.release-grid--catalog .release-card__body {
  padding: 1.05rem var(--release-card-pad) var(--release-card-pad);
}

/* 2026-06-30 release detail vinyl balance */
.release-page__disc {
  top: auto;
  right: clamp(-12px, -1vw, 0px);
  bottom: 0;
  width: clamp(220px, 44%, 420px);
  opacity: .98;
  animation-duration: 18s;
}

.release-page__cover {
  position: relative;
  z-index: 2;
}


/* 2026-06-30 compact lyrics lines */
.lyrics-block {
  gap: .85rem;
}

.lyrics-block__section {
  gap: .32rem;
}

.lyrics-block__section p {
  line-height: 1.45;
  white-space: normal;
}

.lyrics-block__section p br + br {
  display: none;
}


/* 2026-06-30 lyrics: preserve one line break, no empty second BR */
.lyrics-block__section p {
  line-height: 1.48;
  white-space: normal;
}

.lyrics-block__section p br {
  display: block;
  content: "";
}

.lyrics-block__section p br + br {
  display: none !important;
}

/* 2026-06-30 lyrics hard fix: one visual row per lyric line, no glued text and no double gaps */
.lyrics-lines {
  display: grid;
  gap: .12rem;
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.48;
}

.lyrics-line {
  display: block;
  margin: 0;
  padding: 0;
}

.lyrics-block__section p {
  margin: 0;
}

/* 2026-06-30 album lyrics switcher */
.track-list--lyrics-switcher .track-item {
  grid-template-columns: auto minmax(0, 1fr) auto auto;
}

.track-item--has-lyrics {
  background: linear-gradient(135deg, rgba(255, 227, 241, .72), rgba(255, 255, 255, .68));
}

.track-item--has-lyrics.is-active {
  box-shadow: inset 0 0 0 1px rgba(213, 11, 120, .22), 0 14px 34px rgba(155, 7, 87, .10);
}

.track-lyrics-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .38rem;
  min-height: 2.05rem;
  padding: .42rem .7rem;
  border: 1px solid rgba(178, 0, 102, .16);
  border-radius: var(--radius-full);
  color: var(--pink-700);
  background: rgba(255, 255, 255, .78);
  font-size: .82rem;
  font-weight: 900;
  transition: transform .18s ease, color .18s ease, background-color .18s ease, border-color .18s ease;
}

.track-lyrics-button:hover,
.track-lyrics-button[aria-pressed="true"] {
  color: #fff;
  background: var(--pink-650);
  border-color: var(--pink-650);
  transform: translateY(-1px);
}

.lyrics-viewer-heading {
  display: grid;
  gap: .35rem;
  margin-bottom: .75rem;
}

.lyrics-viewer-heading h2 {
  margin: 0;
  font-size: clamp(1.45rem, 2.4vw, 2.2rem);
  letter-spacing: -.04em;
}

.lyrics-viewer-heading p {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.lyrics-track-panel[hidden] {
  display: none !important;
}

.release-info-card--lyrics.is-lyrics-updated {
  animation: lyrics-flash .22s ease;
}

@keyframes lyrics-flash {
  from { transform: translateY(2px); }
  to { transform: translateY(0); }
}

@media (max-width: 719px) {
  .track-list--lyrics-switcher .track-item {
    grid-template-columns: auto 1fr auto;
  }

  .track-list--lyrics-switcher .track-lyrics-button {
    grid-column: 2 / -1;
    justify-self: start;
  }
}

/* 2026-06-30 album layout polish: smaller about card, wider two-column tracklist */
@media (min-width: 1080px) {
  .release-info-grid--ordered .release-info-card--about {
    grid-column: span 4;
  }

  .release-info-grid--ordered .release-info-card--platforms {
    grid-column: span 3;
  }

  .release-info-grid--ordered .release-info-card--tracks {
    grid-column: span 5;
  }

  .release-info-card--tracks .track-list--lyrics-switcher {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .72rem;
  }

  .release-info-card--tracks .track-list--lyrics-switcher .track-item {
    min-height: 4.6rem;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: .5rem .65rem;
    align-content: center;
    padding: .82rem .9rem;
  }

  .release-info-card--tracks .track-list--lyrics-switcher .track-lyrics-button {
    grid-column: 2 / -1;
    justify-self: start;
    min-height: 1.86rem;
    padding: .33rem .62rem;
    font-size: .78rem;
  }
}

@media (min-width: 1440px) {
  .release-info-grid--ordered .release-info-card--about {
    grid-column: span 4;
  }

  .release-info-grid--ordered .release-info-card--platforms {
    grid-column: span 3;
  }

  .release-info-grid--ordered .release-info-card--tracks {
    grid-column: span 5;
  }
}

/* 2026-06-30 album release information layout: summary + links | wider tracklist */
.release-info-grid--album {
  align-items: start;
}

.release-inline-platforms {
  display: grid;
  gap: .75rem;
  margin-top: 1.1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--card-border);
}

.release-inline-platforms h2 {
  margin: 0;
  font-size: clamp(1.15rem, 1.8vw, 1.55rem);
  letter-spacing: -.035em;
}

.release-platform-list--compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .55rem;
}

.release-platform-list--compact a {
  min-height: 2.85rem;
  padding: .48rem .58rem;
}

.release-platform-list--compact .platform-icon {
  width: 1.95rem;
  height: 1.95rem;
}

.track-item--no-lyrics {
  background: rgba(255, 244, 250, .56);
}

.track-lyrics-empty {
  display: inline-grid;
  place-items: center;
  min-width: 2.05rem;
  min-height: 2.05rem;
  border: 1px solid rgba(178, 0, 102, .10);
  border-radius: var(--radius-full);
  color: rgba(122, 91, 112, .62);
  background: rgba(255,255,255,.54);
  font-weight: 900;
}

.track-item--has-lyrics.is-active {
  background: linear-gradient(135deg, rgba(255, 227, 241, .96), rgba(255, 255, 255, .78));
  border-color: rgba(213, 11, 120, .24);
  box-shadow: inset 0 0 0 1px rgba(213, 11, 120, .26), 0 16px 38px rgba(155, 7, 87, .13);
}

.track-item--has-lyrics.is-active .track-item__num,
.track-item--has-lyrics.is-active strong,
.track-item--has-lyrics.is-active .track-item__duration {
  color: var(--pink-700);
}

.track-lyrics-button[aria-pressed="true"] {
  color: #fff;
  background: var(--pink-650);
  border-color: var(--pink-650);
  box-shadow: 0 10px 22px rgba(178, 0, 102, .20);
}

.lyrics-viewer-meta {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  min-height: 2rem;
  padding: .38rem .72rem;
  border: 1px solid rgba(178, 0, 102, .13);
  border-radius: var(--radius-full);
  color: var(--pink-700) !important;
  background: rgba(255, 227, 241, .68);
  font-size: .86rem;
  font-weight: 900;
  letter-spacing: .02em;
}

.lyrics-viewer-hint {
  color: var(--muted);
}

@media (min-width: 1080px) {
  .release-info-grid--single {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  .release-info-grid--single .release-info-card--about,
  .release-info-grid--single .release-info-card--platforms,
  .release-info-grid--single .release-info-card--tracks {
    grid-column: span 4;
  }

  .release-info-grid--single .release-info-card--lyrics {
    grid-column: 1 / -1;
  }

  .release-info-grid--album {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  .release-info-grid--album .release-info-card--about {
    grid-column: span 5;
  }

  .release-info-grid--album .release-info-card--tracks {
    grid-column: span 7;
  }

  .release-info-grid--album .release-info-card--lyrics {
    grid-column: 1 / -1;
  }

  .release-info-grid--album .track-list--album {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .72rem;
  }

  .release-info-grid--album .track-list--album .track-item {
    grid-template-columns: auto minmax(0, 1fr) auto auto;
    min-height: 4.1rem;
    gap: .55rem .68rem;
    align-content: center;
    padding: .82rem .88rem;
  }

  .release-info-grid--album .track-list--album .track-lyrics-button {
    min-height: 1.95rem;
    padding: .36rem .62rem;
    font-size: .78rem;
  }
}

@media (max-width: 1079px) {
  .release-platform-list--compact {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 719px) {
  .release-info-grid--album .track-list--album .track-item {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }

  .track-lyrics-empty,
  .release-info-grid--album .track-list--album .track-lyrics-button {
    grid-column: 2 / -1;
    justify-self: start;
  }
}


/* 2026-06-30 final catalog/navigation/lyrics polish */
@keyframes release-disc-smooth-spin {
  to { rotate: 360deg; }
}

.release-card__disc,
.release-page__disc {
  animation: none !important;
  transform: none !important;
  translate: 0 0;
  rotate: 0deg;
  transition: translate .48s cubic-bezier(.22, 1, .36, 1), opacity .22s ease, filter .22s ease;
  will-change: translate, rotate;
}

.release-card:hover .release-card__disc,
.release-card:focus-within .release-card__disc {
  translate: 0 .56rem;
  animation: release-disc-smooth-spin 10s linear infinite !important;
  transform: none !important;
}

.release-page-visual:hover .release-page__disc,
.release-page-visual:focus-within .release-page__disc {
  translate: 0 .42rem;
  animation: release-disc-smooth-spin 14s linear infinite !important;
  transform: none !important;
}

@media (hover: none), (prefers-reduced-motion: reduce) {
  .release-card__disc,
  .release-card:hover .release-card__disc,
  .release-card:focus-within .release-card__disc,
  .release-page__disc,
  .release-page-visual:hover .release-page__disc,
  .release-page-visual:focus-within .release-page__disc {
    animation: none !important;
    translate: 0 0;
    rotate: 0deg;
  }
}

.lyrics-viewer-heading--compact {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .65rem .9rem;
  margin-bottom: .95rem;
}

.lyrics-viewer-heading--compact h2,
.lyrics-viewer-heading h2[data-lyrics-current-title] {
  display: none !important;
}

.lyrics-viewer-heading--compact .lyrics-viewer-meta {
  margin: 0;
}

.lyrics-viewer-heading--compact .lyrics-viewer-hint {
  margin: 0;
  line-height: 1.5;
}

.release-info-card--lyrics .lyrics-block {
  margin-top: .15rem;
}

.footer__columns--modern {
  grid-template-columns: minmax(260px, 1.1fr) minmax(220px, .7fr);
}

.discography-hub {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 330px), 1fr));
  gap: clamp(1rem, 2.4vw, 1.6rem);
  margin-bottom: clamp(2rem, 5vw, 3.6rem);
}

.discography-hub-card {
  display: grid;
  align-content: start;
  gap: .9rem;
  min-height: 280px;
  padding: clamp(1.25rem, 3vw, 2rem);
  border: 1px solid rgba(178, 0, 102, .14);
  border-radius: var(--radius-xl);
  background:
    radial-gradient(circle at 100% 0%, rgba(255, 46, 154, .14), transparent 32%),
    linear-gradient(145deg, rgba(255,255,255,.82), rgba(255,244,250,.58));
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(14px) saturate(1.08);
}

.discography-hub-card h3 {
  margin: 0;
  font-size: clamp(1.9rem, 4vw, 3.1rem);
  line-height: .98;
  letter-spacing: -.055em;
}

.discography-hub-card p {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.7;
}

.discography-hub-card__meta {
  display: inline-flex;
  width: fit-content;
  align-items: baseline;
  gap: .45rem;
  padding: .55rem .75rem;
  border: 1px solid rgba(178, 0, 102, .14);
  border-radius: var(--radius-full);
  color: var(--pink-700);
  background: rgba(255, 255, 255, .68);
}

.discography-hub-card__meta strong {
  font-size: 1.25rem;
  font-weight: 950;
}

.discography-hub-card .button {
  justify-self: start;
  margin-top: .25rem;
}

.release-grid--preview {
  margin-top: 1.2rem;
}

.catalog-page-hero {
  padding-top: clamp(3rem, 6vw, 5.5rem);
}

.section-heading--compact {
  margin-top: clamp(1.2rem, 4vw, 2rem);
}

/* 2026-06-30 vinyl placement: disc is thrown lower from under the cover */
.release-card__media {
  overflow: visible;
}

.release-card__disc {
  inset: auto -5% -3.5rem auto;
}

.release-card__body {
  position: relative;
  z-index: 3;
}

@media (max-width: 719px) {
  .release-card__disc {
    inset: auto -6% -2.4rem auto;
  }
}

/* 2026-06-30 vinyl hover state: tucked by default, big exit on hover */
.release-card__disc {
  inset: auto -11% -5.25rem auto;
  opacity: .88;
  translate: 0 0;
  transition:
    inset .46s cubic-bezier(.22, 1, .36, 1),
    translate .46s cubic-bezier(.22, 1, .36, 1),
    opacity .24s ease,
    filter .24s ease;
}

.release-card:hover .release-card__disc,
.release-card:focus-within .release-card__disc {
  inset: auto -5% -3.5rem auto;
  opacity: 1;
  translate: 0 .28rem;
  animation: release-disc-smooth-spin 10s linear infinite !important;
}

@media (max-width: 719px) {
  .release-card__disc {
    inset: auto -10% -3.35rem auto;
    opacity: .9;
  }

  .release-card:hover .release-card__disc,
  .release-card:focus-within .release-card__disc {
    inset: auto -6% -2.4rem auto;
    translate: 0 0;
    animation: none !important;
  }
}

@media (hover: none), (prefers-reduced-motion: reduce) {
  .release-card__disc,
  .release-card:hover .release-card__disc,
  .release-card:focus-within .release-card__disc {
    inset: auto -10% -3.35rem auto;
    translate: 0 0;
    animation: none !important;
  }
}

/* 2026-06-30 final vinyl hover contract */
.release-card__disc {
  inset: auto -5% 0rem auto !important;
  opacity: .96;
  translate: 0 0 !important;
  transform: none !important;
  rotate: 0deg;
  animation: none !important;
  transition:
    inset .48s cubic-bezier(.22, 1, .36, 1),
    opacity .24s ease,
    filter .24s ease;
}

.release-card:hover .release-card__disc,
.release-card:focus-within .release-card__disc {
  inset: auto -5% -3.5rem auto !important;
  opacity: 1;
  translate: 0 0 !important;
  transform: none !important;
  animation: release-disc-smooth-spin 10s linear infinite !important;
}

@media (hover: none), (prefers-reduced-motion: reduce) {
  .release-card__disc,
  .release-card:hover .release-card__disc,
  .release-card:focus-within .release-card__disc {
    inset: auto -5% 0rem auto !important;
    translate: 0 0 !important;
    transform: none !important;
    animation: none !important;
  }
}

/* 2026-06-30 detail page vinyl: can spin immediately because there is only one hero disc */
.release-page__disc {
  animation: disc-spin 18s linear infinite;
  transform-origin: 50% 50%;
  will-change: transform;
}

@media (prefers-reduced-motion: reduce) {
  .release-page__disc {
    animation: none !important;
    will-change: auto;
  }
}

/* Theme toggle lives in the shared shell. Actual palettes are in theme-light.css and theme-dark.css. */
.theme-toggle {
  position: relative;
  overflow: hidden;
}

.theme-toggle__icon {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  transition: transform .22s var(--ease-out), opacity .22s ease;
}

.theme-toggle__icon--dark {
  transform: translateY(100%);
  opacity: 0;
}

[data-theme="dark"] .theme-toggle__icon--light {
  transform: translateY(-100%);
  opacity: 0;
}

[data-theme="dark"] .theme-toggle__icon--dark {
  transform: translateY(0);
  opacity: 1;
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) .theme-toggle__icon--light {
    transform: translateY(-100%);
    opacity: 0;
  }

  :root:not([data-theme]) .theme-toggle__icon--dark {
    transform: translateY(0);
    opacity: 1;
  }
}

/* 2026-07-01 unified single/album release info layout */
.release-info-grid--unified {
  align-items: start;
}

.release-info-grid--unified .release-info-card--about {
  order: 1;
}

.release-info-grid--unified .release-info-card--tracks {
  order: 2;
}

.release-info-grid--unified .release-info-card--lyrics {
  order: 3;
}

.release-info-grid--unified .release-inline-platforms {
  margin-top: clamp(1rem, 2vw, 1.25rem);
}

.release-info-grid--unified .release-platform-list--compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.release-info-grid--unified .release-platform-list--compact .release-platform-item--youtube,
.release-info-grid--unified .release-platform-list--compact .release-platform-item--telegram,
.release-info-grid--unified .release-platform-list--compact .release-platform-item--other {
  grid-column: 1 / -1;
}

@media (min-width: 1080px) {
  .release-info-grid--unified {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  .release-info-grid--unified .release-info-card--about {
    grid-column: span 5;
  }

  .release-info-grid--unified .release-info-card--tracks {
    grid-column: span 7;
  }

  .release-info-grid--unified .release-info-card--lyrics {
    grid-column: 1 / -1;
  }

  .release-info-grid--unified .track-list--album {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .72rem;
  }

  .release-info-grid--unified .track-list--album .track-item {
    grid-template-columns: auto minmax(0, 1fr) auto auto;
    min-height: 4.1rem;
    gap: .55rem .68rem;
    align-content: center;
    padding: .82rem .88rem;
  }
}

@media (max-width: 1079px) {
  .release-info-grid--unified .release-platform-list--compact {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 719px) {
  .release-info-grid--unified .track-list--album .track-item {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }
}

.release-info-grid--unified .track-list--single-track {
  grid-template-columns: 1fr;
}

/* 2026-07-01 final release-ready visual polish */
body {
  background: var(--body-bg);
  background-attachment: fixed;
}

.release-detail .section-shell--gradient,
.release-detail .release-media-section,
.release-detail .release-information-section {
  background: transparent;
}

.release-detail .release-media-card,
.release-detail .release-info-card {
  border-color: var(--release-card-border, var(--card-border));
  background: var(--release-card-bg, var(--media-card-bg));
  box-shadow: var(--release-card-shadow, var(--shadow-soft));
}

.release-detail .release-info-card--lyrics .lyrics-block__section,
.release-detail .track-item,
.release-detail .release-platform-item a,
.release-detail .release-facts div {
  border-color: color-mix(in srgb, var(--release-card-border, var(--card-border)) 88%, transparent);
}

.release-detail .lyrics-block__section {
  background: var(--release-subcard-bg, var(--surface-soft));
}

.release-detail .lyrics-block__section h3 {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  min-height: 1.9rem;
  padding: .25rem .7rem;
  border: 1px solid color-mix(in srgb, var(--pink-500) 26%, transparent);
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--pink-500) 10%, transparent);
  color: var(--pink-700);
  line-height: 1;
}

.release-detail .eyebrow {
  background: color-mix(in srgb, var(--release-subcard-bg, var(--surface-soft)) 78%, transparent);
}

.release-detail .release-page-copy .eyebrow {
  background: color-mix(in srgb, var(--pink-500) 12%, transparent);
}

.release-detail .release-info-card--about,
.release-detail .release-info-card--tracks {
  align-self: stretch;
}

.release-detail .release-inline-platforms h2 {
  margin-top: clamp(1rem, 2vw, 1.4rem);
}

.release-detail .track-list--single-track .track-item {
  min-height: 4.4rem;
}

@supports not (color: color-mix(in srgb, #fff 50%, #000)) {
  .release-detail .release-info-card--lyrics .lyrics-block__section,
  .release-detail .track-item,
  .release-detail .release-platform-item a,
  .release-detail .release-facts div {
    border-color: var(--release-card-border, var(--card-border));
  }

  .release-detail .lyrics-block__section h3 {
    border-color: var(--release-card-border, var(--card-border));
    background: var(--pill-bg);
  }

  .release-detail .eyebrow {
    background: var(--pill-bg);
  }
}

/* 2026-07-01 mobile header and release hero vinyl final contract */
@media (max-width: 919px) {
  :root {
    --header-height: 66px;
  }

  .site-header {
    min-width: 0;
  }

  .header__inner {
    width: calc(100% - 1rem);
    min-width: 0;
    gap: .5rem;
  }

  .logo {
    flex: 1 1 auto;
    min-width: 0;
    max-width: calc(100% - 6.4rem);
    overflow: hidden;
  }

  .logo__image {
    width: clamp(7.15rem, 34vw, 8.7rem);
    max-width: 100%;
  }

  .header-actions {
    flex: 0 0 auto;
    gap: .38rem;
  }

  .header-actions .icon-button {
    width: 2.35rem;
    height: 2.35rem;
    min-width: 2.35rem;
  }

  .theme-toggle,
  .nav-toggle {
    display: inline-grid;
    place-items: center;
  }

  .nav-toggle {
    gap: .22rem;
  }

  .nav-toggle__bar,
  .nav-toggle::before,
  .nav-toggle::after {
    width: .98rem;
  }

  .primary-nav {
    inset: calc(var(--header-height) + .55rem) .6rem auto .6rem;
    max-height: calc(100svh - var(--header-height) - 1.25rem);
    padding: .75rem;
    overflow: auto;
    border-radius: var(--radius-md);
  }

  .nav-link {
    min-height: 2.65rem;
    padding: .68rem .85rem;
  }

  body.nav-open {
    overflow: hidden;
  }
}

@media (max-width: 374px) {
  .header__inner {
    width: calc(100% - .75rem);
    gap: .35rem;
  }

  .logo {
    max-width: calc(100% - 5.85rem);
  }

  .logo__image {
    width: 6.8rem;
  }

  .header-actions {
    gap: .28rem;
  }

  .header-actions .icon-button {
    width: 2.22rem;
    height: 2.22rem;
    min-width: 2.22rem;
  }
}

.release-page__disc,
.release-page-visual:hover .release-page__disc,
.release-page-visual:focus-within .release-page__disc {
  translate: 0 0 !important;
  transform: none !important;
  animation: release-disc-smooth-spin 18s linear infinite !important;
  transform-origin: 50% 50%;
  will-change: rotate;
}

@media (prefers-reduced-motion: reduce) {
  .release-page__disc,
  .release-page-visual:hover .release-page__disc,
  .release-page-visual:focus-within .release-page__disc {
    translate: 0 0 !important;
    rotate: 0deg !important;
    animation: none !important;
    will-change: auto;
  }
}

/* 2026-07-01 normalized release media: audio fallbacks and wide YouTube */
.release-media-grid--single,
.release-media-grid--youtube-wide {
  grid-template-columns: 1fr;
}

.release-media-card--wide {
  grid-column: 1 / -1;
}

.release-media-grid--youtube-wide .release-media-card--video {
  grid-column: 1 / -1;
}

@media (min-width: 900px) {
  .release-media-grid--youtube-wide .release-embed--youtube {
    height: clamp(440px, 46vw, 720px);
    min-height: clamp(440px, 46vw, 720px);
  }

  .release-media-grid--youtube-wide .release-media-fallback {
    min-height: clamp(360px, 34vw, 520px);
  }
}

.release-embed--spotify {
  background: #111;
}


/* 2026-07-01 fallback cover: releases without cover art use one vinyl visual, without duplicate decorative discs */
.release-card--no-cover .release-card__disc,
.release-page-visual--fallback-disc .release-page__disc {
  display: none !important;
}

.release-card__cover--fallback-disc,
.release-page__cover--fallback-disc {
  background: radial-gradient(circle at 28% 18%, rgba(255, 46, 154, .22), transparent 44%), var(--surface-strong);
}

.release-card__cover--fallback-disc img,
.release-page__cover--fallback-disc img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.release-card--no-cover .release-card__media {
  overflow: hidden;
}

.release-card--no-cover:hover .release-card__cover,
.release-card--no-cover:focus-within .release-card__cover {
  transform: scale(1.015);
  filter: saturate(1.08) contrast(1.05);
}

.release-page-visual--fallback-disc {
  width: min(100%, 520px);
}

.release-page-visual--fallback-disc .release-page__cover {
  width: min(100%, 440px);
  margin-inline: auto;
  box-shadow: var(--shadow-deep), 0 0 72px rgba(241, 15, 136, .22);
}

.release-media-fallback--youtube img {
  border-radius: calc(var(--radius-lg) - .35rem);
  box-shadow: 0 18px 48px rgba(20, 0, 14, .22);
}

/* 2026-07-01 theme-aware release disc cover fallback */
:root,
[data-theme="light"] {
  --release-disc-core: #050507;
  --release-disc-ring-gold: #e4bf72;
  --release-disc-ring-accent: #7d1945;
  --release-disc-a: #242631;
  --release-disc-b: #09090d;
  --release-disc-c: #171923;
  --release-disc-highlight: rgba(255,255,255,.18);
  --release-disc-highlight-strong: rgba(255,255,255,.30);
  --release-disc-groove-a: rgba(255,255,255,.12);
  --release-disc-groove-b: rgba(255,255,255,.035);
  --release-disc-shade: rgba(0,0,0,.52);
  --release-disc-pink-glow: rgba(255,46,154,.12);
  --release-disc-inner-ring: #15161d;
  --release-disc-shadow: 0 24px 68px rgba(52,0,27,.24);
  --release-disc-inset-dark: inset -22px -18px 36px rgba(0,0,0,.42);
  --release-disc-inset-light: inset 18px 16px 28px rgba(255,255,255,.075);
  --fallback-disc-cover-bg: radial-gradient(circle at 20% 8%, rgba(255,46,154,.16), transparent 35%), radial-gradient(circle at 88% 84%, rgba(125,25,69,.18), transparent 38%), linear-gradient(145deg, rgba(255,255,255,.92), rgba(248,239,246,.84));
  --fallback-disc-cover-border: rgba(125,25,69,.12);
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --release-disc-core: #09050a;
    --release-disc-ring-gold: #f0cd84;
    --release-disc-ring-accent: #ff58ad;
    --release-disc-a: #ffffff;
    --release-disc-b: #cfd3dc;
    --release-disc-c: #f2f3f6;
    --release-disc-highlight: rgba(124,10,73,.34); /* #7c0a49 */
    --release-disc-highlight-strong: rgba(176,9,99,.62); /* #b00963 */
    --release-disc-groove-a: rgba(12,8,13,.16);
    --release-disc-groove-b: rgba(12,8,13,.075);
    --release-disc-shade: rgba(58,16,37,.24); /* #3a1025 */
    --release-disc-pink-glow: rgba(124,10,73,.52); /* #7c0a49 */
    --release-disc-inner-ring: #dfe2e8;
    --release-disc-shadow: 0 28px 82px rgba(255,192,221,.13), 0 24px 72px rgba(0,0,0,.32);
    --release-disc-inset-dark: inset -22px -18px 36px rgba(10,8,12,.16);
    --release-disc-inset-light: inset 18px 16px 28px rgba(255,255,255,.64);
    --fallback-disc-cover-bg: radial-gradient(circle at 22% 10%, rgba(124,10,73,.34), transparent 38%), radial-gradient(circle at 82% 88%, rgba(176,9,99,.16), transparent 42%), linear-gradient(145deg, rgba(58,16,37,.90), rgba(12,5,10,.86));
    --fallback-disc-cover-border: rgba(176,9,99,.24);
  }
}

[data-theme="dark"] {
  --release-disc-core: #09050a;
  --release-disc-ring-gold: #f0cd84;
  --release-disc-ring-accent: #ff58ad;
  --release-disc-a: #ffffff;
  --release-disc-b: #cfd3dc;
  --release-disc-c: #f2f3f6;
  --release-disc-highlight: rgba(124,10,73,.34); /* #7c0a49 */
  --release-disc-highlight-strong: rgba(176,9,99,.62); /* #b00963 */
  --release-disc-groove-a: rgba(12,8,13,.16);
  --release-disc-groove-b: rgba(12,8,13,.075);
  --release-disc-shade: rgba(58,16,37,.24); /* #3a1025 */
  --release-disc-pink-glow: rgba(124,10,73,.52); /* #7c0a49 */
  --release-disc-inner-ring: #dfe2e8;
  --release-disc-shadow: 0 28px 82px rgba(255,192,221,.13), 0 24px 72px rgba(0,0,0,.32);
  --release-disc-inset-dark: inset -22px -18px 36px rgba(10,8,12,.16);
  --release-disc-inset-light: inset 18px 16px 28px rgba(255,255,255,.64);
  --fallback-disc-cover-bg: radial-gradient(circle at 22% 10%, rgba(124,10,73,.34), transparent 38%), radial-gradient(circle at 82% 88%, rgba(176,9,99,.16), transparent 42%), linear-gradient(145deg, rgba(58,16,37,.90), rgba(12,5,10,.86));
  --fallback-disc-cover-border: rgba(176,9,99,.24);
}

.disc-graphic,
.release-card__disc,
.release-page__disc,
.themed-disc {
  display: block;
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.16) 0 .55%, transparent .7%),
    radial-gradient(circle at center, var(--release-disc-core) 0 6.6%, var(--release-disc-ring-gold) 6.8% 8.2%, var(--release-disc-ring-accent) 8.5% 15.2%, var(--release-disc-inner-ring) 15.6% 18.2%, transparent 18.5%),
    repeating-radial-gradient(circle at center, var(--release-disc-groove-a) 0 1px, var(--release-disc-groove-b) 1.3px 1.85px, transparent 2px 6px),
    radial-gradient(circle at 28% 22%, var(--release-disc-highlight), transparent 21%),
    radial-gradient(circle at 74% 78%, var(--release-disc-shade), transparent 36%),
    linear-gradient(150deg, var(--release-disc-a) 0%, var(--release-disc-b) 44%, var(--release-disc-c) 100%);
  box-shadow:
    var(--release-disc-inset-dark),
    var(--release-disc-inset-light),
    var(--release-disc-shadow);
}

.disc-graphic::before,
.release-card__disc::before,
.release-page__disc::before,
.themed-disc::before {
  content: "";
  position: absolute;
  inset: 7%;
  border-radius: 50%;
  background:
    conic-gradient(from 220deg, var(--release-disc-highlight-strong), transparent 16%, transparent 50%, var(--release-disc-highlight) 74%, transparent 88%, var(--release-disc-highlight-strong)),
    radial-gradient(circle at 34% 24%, var(--release-disc-highlight-strong), transparent 24%),
    radial-gradient(circle at 66% 72%, var(--release-disc-pink-glow), transparent 26%);
  mix-blend-mode: screen;
  opacity: .92;
}

[data-theme="dark"] .themed-disc::before,
[data-theme="dark"] .disc-graphic::before,
[data-theme="dark"] .release-card__disc::before,
[data-theme="dark"] .release-page__disc::before {
  background:
    conic-gradient(from 250deg, transparent 0 66%, rgba(58,16,37,.10) 70%, rgba(124,10,73,.58) 74%, rgba(176,9,99,.34) 79%, transparent 87%, transparent 100%),
    radial-gradient(ellipse at 73% 52%, rgba(124,10,73,.50), transparent 34%),
    conic-gradient(from 220deg, var(--release-disc-highlight-strong), transparent 16%, transparent 50%, var(--release-disc-highlight) 74%, transparent 88%, var(--release-disc-highlight-strong)),
    radial-gradient(circle at 34% 24%, var(--release-disc-highlight-strong), transparent 24%),
    radial-gradient(circle at 66% 72%, var(--release-disc-pink-glow), transparent 26%);
  mix-blend-mode: multiply;
  opacity: .76;
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) .themed-disc::before,
  :root:not([data-theme]) .disc-graphic::before,
  :root:not([data-theme]) .release-card__disc::before,
  :root:not([data-theme]) .release-page__disc::before {
    background:
      conic-gradient(from 250deg, transparent 0 66%, rgba(58,16,37,.10) 70%, rgba(124,10,73,.58) 74%, rgba(176,9,99,.34) 79%, transparent 87%, transparent 100%),
      radial-gradient(ellipse at 73% 52%, rgba(124,10,73,.50), transparent 34%),
      conic-gradient(from 220deg, var(--release-disc-highlight-strong), transparent 16%, transparent 50%, var(--release-disc-highlight) 74%, transparent 88%, var(--release-disc-highlight-strong)),
      radial-gradient(circle at 34% 24%, var(--release-disc-highlight-strong), transparent 24%),
      radial-gradient(circle at 66% 72%, var(--release-disc-pink-glow), transparent 26%);
    mix-blend-mode: multiply;
    opacity: .76;
  }
}

.disc-graphic::after,
.release-card__disc::after,
.release-page__disc::after,
.themed-disc::after {
  content: "";
  position: absolute;
  inset: 44%;
  border-radius: 50%;
  background: var(--release-disc-core);
  box-shadow:
    0 0 0 .2rem rgba(255,255,255,.48),
    0 0 0 .72rem var(--release-disc-ring-gold),
    0 0 0 1.58rem var(--release-disc-ring-accent),
    0 0 0 2.06rem rgba(255,255,255,.05);
}

.release-card__cover--fallback-disc,
.release-page__cover--fallback-disc,
.release-showcase__cover--fallback-disc {
  display: grid;
  place-items: center;
  aspect-ratio: 1;
  padding: clamp(1rem, 6%, 2.25rem);
  background: var(--fallback-disc-cover-bg);
  border: 1px solid var(--fallback-disc-cover-border);
}

.release-card__cover--fallback-disc {
  height: calc(100% - clamp(1.15rem, 3.5vw, 1.8rem));
}

.release-page__cover--fallback-disc,
.release-showcase__cover--fallback-disc {
  min-height: 0;
}

.themed-disc {
  position: relative;
}

.themed-disc--cover {
  width: min(88%, 22rem);
  max-width: 100%;
  animation: release-disc-smooth-spin 18s linear infinite;
  transform-origin: 50% 50%;
}

.release-card__cover--fallback-disc .themed-disc--cover {
  width: 82%;
  animation-duration: 22s;
}

.themed-disc--cover-large {
  width: min(82%, 440px);
}

.release-media-fallback__disc-wrap {
  display: grid;
  place-items: center;
  width: min(100%, 360px);
  aspect-ratio: 1;
  border-radius: calc(var(--radius-lg) - .35rem);
  background: var(--fallback-disc-cover-bg);
  border: 1px solid var(--fallback-disc-cover-border);
  box-shadow: 0 18px 48px rgba(20, 0, 14, .22);
}

.themed-disc--fallback-media {
  width: 74%;
  animation: release-disc-smooth-spin 20s linear infinite;
}

.release-card--no-cover:hover .release-card__cover--fallback-disc,
.release-card--no-cover:focus-within .release-card__cover--fallback-disc {
  transform: scale(1.015);
  filter: saturate(1.08) contrast(1.05);
}

@media (prefers-reduced-motion: reduce) {
  .themed-disc--cover,
  .themed-disc--fallback-media {
    animation: none !important;
  }
}

/* 2026-07-01 release detail disc rule: disc inside release always rotates, with theme-aware pink motion glints */
:root,
[data-theme="light"] {
  --release-disc-motion-glint-strong: rgba(255, 106, 188, .46);
  --release-disc-motion-glint-soft: rgba(255, 174, 219, .28);
  --release-disc-motion-glow: rgba(255, 104, 190, .22);
  --release-disc-motion-rim: rgba(255, 128, 204, .42);
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --release-disc-motion-glint-strong: rgba(176, 9, 99, .34); /* #b00963 */
    --release-disc-motion-glint-soft: rgba(124, 10, 73, .30); /* #7c0a49 */
    --release-disc-motion-glow: rgba(58, 16, 37, .28); /* #3a1025 */
    --release-disc-motion-rim: rgba(124, 10, 73, .28); /* #7c0a49 */
  }
}

[data-theme="dark"] {
  --release-disc-motion-glint-strong: rgba(176, 9, 99, .34); /* #b00963 */
  --release-disc-motion-glint-soft: rgba(124, 10, 73, .30); /* #7c0a49 */
  --release-disc-motion-glow: rgba(58, 16, 37, .28); /* #3a1025 */
  --release-disc-motion-rim: rgba(124, 10, 73, .28); /* #7c0a49 */
}

.release-detail .release-page__disc,
.release-detail .release-page-visual:hover .release-page__disc,
.release-detail .release-page-visual:focus-within .release-page__disc {
  translate: 0 0 !important;
  transform: none !important;
  rotate: 0deg;
  animation: release-disc-smooth-spin 18s linear infinite !important;
  transform-origin: 50% 50%;
  will-change: rotate;
}

.release-detail .release-page__cover--fallback-disc .themed-disc--cover,
.release-detail .release-page__cover--fallback-disc .themed-disc--cover-large {
  animation: release-disc-smooth-spin 18s linear infinite !important;
  transform: none !important;
  rotate: 0deg;
  transform-origin: 50% 50%;
  will-change: rotate;
}

.release-detail .release-page__disc::before,
.release-detail .release-page__cover--fallback-disc .themed-disc::before,
.release-detail .release-media-fallback__disc-wrap .themed-disc::before {
  border: 1px solid var(--release-disc-motion-rim);
  background:
    conic-gradient(from 14deg,
      transparent 0 8%,
      var(--release-disc-motion-glint-strong) 9% 10.25%,
      transparent 11.75% 43%,
      var(--release-disc-motion-glint-soft) 45% 46.5%,
      transparent 48% 71%,
      var(--release-disc-motion-glint-strong) 72% 73%,
      transparent 74.5% 100%),
    radial-gradient(circle at 31% 22%, var(--release-disc-highlight-strong), transparent 22%),
    radial-gradient(circle at 69% 78%, var(--release-disc-motion-glow), transparent 24%),
    conic-gradient(from 220deg, var(--release-disc-highlight-strong), transparent 16%, transparent 50%, var(--release-disc-highlight), transparent 88%, var(--release-disc-highlight-strong));
  mix-blend-mode: screen;
  opacity: .92;
}

[data-theme="dark"] .release-detail .release-page__disc::before,
[data-theme="dark"] .release-detail .release-page__cover--fallback-disc .themed-disc::before,
[data-theme="dark"] .release-detail .release-media-fallback__disc-wrap .themed-disc::before {
  mix-blend-mode: screen;
  opacity: .64;
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) .release-detail .release-page__disc::before,
  :root:not([data-theme]) .release-detail .release-page__cover--fallback-disc .themed-disc::before,
  :root:not([data-theme]) .release-detail .release-media-fallback__disc-wrap .themed-disc::before {
    mix-blend-mode: screen;
    opacity: .64;
  }
}

.release-detail .release-page__disc,
.release-detail .release-page__cover--fallback-disc .themed-disc,
.release-detail .release-media-fallback__disc-wrap .themed-disc {
  box-shadow:
    var(--release-disc-inset-dark),
    var(--release-disc-inset-light),
    var(--release-disc-shadow),
    0 0 30px var(--release-disc-motion-glow),
    0 0 70px rgba(124, 10, 73, .08);
}

.release-page__cover--fallback-disc {
  background:
    radial-gradient(circle at 18% 10%, var(--release-disc-motion-glow), transparent 32%),
    radial-gradient(circle at 86% 84%, rgba(124, 10, 73, .10), transparent 34%),
    var(--fallback-disc-cover-bg);
}

@media (prefers-reduced-motion: reduce) {
  .release-detail .release-page__disc,
  .release-detail .release-page-visual:hover .release-page__disc,
  .release-detail .release-page-visual:focus-within .release-page__disc,
  .release-detail .release-page__cover--fallback-disc .themed-disc--cover,
  .release-detail .release-page__cover--fallback-disc .themed-disc--cover-large {
    animation: none !important;
    rotate: 0deg !important;
    will-change: auto;
  }
}

/* 2026-07-01 dark theme white vinyl correction:
   keep the dark-theme disc light/white, but make its pink layer a deeper translucent magenta.
   Light theme stays on the black vinyl treatment. */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --release-disc-core: #09050a;
    --release-disc-ring-gold: #f0cd84;
    --release-disc-ring-accent: #b00963;
    --release-disc-a: #ffffff;
    --release-disc-b: #cfd3dc;
    --release-disc-c: #f2f3f6;
    --release-disc-highlight: rgba(124, 10, 73, .48);
    --release-disc-highlight-strong: rgba(176, 9, 99, .78);
    --release-disc-groove-a: rgba(58, 16, 37, .18);
    --release-disc-groove-b: rgba(124, 10, 73, .085);
    --release-disc-shade: rgba(58, 16, 37, .30);
    --release-disc-pink-glow: rgba(124, 10, 73, .66);
    --release-disc-inner-ring: #dfe2e8;
    --release-disc-shadow: 0 28px 82px rgba(255, 192, 221, .13), 0 24px 72px rgba(0, 0, 0, .34), 0 0 46px rgba(124, 10, 73, .12);
    --release-disc-inset-dark: inset -22px -18px 36px rgba(10, 8, 12, .16);
    --release-disc-inset-light: inset 18px 16px 28px rgba(255, 255, 255, .64);
    --fallback-disc-cover-bg: radial-gradient(circle at 22% 10%, rgba(124, 10, 73, .34), transparent 38%), radial-gradient(circle at 82% 88%, rgba(176, 9, 99, .16), transparent 42%), linear-gradient(145deg, rgba(58, 16, 37, .90), rgba(12, 5, 10, .86));
    --fallback-disc-cover-border: rgba(176, 9, 99, .24);
  }

  :root:not([data-theme]) .themed-disc::before,
  :root:not([data-theme]) .disc-graphic::before,
  :root:not([data-theme]) .release-card__disc::before,
  :root:not([data-theme]) .release-page__disc::before {
    background:
      conic-gradient(from 250deg, transparent 0 63%, rgba(58, 16, 37, .16) 68%, rgba(124, 10, 73, .72) 73%, rgba(176, 9, 99, .52) 80%, transparent 88%, transparent 100%),
      radial-gradient(ellipse at 73% 52%, rgba(124, 10, 73, .58), transparent 34%),
      conic-gradient(from 220deg, rgba(176, 9, 99, .78), transparent 16%, transparent 50%, rgba(124, 10, 73, .48) 74%, transparent 88%, rgba(176, 9, 99, .78)),
      radial-gradient(circle at 34% 24%, rgba(176, 9, 99, .42), transparent 24%),
      radial-gradient(circle at 66% 72%, rgba(124, 10, 73, .52), transparent 26%);
    mix-blend-mode: multiply;
    opacity: .88;
  }

  :root:not([data-theme]) .release-detail .release-page__disc::before,
  :root:not([data-theme]) .release-detail .release-page__cover--fallback-disc .themed-disc::before,
  :root:not([data-theme]) .release-detail .release-media-fallback__disc-wrap .themed-disc::before {
    mix-blend-mode: multiply;
    opacity: .88;
  }
}

[data-theme="dark"] {
  --release-disc-core: #09050a;
  --release-disc-ring-gold: #f0cd84;
  --release-disc-ring-accent: #b00963;
  --release-disc-a: #ffffff;
  --release-disc-b: #cfd3dc;
  --release-disc-c: #f2f3f6;
  --release-disc-highlight: rgba(124, 10, 73, .48);
  --release-disc-highlight-strong: rgba(176, 9, 99, .78);
  --release-disc-groove-a: rgba(58, 16, 37, .18);
  --release-disc-groove-b: rgba(124, 10, 73, .085);
  --release-disc-shade: rgba(58, 16, 37, .30);
  --release-disc-pink-glow: rgba(124, 10, 73, .66);
  --release-disc-inner-ring: #dfe2e8;
  --release-disc-shadow: 0 28px 82px rgba(255, 192, 221, .13), 0 24px 72px rgba(0, 0, 0, .34), 0 0 46px rgba(124, 10, 73, .12);
  --release-disc-inset-dark: inset -22px -18px 36px rgba(10, 8, 12, .16);
  --release-disc-inset-light: inset 18px 16px 28px rgba(255, 255, 255, .64);
  --fallback-disc-cover-bg: radial-gradient(circle at 22% 10%, rgba(124, 10, 73, .34), transparent 38%), radial-gradient(circle at 82% 88%, rgba(176, 9, 99, .16), transparent 42%), linear-gradient(145deg, rgba(58, 16, 37, .90), rgba(12, 5, 10, .86));
  --fallback-disc-cover-border: rgba(176, 9, 99, .24);
}

[data-theme="dark"] .themed-disc::before,
[data-theme="dark"] .disc-graphic::before,
[data-theme="dark"] .release-card__disc::before,
[data-theme="dark"] .release-page__disc::before {
  background:
    conic-gradient(from 250deg, transparent 0 63%, rgba(58, 16, 37, .16) 68%, rgba(124, 10, 73, .72) 73%, rgba(176, 9, 99, .52) 80%, transparent 88%, transparent 100%),
    radial-gradient(ellipse at 73% 52%, rgba(124, 10, 73, .58), transparent 34%),
    conic-gradient(from 220deg, rgba(176, 9, 99, .78), transparent 16%, transparent 50%, rgba(124, 10, 73, .48) 74%, transparent 88%, rgba(176, 9, 99, .78)),
    radial-gradient(circle at 34% 24%, rgba(176, 9, 99, .42), transparent 24%),
    radial-gradient(circle at 66% 72%, rgba(124, 10, 73, .52), transparent 26%);
  mix-blend-mode: multiply;
  opacity: .88;
}

[data-theme="dark"] .release-detail .release-page__disc::before,
[data-theme="dark"] .release-detail .release-page__cover--fallback-disc .themed-disc::before,
[data-theme="dark"] .release-detail .release-media-fallback__disc-wrap .themed-disc::before {
  mix-blend-mode: multiply;
  opacity: .88;
}

/* 2026-07-01 header/footer entities and icon-only social contract */
.sr-only,
.social-mini__link .sr-only,
.footer-social-round .sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.nav-link {
  gap: .55rem;
}

.nav-link i {
  width: 1.05rem;
  flex: 0 0 1.05rem;
  text-align: center;
  font-size: .95rem;
  line-height: 1;
  opacity: .82;
}

.nav-link:hover i,
.nav-link[aria-current="page"] i {
  opacity: 1;
}

.social-mini--icons .social-mini__link,
.footer-social-round {
  position: relative;
}

.social-mini__link i,
.theme-toggle i {
  font-size: 1rem;
  line-height: 1;
}

.social-mini__link[title="YouTube"] { color: #e62117; }
.social-mini__link[title="Telegram"] { color: #229ed9; }
.social-mini__link[title="VK"] { color: #4c75a3; }

.social-mini__link:hover {
  color: #fff;
}

.footer__columns--template-ready {
  grid-template-columns: minmax(300px, 1.35fr) minmax(170px, .62fr) minmax(210px, .72fr) minmax(260px, .9fr);
  gap: clamp(1.25rem, 2.5vw, 2rem);
}

.footer-module {
  min-width: 0;
}

.footer__brand.footer-module--brand {
  max-width: none;
  padding: clamp(1rem, 2vw, 1.25rem);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--radius-xl);
  background: linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.035));
  box-shadow: 0 26px 70px rgba(0,0,0,.18);
}

.footer-entity-strip {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .62rem;
  margin-top: .2rem;
}

.footer-entity-pill {
  display: grid;
  grid-template-columns: 2.05rem 1fr;
  grid-template-areas:
    "icon value"
    "icon label";
  align-items: center;
  column-gap: .65rem;
  min-height: 3.05rem;
  padding: .62rem .72rem;
  border: 1px solid rgba(255,255,255,.11);
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.065);
}

.footer-entity-pill i {
  grid-area: icon;
  display: inline-grid;
  place-items: center;
  width: 2.05rem;
  height: 2.05rem;
  border-radius: var(--radius-full);
  color: #fff;
  background: rgba(255, 46, 154, .36);
  box-shadow: 0 14px 28px rgba(0,0,0,.18);
}

.footer-entity-pill strong {
  grid-area: value;
  color: #fff;
  font-size: 1.05rem;
  line-height: 1;
}

.footer-entity-pill span {
  grid-area: label;
  color: rgba(255,255,255,.62);
  font-size: .78rem;
  line-height: 1.2;
}

.footer-list--icons {
  gap: .52rem;
}

.footer-list--icons a {
  display: grid;
  grid-template-columns: 1.65rem 1fr;
  align-items: center;
  gap: .62rem;
  min-height: 2.35rem;
  padding: .36rem .5rem;
  margin-left: -.5rem;
  border-radius: var(--radius-full);
}

.footer-list--icons a:hover {
  color: #fff;
  background: rgba(255,255,255,.08);
}

.footer-list--icons i {
  display: inline-grid;
  place-items: center;
  width: 1.65rem;
  height: 1.65rem;
  border-radius: var(--radius-full);
  color: #fff;
  background: rgba(255, 46, 154, .25);
  font-size: .8rem;
}

.footer-icon-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 2.75rem));
  gap: .7rem;
}

.site-footer .footer-social-round--platform,
.site-footer .footer-social-round--platform:nth-child(n) {
  background: rgba(255,255,255,.08);
}

.site-footer .footer-social-round--platform:hover {
  background: var(--pink-650);
}

.footer__bottom--template-ready {
  margin-top: -.5rem;
}

@media (min-width: 920px) {
  .primary-nav {
    position: static;
    display: block;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    transform: none;
    opacity: 1;
    visibility: visible;
  }

  .nav-list {
    display: flex;
    align-items: center;
    gap: .25rem;
  }

  .nav-link {
    min-height: 2.65rem;
    padding: .72rem .92rem;
    white-space: nowrap;
  }

  .nav-toggle {
    display: none;
  }
}

@media (max-width: 1180px) {
  .footer__columns--template-ready {
    grid-template-columns: minmax(280px, 1.2fr) repeat(2, minmax(180px, .8fr));
  }

  .footer-module--listen {
    grid-column: 1 / -1;
  }

  .footer-icon-grid {
    grid-template-columns: repeat(8, minmax(0, 2.75rem));
  }
}

@media (max-width: 860px) {
  .footer__columns--template-ready {
    grid-template-columns: 1fr;
  }

  .footer-module--listen {
    grid-column: auto;
  }

  .footer-icon-grid {
    grid-template-columns: repeat(4, minmax(0, 2.75rem));
  }
}

@media (max-width: 520px) {
  .footer-entity-strip {
    grid-template-columns: 1fr;
  }

  .footer__bottom--template-ready {
    align-items: flex-start;
  }
}

/* 2026-07-01 full social set in header/footer */
.social-mini {
  max-width: min(42vw, 23rem);
  overflow-x: auto;
  scrollbar-width: none;
}

.social-mini::-webkit-scrollbar { display: none; }

.social-mini--icons .social-mini__link {
  width: 2.35rem;
  height: 2.35rem;
  flex: 0 0 2.35rem;
}

.social-mini__link[title="Spotify"] { color: #1db954; }
.social-mini__link[title="Звук"] { color: #ff5a1f; }
.social-mini__link[title="Яндекс Музыка"] { color: #ffcc00; }
.social-mini__link[title="МТС Музыка"] { color: #e30611; }
.social-mini__link[title="Apple Music"] { color: #111; }

[data-theme="dark"] .social-mini__link[title="Apple Music"] { color: #fff; }

@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) .social-mini__link[title="Apple Music"] { color: #fff; }
}

.site-footer .footer-social-round:nth-child(5) { background: #ff5a1f; }
.site-footer .footer-social-round:nth-child(6) { background: #ffcc00; color: #111; }
.site-footer .footer-social-round:nth-child(7) { background: #e30611; }
.site-footer .footer-social-round:nth-child(8) { background: #111; }

@media (max-width: 1180px) {
  .social-mini { max-width: min(34vw, 15.5rem); }
  .social-mini--icons .social-mini__link {
    width: 2.15rem;
    height: 2.15rem;
    flex-basis: 2.15rem;
  }
}


/* Catalog filters: kept from proofing pass without changing the previous page concept. */
.catalog-tools {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(140px, .28fr) minmax(150px, .3fr) auto auto;
  gap: 14px;
  align-items: end;
  margin: 26px 0 28px;
  padding: clamp(16px, 2vw, 22px);
  border-radius: 24px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(255,255,255,.3);
  box-shadow: var(--shadow-sm, 0 10px 30px rgba(0,0,0,.08));
}

.catalog-field {
  display: grid;
  gap: 8px;
  font-weight: 800;
  color: var(--text, #1a1220);
}

.catalog-field span {
  font-size: .82rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--muted, #6f6472);
}

.catalog-field input,
.catalog-field select {
  min-height: 48px;
  width: 100%;
  border: 1px solid var(--line, rgba(0,0,0,.12));
  border-radius: 14px;
  padding: 0 14px;
  background: var(--surface, #fff);
  color: var(--text, #1a1220);
  font: inherit;
}

.catalog-field--search input {
  padding-left: 16px;
}

.catalog-reset {
  min-height: 48px;
  align-self: end;
}

.catalog-tools__count {
  margin: 0;
  align-self: center;
  color: var(--muted, #6f6472);
  white-space: nowrap;
}

@media (max-width: 980px) {
  .catalog-tools {
    grid-template-columns: 1fr 1fr;
  }

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

@media (max-width: 640px) {
  .catalog-tools {
    grid-template-columns: 1fr;
  }
}

/* 2026-07-02: polished catalog filters, custom selects and stable filtered grids. */

.catalog-tools:focus-within,
.catalog-tools.is-select-open {
  z-index: 1800;
}

.catalog-tools + .release-grid__message,
.catalog-tools ~ .release-grid--catalog {
  position: relative;
  z-index: 1;
}

.catalog-tools {
  position: relative;
  z-index: 60;
  overflow: visible;
  --catalog-panel-bg: rgba(255, 255, 255, .74);
  --catalog-panel-border: rgba(178, 0, 102, .15);
  --catalog-panel-shadow: 0 22px 64px rgba(155, 7, 87, .12);
  --catalog-field-bg: rgba(255, 255, 255, .88);
  --catalog-field-border: rgba(178, 0, 102, .18);
  --catalog-field-border-active: rgba(241, 15, 136, .70);
  --catalog-field-shadow: 0 12px 32px rgba(155, 7, 87, .08), inset 0 1px 0 rgba(255, 255, 255, .72);
  --catalog-menu-bg: rgba(255, 255, 255, .97);
  --catalog-menu-hover: rgba(241, 15, 136, .10);
  --catalog-menu-selected: rgba(241, 15, 136, .14);
  --catalog-icon-color: var(--pink-650);
  grid-template-columns: minmax(250px, 1fr) minmax(150px, .34fr) minmax(165px, .36fr) auto auto;
  gap: clamp(.75rem, 1.4vw, 1.1rem);
  align-items: end;
  padding: clamp(1.05rem, 2vw, 1.55rem);
  border-color: var(--catalog-panel-border);
  background: var(--catalog-panel-bg);
  box-shadow: var(--catalog-panel-shadow);
  backdrop-filter: blur(16px) saturate(1.1);
}

.catalog-field {
  position: relative;
  gap: .55rem;
  min-width: 0;
  color: var(--ink);
}

.catalog-field span {
  color: var(--pink-700);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .075em;
}

.catalog-field input,
.catalog-field select,
.catalog-select__button {
  min-height: 3.3rem;
  width: 100%;
  border: 1px solid var(--catalog-field-border);
  border-radius: 1.15rem;
  background: var(--catalog-field-bg);
  color: var(--ink);
  box-shadow: var(--catalog-field-shadow);
  transition: border-color .18s ease, box-shadow .18s ease, background-color .18s ease, transform .18s ease;
}

.catalog-field input,
.catalog-field select {
  padding: 0 1rem;
}

.catalog-field input::placeholder {
  color: color-mix(in srgb, var(--muted) 76%, transparent);
  opacity: 1;
}

.catalog-field input:focus,
.catalog-field select:focus,
.catalog-select__button:focus-visible,
.catalog-select.is-open .catalog-select__button {
  border-color: var(--catalog-field-border-active);
  box-shadow: 0 0 0 4px rgba(241, 15, 136, .13), var(--catalog-field-shadow);
}

.catalog-field--search::after {
  content: "";
  position: absolute;
  left: 1.05rem;
  bottom: 1.06rem;
  width: 1.05rem;
  height: 1.05rem;
  pointer-events: none;
  border: 2px solid var(--catalog-icon-color);
  border-radius: 50%;
  opacity: .92;
}

.catalog-field--search::before {
  content: "";
  position: absolute;
  left: 1.92rem;
  bottom: .98rem;
  width: .45rem;
  height: 2px;
  pointer-events: none;
  border-radius: 999px;
  background: var(--catalog-icon-color);
  transform: rotate(45deg);
  opacity: .92;
}

.catalog-field--search input {
  padding-left: 3.15rem;
}

.catalog-field--search input::-webkit-search-decoration,
.catalog-field--search input::-webkit-search-cancel-button,
.catalog-field--search input::-webkit-search-results-button,
.catalog-field--search input::-webkit-search-results-decoration {
  -webkit-appearance: none;
}

.catalog-field select {
  appearance: none;
  padding-right: 2.8rem;
  background-image:
    linear-gradient(45deg, transparent 50%, currentColor 50%),
    linear-gradient(135deg, currentColor 50%, transparent 50%);
  background-position:
    calc(100% - 1.35rem) 50%,
    calc(100% - 1rem) 50%;
  background-size: .38rem .38rem, .38rem .38rem;
  background-repeat: no-repeat;
}

.catalog-field--custom-select select.catalog-select-native {
  position: absolute;
  width: 1px;
  height: 1px;
  min-height: 0;
  margin: 0;
  padding: 0;
  border: 0;
  opacity: 0;
  pointer-events: none;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
}

.catalog-select {
  position: relative;
  z-index: 70;
}

.catalog-select.is-open {
  z-index: 1500;
}

.catalog-select__button {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: .75rem;
  padding: 0 3rem 0 1rem;
  text-align: left;
  font-weight: 900;
}

.catalog-select__icon {
  flex: 0 0 auto;
  width: 1.1rem;
  height: 1.1rem;
  color: var(--catalog-icon-color);
  opacity: .94;
}

.catalog-select__icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

.catalog-select__button::after {
  content: "";
  position: absolute;
  right: 1.15rem;
  top: 50%;
  width: .58rem;
  height: .58rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: translateY(-62%) rotate(45deg);
  transition: transform .18s ease;
  opacity: .75;
}

.catalog-select.is-open .catalog-select__button::after {
  transform: translateY(-35%) rotate(225deg);
}

.catalog-select__value {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.catalog-select__menu {
  position: absolute;
  z-index: 1600;
  inset: calc(100% + .55rem) 0 auto 0;
  display: grid;
  min-width: 100%;
  padding: .45rem;
  border: 1px solid var(--catalog-field-border);
  border-radius: 1.05rem;
  background: var(--catalog-menu-bg);
  box-shadow: 0 20px 52px rgba(70, 0, 42, .18);
  opacity: 0;
  transform: translateY(-.35rem) scale(.98);
  transform-origin: top center;
  pointer-events: none;
  transition: opacity .16s ease, transform .16s ease;
}

.catalog-select.is-open .catalog-select__menu {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.catalog-select__option {
  display: flex;
  align-items: center;
  width: 100%;
  min-height: 2.45rem;
  padding: .62rem .8rem;
  border-radius: .72rem;
  background: transparent;
  color: var(--ink);
  text-align: left;
  font-weight: 760;
  transition: background-color .16s ease, color .16s ease;
}

.catalog-select__option:hover,
.catalog-select__option:focus-visible {
  background: var(--catalog-menu-hover);
  color: var(--pink-700);
}

.catalog-select__option.is-selected {
  background: var(--catalog-menu-selected);
  color: var(--pink-650);
  font-weight: 920;
}

.catalog-reset {
  min-height: 3.3rem;
  padding-inline: 1.35rem;
  border-color: var(--catalog-field-border-active);
  color: var(--pink-650);
  background: color-mix(in srgb, var(--catalog-field-bg) 80%, var(--pink-100) 20%);
  box-shadow: var(--catalog-field-shadow);
}

.catalog-reset::before {
  content: "↻";
  display: inline-block;
  margin-right: .45rem;
  font-weight: 900;
  line-height: 1;
}

.catalog-tools__count {
  align-self: center;
  justify-self: end;
  font-weight: 780;
}

.catalog-tools__count strong {
  color: var(--pink-650);
}

.release-grid--catalog {
  position: relative;
  z-index: 1;
  --catalog-card-fixed: 24.5rem;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 19.75rem), 1fr));
  align-items: stretch;
}

.release-grid--catalog .release-card {
  min-width: 0;
  height: 100%;
}

.release-grid--catalog .release-card__media {
  width: 100%;
  aspect-ratio: 1;
}

@media (min-width: 1280px) {
  .release-grid--catalog.is-count-4plus {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .release-grid--catalog.is-count-3 {
    grid-template-columns: repeat(3, minmax(0, var(--catalog-card-fixed)));
    justify-content: start;
  }

  .release-grid--catalog.is-count-2 {
    grid-template-columns: repeat(2, minmax(0, var(--catalog-card-fixed)));
    justify-content: start;
  }

  .release-grid--catalog.is-count-1 {
    grid-template-columns: minmax(0, var(--catalog-card-fixed));
    justify-content: start;
  }
}

@media (min-width: 900px) and (max-width: 1279px) {
  .release-grid--catalog.is-count-3,
  .release-grid--catalog.is-count-4plus {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .release-grid--catalog.is-count-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: 52rem;
  }

  .release-grid--catalog.is-count-1 {
    grid-template-columns: minmax(0, min(100%, 24rem));
  }
}

@media (min-width: 620px) and (max-width: 899px) {
  .release-grid--catalog.is-count-1 {
    grid-template-columns: minmax(0, min(100%, 23rem));
  }

  .release-grid--catalog.is-count-2,
  .release-grid--catalog.is-count-3,
  .release-grid--catalog.is-count-4plus {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) .catalog-tools {
    --catalog-panel-bg: linear-gradient(145deg, rgba(43, 14, 31, .86), rgba(17, 7, 13, .78));
    --catalog-panel-border: rgba(255, 140, 198, .22);
    --catalog-panel-shadow: 0 22px 74px rgba(0, 0, 0, .34), inset 0 1px 0 rgba(255, 192, 221, .08);
    --catalog-field-bg: rgba(14, 6, 11, .72);
    --catalog-field-border: rgba(255, 140, 198, .25);
    --catalog-field-border-active: rgba(255, 109, 184, .82);
    --catalog-field-shadow: 0 16px 34px rgba(0, 0, 0, .24), inset 0 1px 0 rgba(255, 192, 221, .06);
    --catalog-menu-bg: linear-gradient(180deg, rgba(34, 11, 25, .98), rgba(18, 7, 14, .98));
    --catalog-menu-hover: rgba(255, 109, 184, .14);
    --catalog-menu-selected: rgba(255, 76, 167, .25);
  }
}

[data-theme="dark"] .catalog-tools {
  --catalog-panel-bg: linear-gradient(145deg, rgba(43, 14, 31, .86), rgba(17, 7, 13, .78));
  --catalog-panel-border: rgba(255, 140, 198, .22);
  --catalog-panel-shadow: 0 22px 74px rgba(0, 0, 0, .34), inset 0 1px 0 rgba(255, 192, 221, .08);
  --catalog-field-bg: rgba(14, 6, 11, .72);
  --catalog-field-border: rgba(255, 140, 198, .25);
  --catalog-field-border-active: rgba(255, 109, 184, .82);
  --catalog-field-shadow: 0 16px 34px rgba(0, 0, 0, .24), inset 0 1px 0 rgba(255, 192, 221, .06);
  --catalog-menu-bg: linear-gradient(180deg, rgba(34, 11, 25, .98), rgba(18, 7, 14, .98));
  --catalog-menu-hover: rgba(255, 109, 184, .14);
  --catalog-menu-selected: rgba(255, 76, 167, .25);
}

@media (max-width: 980px) {
  .catalog-tools {
    grid-template-columns: 1fr 1fr;
  }

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

  .catalog-tools__count {
    justify-self: start;
  }
}

@media (max-width: 640px) {
  .catalog-tools {
    grid-template-columns: 1fr;
  }

  .catalog-select__menu {
    position: static;
    margin-top: .5rem;
  }
}

@media (max-width: 640px) {
  .catalog-select__menu {
    position: absolute;
    margin-top: 0;
  }
}

/* 2026-07-02 — theme-aware scrollbar polish */
:root,
[data-theme="light"] {
  --scrollbar-size: 12px;
  --scrollbar-radius: 999px;
  --scrollbar-track: rgba(255, 244, 250, .86);
  --scrollbar-track-solid: #fff4fa;
  --scrollbar-thumb: #ff8cc6;
  --scrollbar-thumb-start: #ffc0dd;
  --scrollbar-thumb-end: #f10f88;
  --scrollbar-thumb-hover-start: #ff8cc6;
  --scrollbar-thumb-hover-end: #d50b78;
  --scrollbar-thumb-active-start: #ff58ad;
  --scrollbar-thumb-active-end: #9b0757;
  --scrollbar-corner: #fff4fa;
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --scrollbar-track: rgba(20, 7, 15, .94);
    --scrollbar-track-solid: #14070f;
    --scrollbar-thumb: #7c0a49;
    --scrollbar-thumb-start: #3a1025;
    --scrollbar-thumb-end: #ff2e9a;
    --scrollbar-thumb-hover-start: #7c0a49;
    --scrollbar-thumb-hover-end: #ff6db8;
    --scrollbar-thumb-active-start: #b00963;
    --scrollbar-thumb-active-end: #ffc0dd;
    --scrollbar-corner: #14070f;
  }
}

[data-theme="dark"] {
  --scrollbar-track: rgba(20, 7, 15, .94);
  --scrollbar-track-solid: #14070f;
  --scrollbar-thumb: #7c0a49;
  --scrollbar-thumb-start: #3a1025;
  --scrollbar-thumb-end: #ff2e9a;
  --scrollbar-thumb-hover-start: #7c0a49;
  --scrollbar-thumb-hover-end: #ff6db8;
  --scrollbar-thumb-active-start: #b00963;
  --scrollbar-thumb-active-end: #ffc0dd;
  --scrollbar-corner: #14070f;
}

html {
  scrollbar-gutter: stable;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

body,
.primary-nav,
.catalog-select__menu {
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

::-webkit-scrollbar {
  width: var(--scrollbar-size);
  height: var(--scrollbar-size);
}

::-webkit-scrollbar-track {
  background: var(--scrollbar-track);
}

::-webkit-scrollbar-thumb {
  min-height: 3rem;
  border: 3px solid var(--scrollbar-track-solid);
  border-radius: var(--scrollbar-radius);
  background: linear-gradient(180deg, var(--scrollbar-thumb-start), var(--scrollbar-thumb-end));
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .18), 0 0 18px rgba(255, 46, 154, .14);
}

::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, var(--scrollbar-thumb-hover-start), var(--scrollbar-thumb-hover-end));
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .26), 0 0 22px rgba(255, 46, 154, .22);
}

::-webkit-scrollbar-thumb:active {
  background: linear-gradient(180deg, var(--scrollbar-thumb-active-start), var(--scrollbar-thumb-active-end));
}

::-webkit-scrollbar-corner {
  background: var(--scrollbar-corner);
}

.catalog-select__menu {
  max-height: min(18rem, calc(100vh - 14rem));
  overflow-y: auto;
  scrollbar-gutter: stable;
}

.catalog-select__menu::-webkit-scrollbar,
.primary-nav::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

.catalog-select__menu::-webkit-scrollbar-thumb,
.primary-nav::-webkit-scrollbar-thumb {
  border-width: 2px;
}
