:root {
  --ink: #1b0702;
  --cream: #efe8d7;
  --paper: #fff7e8;
  --red: #a94f28;
  --gold: #c67a4c;
  --green: #8fd68f;
  --chrome: #34260f;
  --muted: #6f6048;
  --line: #d2b893;
}

/* Hi-fi dark listening-room theme */
:root {
  --ink: #f3eadb;
  --cream: #090908;
  --paper: #171512;
  --red: #c36a3f;
  --gold: #d19a53;
  --green: #f08a36;
  --chrome: #050504;
  --muted: #a89c8b;
  --line: rgba(209,154,83,.34);
  --dark-bg: #090908;
  --dark-panel: #15130f;
  --dark-panel-2: #1e1a14;
  --tube: #ff8a2a;
  --tube-soft: rgba(255,138,42,.22);
}
html { background: var(--dark-bg); }
body {
  color: var(--ink);
  background:
    radial-gradient(circle at 80% 0%, rgba(255,138,42,.11), transparent 30rem),
    radial-gradient(circle at 10% 18%, rgba(60,91,126,.18), transparent 28rem),
    linear-gradient(180deg,#080807 0%,#11100d 42%,#080807 100%);
}
.collection-banner {
  min-height: clamp(240px,33vw,430px);
  border-bottom: 1px solid rgba(209,154,83,.55);
  background:
    linear-gradient(90deg,rgba(0,0,0,.9) 0%,rgba(0,0,0,.58) 38%,rgba(0,0,0,.18) 78%),
    url("/images/hifi-turntable-hero-desktop.webp") 58% 58%/cover no-repeat;
  box-shadow: inset 0 -90px 120px rgba(0,0,0,.74), 0 18px 55px rgba(0,0,0,.45);
}
.collection-banner::after {
  background:
    radial-gradient(ellipse at 70% 62%,rgba(255,142,52,.18),transparent 28%),
    linear-gradient(180deg,rgba(0,0,0,.1),rgba(0,0,0,.72));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04), inset 0 -32px 60px rgba(0,0,0,.75);
}
.collection-banner-link {
  align-items: flex-start;
  max-width: min(92%,1180px);
  margin: 0;
  padding-left: clamp(28px,8vw,150px);
  color: #fff5e7;
  text-align: left;
  text-shadow: 0 3px 20px rgba(0,0,0,.9);
}
.collection-banner-kicker { color: var(--tube); letter-spacing: .18em; }
.collection-banner-title { max-width: 650px; letter-spacing: -.045em; }
.collection-banner-title em { color: var(--tube); text-shadow: 0 0 22px rgba(255,138,42,.35); }
.collection-banner-title strong { color: #f7ead8; }
.collection-banner-rule {
  margin-left: 0;
  background: linear-gradient(90deg,var(--tube),rgba(209,154,83,.75),transparent);
  box-shadow: 0 0 22px rgba(255,138,42,.38);
}
.collection-banner-subtitle { color: #d9c9b4; font-size: clamp(12px,1.18vw,16px); }
main { background: transparent; }
.stats {
  border-top: 1px solid rgba(255,255,255,.05);
  border-bottom: 1px solid rgba(209,154,83,.28);
  background: linear-gradient(90deg,#070706,#17130f 50%,#090807);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 12px 34px rgba(0,0,0,.35);
}
.stats strong { color: var(--tube); text-shadow: 0 0 18px rgba(255,138,42,.32); }
.stats span { color: #cab9a1; }
.catalogue { background: transparent; }
.toolbar {
  background: linear-gradient(90deg,#080807,#17130e 55%,#080807) !important;
  border-bottom: 1px solid rgba(209,154,83,.22);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 12px 34px rgba(0,0,0,.36) !important;
}
.search-row .artist-only-option,
.search-row input,
.toolbar select,
.sort-control select,
.view-switcher button,
#mobile-filters,
.filter-dropdown-trigger,
#pagination button {
  color: #f3eadb;
  border-color: rgba(209,154,83,.34) !important;
  background: linear-gradient(#211d17,#14120f) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 3px 0 rgba(0,0,0,.55), 0 8px 18px rgba(0,0,0,.24) !important;
}
.search-row input::placeholder { color: #8f8170; }
.artist-only-option { color: #d0bfa8; }
.search-submit,
.sort-control label,
.view-switcher button.active,
#mobile-filters.has-active-filters,
#pagination button.active,
#search-form button,
.primary {
  color: #140b05 !important;
  border-color: #9b4f20 !important;
  background: linear-gradient(#ffad62,var(--tube)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.34), 0 3px 0 #7e3b14, 0 0 22px rgba(255,138,42,.24) !important;
}
.search-reset,
.search-row .search-reset {
  color: #160c06 !important;
  border-color: #9b4f20 !important;
  background: linear-gradient(#e8b36e,var(--gold)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.28), 0 3px 0 #7e4f1d, 0 8px 18px rgba(0,0,0,.25) !important;
}
.chart-filter,
.graph-criteria {
  color: #f3eadb !important;
  border-color: rgba(209,154,83,.42);
  background: linear-gradient(145deg,#201b14,#14110d 58%,#0d0b09) !important;
  box-shadow: inset 1px 1px 0 rgba(255,255,255,.06), inset -1px -1px 0 rgba(0,0,0,.62), 0 4px 0 #070605, 0 12px 28px rgba(0,0,0,.38) !important;
}
.filters,
.filter-dropdown-panel,
.style-subdivision-panel {
  color: #f3eadb;
  border-color: rgba(209,154,83,.38);
  background: rgba(18,16,13,.98);
  box-shadow: 0 22px 55px rgba(0,0,0,.56);
}
.filters h2,
.graphics-intro h2,
.playlist-heading h2,
.feedback-copy h2,
.feedback-feed h3 { color: #f7ead8; }
.filters > div button,
.filter-dropdown-trigger strong,
.card-copy p,
.card-copy h4,
.playlist-item p,
.discogs-link,
.footer-contact a,
.protected-contact { color: var(--tube); }
.filter-dropdown-panel button,
.style-subdivision-panel button { color: #f3eadb; }
.filter-dropdown-panel button:hover,
.filter-dropdown-panel button:focus-visible,
.filter-dropdown-panel button.selected {
  color: var(--tube);
  background: rgba(255,138,42,.12);
}
.grid-loading,
.empty,
.feedback-copy,
.feedback-feed,
.feedback-form,
.feedback-item,
.playlist-item,
.view-list article {
  color: #f3eadb;
  border-color: rgba(209,154,83,.28);
  background: rgba(20,18,14,.88);
  box-shadow: 0 12px 30px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.04);
}
.cover {
  border-color: rgba(209,154,83,.34);
  background: #0d0c0a;
  box-shadow: 0 12px 30px rgba(0,0,0,.48);
}
.result-card:hover .cover,
.result-card:focus-visible .cover {
  border-color: var(--tube);
  box-shadow: 0 14px 36px rgba(0,0,0,.54), 0 0 0 3px rgba(255,138,42,.18), 0 0 26px rgba(255,138,42,.2);
}
.card-copy h3,
.playlist-item h3 { color: #f4eadb; }
.card-copy span,
.feedback-copy p:not(.eyebrow),
.feedback-item time,
.feedback-item > span,
dt,
.brand small,
.filter-dropdown-empty,
.style-subdivision-empty,
.grid-loading span:last-child,
footer { color: var(--muted); }
.collection-graphics {
  background:
    linear-gradient(rgba(9,9,8,.78),rgba(9,9,8,.9)),
    url("/images/hifi-room-desktop.webp") center 58%/cover fixed no-repeat;
}
.graphics-window {
  border-color: rgba(209,154,83,.3);
  background: rgba(15,14,12,.9);
  box-shadow: 0 18px 55px rgba(0,0,0,.48), inset 0 1px 0 rgba(255,255,255,.04);
  backdrop-filter: blur(2px);
}
.graphics-intro-image img {
  filter: saturate(1.08) contrast(1.08) drop-shadow(0 10px 18px rgba(0,0,0,.44));
  mix-blend-mode: normal;
}
.year-chart .axis,
.year-chart .ticks line { stroke: rgba(209,154,83,.3); }
.year-chart text,
.style-table-header { fill: var(--muted); color: var(--muted); }
.year-guides line { stroke: rgba(209,154,83,.15); }
.style-category-trigger { color: #f3eadb; }
.style-category-trigger:hover,
.style-category-trigger:focus,
.style-category.selected .style-category-trigger {
  color: #fff4e6;
  background: rgba(255,138,42,.12);
}
.style-category-trigger > div { background: #0d0b09; }
.style-selection-count,
.style-category-trigger > strong { color: #d9c9b4; }
.feedback-section,
.jukebox-playlist,
footer {
  border-top-color: rgba(209,154,83,.25);
  background: linear-gradient(180deg,#0f0e0c,#090908);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.feedback-form input:not([type="checkbox"]),
.feedback-form textarea {
  color: #f3eadb;
  border-color: rgba(209,154,83,.34);
  background: #100f0d;
}
dialog { background: #0b0a08; }
dialog::backdrop { background: rgba(0,0,0,.82); backdrop-filter: blur(3px); }
.close,
.feedback-close {
  color: #120a05;
  background: #f4e4ce;
}
#details {
  border-color: rgba(209,154,83,.42) !important;
  background: #0c0b09 !important;
}
.detail-cover { background: radial-gradient(circle at 50% 42%,#211912 0%,#080706 66%) !important; }
.detail-info {
  color: #f3eadb;
  border-left-color: rgba(209,154,83,.28) !important;
  background: rgba(18,16,13,.96) !important;
}
.detail-layout h2,
dd { color: #f7ead8; }
.detail-layout h3,
.side-tracks strong { color: var(--tube); }
.side-tracks { color: #d9c9b4; }
dl,
dl div,
.detail-info dl,
.detail-info dl div { border-color: rgba(209,154,83,.22) !important; }
.notes { background: rgba(255,138,42,.07); }
.detail-playlist-button {
  color: #170b04;
  border-color: #9b4f20;
  background: linear-gradient(#ffad62,var(--tube));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.34), 0 3px 0 #7e3b14, 0 0 20px rgba(255,138,42,.22);
}
.detail-playlist-button.is-selected {
  color: #130a04;
  border-color: #a7712f;
  background: linear-gradient(#f2c478,var(--gold));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.32), 0 3px 0 #7c541f;
}
@media (max-width: 1180px) {
  .collection-banner {
    background:
      linear-gradient(90deg,rgba(0,0,0,.9) 0%,rgba(0,0,0,.58) 42%,rgba(0,0,0,.25) 86%),
      url("/images/hifi-turntable-hero-tablet.webp") 58% 58%/cover no-repeat;
  }
  .collection-graphics { background-image: linear-gradient(rgba(9,9,8,.8),rgba(9,9,8,.93)), url("/images/hifi-room-tablet.webp"); }
}
@media (max-width: 760px) {
  .collection-banner {
    min-height: 220px;
    background:
      linear-gradient(90deg,rgba(0,0,0,.9),rgba(0,0,0,.55)),
      url("/images/hifi-turntable-hero-mobile.webp") 61% 54%/cover no-repeat;
  }
  .collection-banner-link {
    align-items: flex-start;
    max-width: 100%;
    min-height: 220px;
    padding: 22px 20px;
    text-align: left;
  }
  .collection-banner-title { font-size: clamp(34px,10vw,48px); }
  .collection-banner-subtitle { max-width: 250px; }
  .collection-graphics {
    background-image: linear-gradient(rgba(9,9,8,.84),rgba(9,9,8,.96)), url("/images/hifi-room-mobile.webp");
    background-attachment: scroll;
  }
  .toolbar { background: linear-gradient(90deg,#080807,#17130e 55%,#080807) !important; }
  .chart-filter { background: linear-gradient(145deg,#201b14,#14110d 58%,#0d0b09) !important; }
}
* { box-sizing: border-box; }
body { margin: 0; color: var(--ink); background: var(--cream); font: 15px/1.5 Arial, sans-serif; }
button, input, select, textarea { font: inherit; }
header { display: flex; justify-content: space-between; align-items: center; padding: 18px clamp(22px,6vw,90px); border-bottom: 1px solid var(--line); background: rgba(255,250,240,.92); }
header a { color: var(--red); font-weight: 700; }
.collection-banner {
  position: relative;
  display: block;
  min-height: clamp(170px,21vw,285px);
  padding: 0;
  overflow: hidden;
  border-bottom: 4px solid var(--gold);
  background: var(--ink) url("/jukebox-collection-banner-desktop.webp?v=20260704-rightshift") center/cover no-repeat;
}
.collection-banner::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse at center,rgba(18,4,1,.5) 0%,rgba(18,4,1,.32) 38%,rgba(18,4,1,.08) 72%),
    linear-gradient(180deg,rgba(18,4,1,.16),rgba(18,4,1,.34));
  box-shadow: inset 0 -28px 48px rgba(27,7,2,.28), inset 0 0 70px rgba(18,4,1,.3);
}
.collection-banner-link {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(92%,980px);
  min-height: inherit;
  margin: 0 auto;
  padding: clamp(20px,3vw,42px) clamp(24px,7vw,112px);
  color: var(--paper);
  text-align: center;
  text-decoration: none;
  text-shadow: 0 3px 15px rgba(0,0,0,.8);
}
.collection-banner-kicker {
  color: var(--green);
  font-size: clamp(9px,1vw,13px);
  font-weight: 900;
  letter-spacing: .22em;
  text-transform: uppercase;
}
.collection-banner-title {
  display: block;
  margin-top: 7px;
  font: 700 clamp(36px,5.2vw,76px)/.88 Georgia, serif;
  letter-spacing: -.055em;
}
.collection-banner-title em { color: #eaa06d; font-weight: 400; }
.collection-banner-title strong {
  display: block;
  margin-top: .28em;
  color: var(--paper);
  font-size: .53em;
  font-style: italic;
  font-weight: 400;
  letter-spacing: .025em;
}
.collection-banner-rule {
  width: clamp(90px,18vw,260px);
  height: 3px;
  margin: 16px auto 10px;
  background: linear-gradient(90deg,var(--green),var(--gold),transparent);
}
.collection-banner-subtitle {
  color: #f1dfc0;
  font-size: clamp(10px,1.1vw,15px);
  font-weight: 600;
}
.collection-banner-subtitle a {
  color: inherit;
  font-weight: 800;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}
.collection-banner-subtitle a:hover,
.collection-banner-subtitle a:focus {
  color: var(--green);
  outline: none;
}
.brand { display: flex; align-items: center; gap: 12px; color: var(--ink); text-decoration: none; }
.brand strong, .brand small { display: block; }
.brand strong { font: 700 23px Georgia, serif; }
.brand small { color: var(--muted); }
.brand-disc { width: 43px; height: 43px; border: 10px solid var(--ink); border-radius: 50%; background: var(--green); box-shadow: inset 0 0 0 2px var(--cream), 0 0 18px rgba(143,214,143,.45); }
.hero {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, .72fr);
  align-items: center;
  gap: clamp(34px, 6vw, 90px);
  padding: 58px clamp(24px,8vw,130px);
  background: var(--paper);
}
.hero-copy { min-width: 0; }
.eyebrow { color: var(--red); font-size: 12px; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; }
h1 { margin: 4px 0 8px; font: 700 clamp(30px,4vw,52px)/.95 Georgia, serif; letter-spacing: -.035em; }
h1 em { color: var(--red); font-weight: 400; }
.hero-copy > p:not(.eyebrow) { max-width: 690px; color: var(--muted); font-size: 18px; }
.hero-photo {
  position: relative;
  width: min(100%, 410px);
  margin: 0;
  justify-self: end;
  overflow: hidden;
  border: 1px solid var(--line);
  background: var(--chrome);
  box-shadow: 18px 22px 0 #e4d4ba, 0 24px 60px rgba(27,7,2,.28), -8px 10px 28px rgba(143,214,143,.24);
}
.hero-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  box-shadow: inset 0 0 0 10px rgba(255,250,240,.14);
}
.hero-photo img {
  display: block;
  width: 100%;
  height: auto;
}
.toolbar { display: grid; grid-template-columns: auto minmax(320px,1fr) auto auto auto minmax(230px,auto); align-items: center; gap: 10px 12px; margin-bottom: 18px; }
#search-form { display: contents; margin: 0; padding: 0; border: 0; background: transparent; }
.search-row { display: flex; grid-column: 2; grid-row: 1; align-items: stretch; min-width: 0; }
.search-row .artist-only-option { flex: 0 0 auto; min-height: 42px; padding: 0 12px; border: 1px solid var(--line); border-right: 0; border-radius: 9px 0 0 9px; color: var(--ink); background: linear-gradient(#fffaf0,var(--paper)); box-shadow: inset 0 1px 0 rgba(255,255,255,.7), 0 3px 0 rgba(193,142,83,.38), 0 5px 9px rgba(52,38,15,.08); white-space: nowrap; }
.search-row input { flex: 1; min-width: 0; padding: 0 17px; border: 1px solid var(--line); border-left: 0; border-right: 0; border-radius: 0; background: white; }
#search-form button, .primary { padding: 0 23px; border: 0; color: white; background: var(--red); font-weight: 800; cursor: pointer; }
.toolbar button,
.toolbar select,
.sort-control label {
  font-family: Arial, sans-serif;
  font-weight: 800;
  letter-spacing: 0;
}
.control-raise,
#mobile-filters,
.view-switcher button,
.search-reset,
.search-submit,
.search-row .search-reset {
  border-radius: 9px;
  box-shadow: 0 3px 0 rgba(142,66,31,.8), 0 5px 9px rgba(52,38,15,.18);
  transition: transform .1s ease, box-shadow .1s ease, filter .15s ease;
}
.control-raise:active,
#mobile-filters:active,
.view-switcher button:active,
.search-reset:active,
.search-submit:active,
.search-row .search-reset:active {
  transform: translateY(2px);
  box-shadow: inset 0 1px 3px rgba(27,7,2,.22), 0 1px 0 rgba(142,66,31,.8), 0 2px 4px rgba(52,38,15,.16);
}
.search-submit { flex: 0 0 auto; border: 1px solid #93431f !important; border-radius: 0; }
.search-reset {
  flex: 0 0 auto;
  min-height: 42px;
  padding: 5px 11px !important;
  border: 1px solid #93431f !important;
  border-radius: 0 9px 9px 0 !important;
  color: white !important;
  background: linear-gradient(#d98b56, var(--gold)) !important;
  box-shadow: 0 3px 0 #8e421f, 0 5px 9px rgba(52,38,15,.22);
  font-size: 12px;
  font-weight: 800;
  text-shadow: 0 1px 1px rgba(27,7,2,.35);
  transition: transform .1s ease, box-shadow .1s ease, filter .15s ease;
}
.search-reset:hover { filter: brightness(1.04); }
.search-reset:active {
  transform: translateY(2px);
  box-shadow: inset 0 1px 3px rgba(27,7,2,.28), 0 1px 0 #8e421f, 0 2px 4px rgba(52,38,15,.16);
}
.search-reset-all:active {
  box-shadow: inset 0 1px 3px rgba(27,7,2,.28), 0 1px 0 #8e421f, 0 2px 4px rgba(52,38,15,.16);
}
.artist-only-option {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-height: 34px;
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
}
.artist-only-option input { width: 18px; height: 18px; margin: 0; accent-color: var(--red); }
.stats { display: grid; grid-template-columns: repeat(4,1fr); padding: 16px clamp(24px,8vw,130px); color: white; background: linear-gradient(90deg, var(--ink), var(--chrome)); }
.stats div { text-align: center; border-right: 0; }
.stats strong, .stats span { display: block; }
.stats strong { color: var(--green); font: 700 30px Georgia, serif; }
.catalogue { position: relative; display: block; padding: 0 0 54px; }
@media (min-width: 761px) {
  .toolbar { grid-template-columns: 128px minmax(520px,1fr) auto auto auto minmax(260px,auto); gap: 12px; align-items: center; }
  #mobile-filters { min-height: 52px; padding: 0 18px; font-size: 16px; }
  .search-row .artist-only-option { min-height: 52px; }
  .search-row input { min-height: 52px; font-size: 16px; }
  .search-submit { min-height: 52px; font-size: 16px; }
  .search-row .search-reset { min-height: 52px; }
  .toolbar #summary { display: none; font-size: 16px; }
  .view-switcher button { min-height: 48px; padding: 0 16px; font-size: 14px; }
  .toolbar select { min-height: 48px; font-size: 16px; }
  .sort-control label { font-size: 16px; }
}
.filters {
  display: none;
  position: absolute;
  z-index: 80;
  top: var(--filter-panel-top, 24px);
  left: var(--filter-panel-left, clamp(22px,6vw,90px));
  width: min(320px, calc(100vw - 44px));
  max-height: min(58vh, var(--filter-panel-max-height, 520px));
  overflow: visible;
  overscroll-behavior: contain;
  padding: 14px;
  border: 1px solid rgba(193,142,83,.62);
  background: rgba(255,250,240,.98);
  box-shadow: 0 20px 55px rgba(52,37,21,.2);
}
.filters.open::before { content: ""; position: absolute; left: 0; right: 0; top: -12px; height: 12px; }
.filters.open { display: block; }
.filters > div { display: flex; justify-content: space-between; align-items: center; }
.filters h2 { margin: 0; font: 700 20px Georgia, serif; }
.filters > div button { border: 0; color: var(--red); background: none; cursor: pointer; }
.filters label { display: block; margin: 12px 0 5px; font-size: 10px; font-weight: 800; text-transform: uppercase; }
.filters select { width: 100%; padding: 7px; border: 1px solid var(--line); background: white; font-size: 12px; }
.filter-dropdown { position: relative; }
.filter-dropdown-trigger { display: grid; grid-template-columns: minmax(0,1fr) auto; align-items: center; gap: 8px; width: 100%; min-height: 34px; padding: 6px 8px; border: 1px solid var(--line); border-radius: 6px; color: var(--ink); background: linear-gradient(#fffaf0,var(--paper)); box-shadow: inset 0 1px 0 rgba(255,255,255,.7), 0 2px 5px rgba(52,37,21,.08); font-size: 12px; font-weight: 800; text-align: left; cursor: pointer; }
.filter-dropdown-trigger span { min-width: 0; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.filter-dropdown-trigger strong { color: var(--red); font-size: 11px; }
.filter-dropdown-trigger.selected { border-color: var(--red); background: color-mix(in srgb,var(--red) 12%,#fff7e9); }
.filter-dropdown-trigger:hover, .filter-dropdown-trigger:focus { color: var(--red); outline: none; }
.filter-dropdown-panel { position: absolute; z-index: 120; top: calc(100% + 3px); left: 0; display: grid; gap: 1px; width: max-content; min-width: 100%; max-width: min(420px,calc(100vw - 32px)); max-height: min(320px,52vh); padding: 2px; overflow: auto; overscroll-behavior: contain; border: 1px solid color-mix(in srgb,var(--red) 28%,var(--line)); border-radius: 6px; background: rgba(255,250,240,.98); box-shadow: 0 12px 26px rgba(52,37,21,.13); }
.filter-dropdown-panel[hidden] { display: none; }
.filter-dropdown-panel button { display: grid; grid-template-columns: minmax(0,max-content); justify-content: stretch; min-height: 25px; width: 100%; padding: 2px 5px; border: 1px solid transparent; border-radius: 4px; color: var(--ink); background: transparent; font-size: .8rem; line-height: 1.15; text-align: left; cursor: pointer; }
.filter-dropdown-panel button:hover, .filter-dropdown-panel button:focus-visible { border-color: color-mix(in srgb,var(--red) 40%,var(--line)); color: var(--red); background: color-mix(in srgb,var(--red) 9%,#fff7e9); outline: none; }
.filter-dropdown-panel button.selected { border-color: var(--red); background: color-mix(in srgb,var(--red) 16%,#fff7e9); color: var(--red); font-weight: 900; }
.filter-dropdown-panel span { min-width: 0; overflow: visible; white-space: nowrap; text-overflow: clip; }
.filter-dropdown-empty { margin: 0; padding: 10px; color: var(--muted); font-size: 12px; }
.filters .primary { width: 100%; margin-top: 15px; padding: 9px; font-size: 12px; }
.toolbar #summary { grid-column: 3; grid-row: 1; margin: 0; color: var(--green); white-space: nowrap; }
.sort-control { display: flex; grid-column: 1 / 3; grid-row: 3; align-items: center; gap: 0; min-width: 0; }
.sort-control label { flex: 0 0 auto; white-space: nowrap; }
.sort-control select { flex: 0 1 300px; min-width: 0; }
.chart-filter { display: flex; align-items: center; gap: 12px; width: min(980px,calc(100% - clamp(44px,12vw,180px))); max-width: none; margin: 18px clamp(22px,6vw,90px) 0; padding: 7px 8px; overflow: hidden; border: 1px solid color-mix(in srgb,var(--gold) 72%,var(--line)); border-radius: 10px; color: var(--ink); background: linear-gradient(145deg,#fffaf0 0%,#eadfcc 54%,#cfb98e 100%); box-shadow: inset 1px 1px 0 rgba(255,255,255,.9), inset -2px -2px 0 rgba(116,79,39,.2), 0 4px 0 #a9814c, 0 10px 18px rgba(52,37,21,.18); font-size: 12px; font-weight: 700; line-height: 1.2; white-space: nowrap; text-overflow: ellipsis; }
.chart-filter .chart-reset { flex: 0 0 auto; }
.chart-filter .graph-criteria { flex: 1 1 auto; min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.toolbar select { padding: 10px; border: 1px solid var(--line); background: var(--paper); box-shadow: 0 3px 0 rgba(193,142,83,.52), 0 5px 9px rgba(52,38,15,.12); }
.view-switcher { display: flex; grid-column: 4; grid-row: 1; gap: 4px; }
.view-switcher button { min-height: 38px; padding: 7px 10px; border: 1px solid var(--line); color: var(--muted); background: linear-gradient(#fffaf0,var(--paper)); font-size: 12px; font-weight: 800; cursor: pointer; }
.view-switcher button.active { border-color: var(--red); color: white; background: linear-gradient(#c46a3d,var(--red)); box-shadow: 0 3px 0 #7e351a, 0 5px 9px rgba(52,38,15,.18); }
#mobile-filters { display: block; width: 126px; min-width: 126px; padding: 9px 6px; overflow: hidden; border: 1px solid var(--line); color: var(--ink); background: linear-gradient(#fffaf0,var(--paper)); font-weight: 800; text-align: center; white-space: nowrap; cursor: pointer; }
#mobile-filters.has-active-filters { border-color: var(--red); color: white; background: linear-gradient(#c46a3d,var(--red)); }
@media (min-width: 761px) {
  .toolbar {
    grid-template-columns: max-content minmax(0,1fr) max-content max-content;
    justify-content: stretch;
    align-items: center;
    column-gap: 12px;
    row-gap: 10px;
    width: 100%;
    margin: 0;
    padding: 18px clamp(22px,6vw,90px);
    color: #fff7e8;
    background: linear-gradient(90deg, var(--ink), var(--chrome));
    box-shadow: 0 10px 24px rgba(52,37,21,.12);
  }
  #mobile-filters { grid-column: 1; grid-row: 1; align-self: center; width: 126px; min-width: 126px; min-height: 42px; height: 42px; padding: 0 6px; font-size: 14px; }
  .search-row { grid-column: 2; grid-row: 1; }
  .search-row .artist-only-option { min-height: 42px; height: 42px; padding-inline: 10px; font-size: 12px; }
  .search-row input { min-height: 42px; height: 42px; font-size: 16px; }
  .search-submit { min-height: 42px; height: 42px; padding: 0 20px !important; font-size: 16px; }
  .search-row .search-reset { min-height: 42px; height: 42px; padding: 0 12px !important; font-size: 12px; }
  .toolbar #summary { display: none; grid-column: 1; grid-row: 2; justify-self: start; color: var(--green); font-size: 18px; font-weight: 900; line-height: 1.1; }
  .view-switcher { grid-column: 3; grid-row: 1; align-self: center; }
  .sort-control { grid-column: 4; grid-row: 1; align-self: center; }
  .view-switcher button {
    min-height: 42px;
    height: 42px;
    border-color: var(--line);
    background: linear-gradient(#fffaf0,var(--paper));
    font-size: 14px;
  }
  .view-switcher { flex: 0 0 auto; }
  .view-switcher button { flex: 0 0 auto; padding-inline: 13px; }
  .sort-control {
    flex: 0 0 auto;
    width: max-content;
    min-height: 42px;
    height: 42px;
    padding: 0;
    border: 0;
    border-radius: 0;
    color: var(--ink);
    background: transparent;
    box-shadow: none;
  }
  .sort-control label {
    display: inline-flex;
    align-items: center;
    min-height: 42px;
    height: 42px;
    padding: 0 14px;
    border: 1px solid var(--line);
    border-radius: 9px 0 0 9px;
    color: white;
    background: linear-gradient(#c46a3d,var(--red));
    box-shadow: 0 3px 0 #7e351a, 0 5px 9px rgba(52,38,15,.18);
    font-size: 14px;
    font-weight: 800;
  }
  .sort-control select {
    flex: 0 0 auto;
    width: 26ch;
    min-width: 26ch;
    max-width: 26ch;
    min-height: 42px;
    height: 42px;
    padding: 0 24px 0 10px;
    border: 1px solid var(--line);
    border-left: 0;
    border-radius: 0 9px 9px 0;
    color: var(--ink);
    background: linear-gradient(#fffaf0,var(--paper));
    box-shadow: 0 3px 0 rgba(193,142,83,.52), 0 5px 9px rgba(52,38,15,.12);
    font-family: Arial, sans-serif;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0;
    text-overflow: ellipsis;
  }
  .sort-control option { font-size: 12px; font-weight: 400; }
}
.grid { display: grid; grid-template-columns: repeat(5,minmax(0,1fr)); gap: 28px 18px; margin: 28px clamp(22px,6vw,90px) 0; }
.grid.view-covers { grid-template-columns: repeat(5,minmax(0,1fr)); gap: 28px 18px; }
.grid.view-compact { grid-template-columns: repeat(6,minmax(0,1fr)); gap: 22px 13px; }
.view-covers .card-copy, .view-compact .card-copy { text-align: center; }
.view-compact .cover-button { width: 72%; }
.view-compact .card-copy h3 { font-size: 13px; }
.view-compact .card-copy h4 { font-size: 12px; }
.view-compact .format-description, .view-list .format-description { display: none; }
.grid.view-list { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: clamp(6px,.8vw,10px); align-items: stretch; border-top: 0; }
.view-list article { position: relative; display: block; height: clamp(70px,6.2vw,82px); min-width: 0; padding: clamp(5px,.6vw,7px) clamp(44px,4.2vw,54px) clamp(5px,.6vw,7px) clamp(6px,.7vw,9px); overflow: hidden; border: 1px solid var(--line); background: rgba(255,250,240,.64); }
.view-list .cover-button { position: absolute; top: clamp(5px,.6vw,7px); right: clamp(5px,.6vw,7px); width: clamp(32px,3.4vw,42px); margin: 0; }
.view-list .card-copy { text-align: left; }
.view-list .card-copy p { margin-top: 0; }
.view-list .card-copy h3, .view-list .card-copy h4 { white-space: nowrap; }
.view-list .card-copy h3 { font-size: clamp(12px,1.1vw,14px); }
.view-list .card-copy h4 { font-size: clamp(10px,.95vw,11px); }
article { min-width: 0; }
.result-card { cursor: pointer; outline: none; }
.result-card:focus-visible .cover,
.result-card:hover .cover { border-color: var(--red); box-shadow: 0 10px 24px rgba(52,37,21,.18), 0 0 0 3px rgba(169,79,40,.16); }
.cover-button { display: block; width: 80%; margin-inline: auto; padding: 0; border: 0; background: none; cursor: pointer; }
.cover { aspect-ratio: 1; overflow: hidden; border: 1px solid var(--line); background: #d9c8aa; box-shadow: 0 8px 22px rgba(52,37,21,.13); }
.cover img, .detail-cover img { width: 100%; height: 100%; object-fit: cover; }
.cover-fallback { display: grid; place-items: center; width: 100%; height: 100%; padding: 15px; color: white; background: var(--red); text-align: center; }
.card-copy p { margin: 11px 0 4px; overflow: hidden; color: var(--red); font-size: 11px; font-weight: 800; text-transform: uppercase; white-space: nowrap; text-overflow: ellipsis; }
.card-copy .country-region { display: inline; color: inherit; font: inherit; font-size: inherit; font-weight: inherit; letter-spacing: inherit; text-transform: inherit; }
.card-copy h3, .card-copy h4 { overflow: hidden; margin: 0; white-space: nowrap; text-overflow: ellipsis; }
.card-copy h3 { font: 700 15px Georgia, serif; }
.card-copy h4 { margin-top: 3px; color: var(--red); font-size: 14px; font-weight: 800; }
.card-copy span {
  display: -webkit-box;
  margin-top: 6px;
  overflow: hidden;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.35;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
}
#pagination { display: flex; flex-wrap: nowrap; align-items: center; justify-content: flex-start; gap: 7px; width: auto; min-width: 0; margin: 45px clamp(22px,6vw,90px) 0; overflow: hidden; white-space: nowrap; }
#pagination button { min-width: 42px; height: 42px; border: 1px solid var(--line); background: var(--paper); cursor: pointer; }
#pagination button.active { color: white; background: var(--red); border-color: var(--red); }
#pagination button:disabled { opacity: .45; cursor: default; }
.pagination-ellipsis { display: inline-grid; flex: 0 0 auto; place-items: center; min-width: 34px; height: 42px; color: var(--muted); font-weight: 800; }
.empty { grid-column: 1/-1; padding: 70px; border: 1px dashed var(--line); text-align: center; }
.grid.is-loading { align-content: center; justify-items: center; }
.grid-loading {
  grid-column: 1 / -1;
  justify-self: center;
  align-self: center;
  display: inline-grid;
  grid-template-columns: auto auto;
  align-items: center;
  gap: 2px 10px;
  min-width: min(340px,100%);
  margin: 0;
  padding: 14px 18px;
  border: 1px solid rgba(169,79,40,.28);
  border-radius: 8px;
  color: var(--ink);
  background: linear-gradient(135deg,rgba(255,250,240,.94),rgba(248,239,217,.88));
  box-shadow: 0 12px 28px rgba(52,37,21,.12), inset 0 1px 0 rgba(255,255,255,.74);
}
.grid-loading-disc {
  grid-row: 1 / 3;
  width: 32px;
  height: 32px;
  border: 7px solid var(--ink);
  border-top-color: var(--red);
  border-right-color: var(--gold);
  border-radius: 50%;
  background: radial-gradient(circle,#fff7e8 0 16%,var(--green) 17% 29%,transparent 30%);
  animation: grid-loading-spin .9s linear infinite;
}
.grid-loading strong { color: var(--red); font-size: 13px; line-height: 1; text-transform: uppercase; }
.grid-loading span:last-child { color: var(--muted); font-size: 12px; font-weight: 700; }
@keyframes grid-loading-spin {
  to { transform: rotate(360deg); }
}
.collection-graphics { padding: 0 clamp(22px,6vw,90px) 52px; }
.graphics-window { padding: 24px; border: 1px solid var(--line); background: var(--paper); box-shadow: 0 12px 30px rgba(52,37,21,.08); }
.graphics-intro { display: grid; grid-template-columns: 112px minmax(0,1fr); gap: 20px; align-items: center; width: 100%; margin-bottom: 22px; }
.graphics-intro-image { width: 126px; height: 112px; margin: 0; overflow: visible; border: 0; background: transparent; }
.graphics-intro-image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 34% center;
  filter: saturate(1.03) contrast(1.02) drop-shadow(0 9px 13px rgba(52,37,21,.22));
  mix-blend-mode: multiply;
  -webkit-mask-image: radial-gradient(ellipse at 48% 50%, #000 52%, rgba(0,0,0,.82) 66%, transparent 100%);
  mask-image: radial-gradient(ellipse at 48% 50%, #000 52%, rgba(0,0,0,.82) 66%, transparent 100%);
}
.graphics-intro h2 { margin: 0; font: 700 clamp(27px,3.4vw,44px)/1 Georgia, serif; letter-spacing: -.015em; }
.graphics-toolbar { display: flex; align-items: center; gap: 12px; margin: -8px 0 16px; }
.chart-grid { display: grid; grid-template-columns: minmax(0,6.3fr) minmax(270px,3.3fr); gap: 24px; align-items: start; }
.chart-card { min-width: 0; padding: 0; border: 0; background: transparent; box-shadow: none; }
.chart-card, .year-chart, .style-chart { overflow-anchor: none; }
.chart-reset { flex: 0 0 auto; min-height: 28px; padding: 4px 10px; border: 1px solid color-mix(in srgb, var(--red) 55%, var(--line)); border-radius: 999px; color: var(--red); background: rgba(255,250,240,.82); box-shadow: 0 2px 8px rgba(52,37,21,.08); font-size: 11px; font-weight: 800; cursor: pointer; }
.chart-reset:hover, .chart-reset:focus { color: white; background: var(--red); outline: none; }
.graph-criteria { flex: 1 1 auto; min-width: 0; margin: 0 !important; padding: 6px 9px; overflow: hidden; border: 1px solid rgba(116,79,39,.24); border-left: 4px solid var(--gold); border-radius: 6px; color: var(--ink) !important; background: linear-gradient(#fffdf7,#f3e7cf); box-shadow: inset 1px 1px 3px rgba(52,37,21,.18), inset -1px -1px 0 rgba(255,255,255,.78); font-size: 11px !important; font-weight: 750; line-height: 1.25; white-space: nowrap; text-overflow: ellipsis; }
.graph-substyle-chip { display: inline-flex; align-items: center; max-width: 220px; min-height: 18px; padding: 2px 7px; overflow: hidden; border-radius: 999px; color: white; background: var(--style-color); box-shadow: inset 0 -2px 0 var(--style-dark), 0 0 0 1px rgba(52,37,21,.1); font-size: 10px; font-weight: 850; vertical-align: middle; white-space: nowrap; text-overflow: ellipsis; }
.year-chart { position: relative; min-width: 0; }
.year-chart svg { display: block; width: 100%; height: auto; touch-action: pan-y; }
.year-column { opacity: .9; }
.year-column:hover { opacity: 1; }
.year-stack-segment { shape-rendering: crispEdges; }
.year-stack-uncategorized { opacity: .72; }
.year-guides line { stroke: rgba(169,79,40,.16); stroke-width: 1; vector-effect: non-scaling-stroke; }
.year-range-excluded { fill: rgba(255,255,255,.42); stroke: rgba(255,255,255,.9); stroke-width: 1.5; filter: drop-shadow(0 4px 8px rgba(52,37,21,.2)); pointer-events: none; }
.year-range-zone { pointer-events: none; }
.year-range-zone-from, .year-range-zone-to { fill: transparent; }
.year-range-handle { stroke: rgba(169,79,40,.72); stroke-width: 4; vector-effect: non-scaling-stroke; pointer-events: none; filter: drop-shadow(0 1px 3px rgba(255,255,255,.55)); }
.year-range-hitbox { fill: transparent; outline: none; pointer-events: none; }
.year-handle-hitbox { fill: transparent; pointer-events: all; touch-action: none; }
.year-handle-hitbox-from { cursor: w-resize; }
.year-handle-hitbox-to { cursor: e-resize; }
.year-range-hitbox[data-mode="from"] { cursor: w-resize; }
.year-range-hitbox[data-mode="to"] { cursor: e-resize; }
.year-range-hitbox:focus { stroke: var(--ink); stroke-width: 2; vector-effect: non-scaling-stroke; }
.year-chart .axis, .year-chart .ticks line { stroke: var(--line); stroke-width: 1; }
.year-chart text { fill: var(--muted); font: 11px Arial, sans-serif; text-anchor: middle; }
.year-step-controls { position: absolute; z-index: 14; inset: 18px 24px auto 48px; display: flex; justify-content: space-between; gap: 12px; pointer-events: none; }
.year-step-control {
  display: inline-grid;
  grid-template-columns: auto auto auto;
  align-items: center;
  gap: 5px;
  min-height: 38px;
  padding: 3px 5px 3px 7px;
  border: 1px solid rgba(169,79,40,.45);
  border-radius: 9px;
  color: var(--ink);
  background: linear-gradient(rgba(255,250,240,.95),rgba(248,239,217,.9));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.74), 0 3px 0 rgba(169,79,40,.42), 0 7px 15px rgba(52,38,15,.14);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  pointer-events: auto;
  touch-action: none;
  user-select: none;
}
.year-step-value {
  display: inline-grid;
  place-items: center;
  min-width: 48px;
  height: 30px;
  padding: 0 6px;
  border: 1px solid rgba(193,142,83,.7);
  border-radius: 6px;
  color: white;
  background: linear-gradient(#d98b56,var(--red));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.34), 0 2px 0 #7e351a;
  font-size: 14px;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
}
.year-step-value:focus { outline: 2px solid rgba(143,214,143,.78); outline-offset: 2px; }
.year-step-buttons { display: grid; gap: 1px; }
.year-step-buttons button {
  display: grid;
  place-items: center;
  width: 20px;
  height: 15px;
  padding: 0;
  border: 1px solid rgba(126,53,26,.48);
  border-radius: 4px;
  color: var(--ink);
  background: linear-gradient(#fffaf0,#eadfcc);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.72), 0 1px 0 rgba(169,79,40,.32);
  font-size: 10px;
  font-weight: 900;
  line-height: 1;
  cursor: pointer;
}
.year-step-buttons button:hover,
.year-step-buttons button:focus { color: white; background: var(--red); outline: none; }
@media (min-width: 761px) {
  .graphics-window {
    display: grid;
    grid-template-columns: minmax(0,6.3fr) minmax(270px,3.3fr);
    grid-template-rows: auto auto minmax(320px,1fr);
    column-gap: 24px;
    align-items: start;
  }
  .graphics-intro { grid-column: 1; grid-row: 1; margin-bottom: 0; }
  .graphics-toolbar { grid-column: 1; grid-row: 2; margin: 0 0 16px; }
  .chart-grid { display: contents; }
  .chart-grid { align-items: stretch; }
  .chart-card-year { grid-column: 1; grid-row: 3; }
  .chart-card-style { grid-column: 2; grid-row: 1 / span 3; align-self: start; padding-top: clamp(26px,1.6vw,34px); }
  .chart-card-year { display: flex; flex-direction: column; min-height: 100%; }
  .chart-card-year .year-chart { display: flex; flex: 1 1 auto; flex-direction: column; min-height: 0; }
  .chart-card-year .year-chart svg { flex: 1 1 auto; height: 100%; min-height: 320px; }
}
.style-chart { display: grid; grid-template-columns: minmax(0,1fr); gap: 8px; align-items: start; }
.style-table-header { display: grid; grid-template-columns: minmax(0,1fr) 82px 66px 76px; align-items: end; gap: 10px; padding: 0 5px 3px; color: var(--muted); font-size: 9px; font-weight: 900; letter-spacing: .06em; text-transform: uppercase; }
.style-table-header span:first-child { text-align: left; }
.style-table-header span:nth-child(n+2) { justify-self: center; text-align: center; }
.style-main-list { position: relative; display: grid; gap: 8px; min-width: 0; }
.style-category { position: relative; }
.style-theme-rock { --style-color: #c74436; --style-dark: #8f2f27; --style-accent: #f3b35b; }
.style-theme-pop { --style-color: #f2b84b; --style-dark: #c27a22; --style-accent: #fbe7a5; }
.style-theme-electronic-dance { --style-color: #2e9cca; --style-dark: #155f85; --style-accent: #9ee8ff; }
.style-theme-jazz { --style-color: #6b4fa3; --style-dark: #34215f; --style-accent: #c3a8ea; }
.style-theme-soul-funk-rnb { --style-color: #b85c9e; --style-dark: #6c2757; --style-accent: #f2b0d8; }
.style-theme-folk-acoustic { --style-color: #8a6e3b; --style-dark: #55401e; --style-accent: #d7bd7b; }
.style-theme-blues { --style-color: #285c9c; --style-dark: #15355f; --style-accent: #83b7f0; }
.style-theme-stage-screen-other { --style-color: #6f7682; --style-dark: #3d424b; --style-accent: #c8ced6; }
.style-theme-reggae-ska { --style-color: #2e8b57; --style-dark: #195334; --style-accent: #f3c742; }
.style-theme-country { --style-color: #a8642a; --style-dark: #683915; --style-accent: #dfb16b; }
.style-theme-latin-world { --style-color: #e86f2d; --style-dark: #9b361b; --style-accent: #ffd0a2; }
.style-theme-hip-hop-rap { --style-color: #111827; --style-dark: #020617; --style-accent: #d6a529; }
.style-theme-uncategorized, .style-theme-default { --style-color: #9a8f80; --style-dark: #5f564c; --style-accent: #d8cec0; }
.style-category-trigger { display: grid; grid-template-columns: minmax(0,1fr) 82px 66px 76px; align-items: center; gap: 10px; width: 100%; min-height: 38px; padding: 5px; border: 0; border-radius: 5px; color: inherit; background: none; text-align: left; cursor: pointer; }
.style-category-trigger > span { display: flex; align-items: center; gap: 8px; min-width: 0; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; font-size: .93rem; font-weight: 800; }
.style-category-trigger > span::before { content: ""; flex: 0 0 12px; width: 12px; height: 24px; border-radius: 2px; background: var(--style-color); box-shadow: inset 0 -8px 0 var(--style-dark), 0 0 0 1px rgba(32,21,12,.12); }
.style-category-trigger > div { justify-self: center; width: min(64px,100%); height: 18px; overflow: hidden; border-radius: 999px; background: #eadfcc; box-shadow: inset 0 0 0 1px rgba(52,37,21,.06); }
.style-category-trigger i { position: relative; display: block; height: 100%; overflow: hidden; border-radius: inherit; background: var(--style-color); }
.style-selection-count { justify-self: center; color: var(--style-dark); font-style: normal; font-size: 11px; font-weight: 900; text-align: center; white-space: nowrap; }
.style-category-trigger > strong { justify-self: center; color: var(--style-dark); font-size: 12px; text-align: center; white-space: nowrap; }
.style-category-trigger:hover, .style-category-trigger:focus { color: var(--style-dark); background: color-mix(in srgb, var(--style-color) 12%, #f8efd9); outline: none; }
.style-category.selected .style-category-trigger { color: var(--style-dark); background: color-mix(in srgb, var(--style-color) 13%, #fff7e9); outline: 2px solid var(--style-color); }
.style-subdivision-panel { position: absolute; z-index: 20; top: calc(50% + 13px); left: var(--style-panel-left,0); display: none; grid-template-columns: max-content; gap: 1px; width: max-content; min-width: 128px; max-width: calc(100vw - 20px); max-height: min(310px,52vh); margin: 0; padding: 2px; overflow: auto; overscroll-behavior: contain; border: 1px solid color-mix(in srgb, var(--style-color, var(--line)) 34%, var(--line)); border-radius: 6px; background: rgba(255,250,240,.98); box-shadow: 0 12px 26px rgba(52,37,21,.13); }
.style-subdivision-panel.open-up { top: auto; bottom: calc(50% + 13px); box-shadow: 0 -12px 26px rgba(52,37,21,.13); }
.style-subdivision-panel.open { display: grid; }
@media (min-width: 761px) {
  .style-category::after { content: ""; position: absolute; z-index: 19; top: 50%; left: 0; width: 100%; height: 34px; }
  .style-category.style-panel-up::after { top: auto; bottom: 50%; }
  .style-category:hover > .style-subdivision-panel,
  .style-category:focus-within > .style-subdivision-panel { display: grid; }
}
.style-subdivision-panel button { display: grid; grid-template-columns: minmax(0,max-content) auto; justify-content: stretch; gap: 6px; min-height: 25px; width: 100%; padding: 2px 4px; border: 1px solid transparent; border-radius: 4px; color: var(--ink); background: transparent; font-size: .8rem; line-height: 1.15; text-align: left; cursor: pointer; }
.style-subdivision-panel button:hover, .style-subdivision-panel button:focus-visible { border-color: color-mix(in srgb, var(--style-color, var(--gold)) 46%, var(--line)); color: var(--style-dark, var(--red)); background: color-mix(in srgb, var(--style-color, var(--green)) 10%, #fff7e9); outline: none; }
.style-subdivision-panel button.selected { border-color: var(--style-color, var(--green)); background: color-mix(in srgb, var(--style-color, var(--green)) 15%, #fff7e9); color: var(--style-dark, var(--red)); }
.style-subdivision-panel span { min-width: 0; overflow: visible; white-space: nowrap; text-overflow: clip; }
.style-subdivision-panel strong { flex: 0 0 auto; color: var(--style-dark, var(--red)); font-size: .8rem; }
.style-select-all { margin-bottom: 3px; border-color: color-mix(in srgb, var(--style-color, var(--gold)) 45%, var(--line)) !important; color: var(--style-dark) !important; background: color-mix(in srgb, var(--style-color) 14%, #fff7e9) !important; font-weight: 900; }
.style-select-all.selected { border-color: var(--style-color) !important; background: color-mix(in srgb, var(--style-color) 24%, #fff7e9) !important; box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--style-color) 65%, #fff7e9); }
.style-select-all span { display: inline-flex; align-items: center; gap: 7px; }
.style-select-all span::before { content: ""; flex: 0 0 10px; width: 10px; height: 18px; border-radius: 2px; background: var(--style-color); box-shadow: inset 0 -6px 0 var(--style-dark); }
.style-subdivision-empty { grid-column: 1 / -1; align-self: center; margin: 0; padding: 28px; color: var(--muted); text-align: center; }
.chart-empty { padding: 28px; }
.feedback-section { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); align-items: start; gap: 20px; padding: 28px clamp(22px,6vw,90px) 62px; border-top: 1px solid var(--line); background: var(--paper); }
.feedback-copy { width: 100%; max-width: none; padding: 17px 19px; border: 1px solid var(--line); background: var(--paper); box-shadow: 0 8px 22px rgba(52,37,21,.07); }
.feedback-copy h2 { margin: 0 0 8px; font: 700 clamp(25px,3vw,38px)/1.02 Georgia, serif; letter-spacing: -.02em; }
.feedback-copy p:not(.eyebrow) { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.4; }
.feedback-open { min-height: 38px; margin-top: 9px; padding-inline: 18px; }
.feedback-feed { min-width: 0; padding: 17px 19px; border: 1px solid var(--line); background: var(--paper); box-shadow: 0 8px 22px rgba(52,37,21,.07); }
.feedback-feed h3 { margin: 0 0 10px; font: 700 19px Georgia, serif; }
.feedback-list { display: grid; gap: 9px; }
.feedback-item { padding: 12px 14px; border: 1px solid var(--line); background: #f8efd9; font-size: 13px; line-height: 1.4; }
.feedback-item > div { display: flex; justify-content: space-between; gap: 18px; }
.feedback-item strong { font: 700 15px Georgia, serif; }
.feedback-item time, .feedback-item > span { color: var(--muted); font-size: 10px; }
.feedback-item p { margin: 7px 0 4px; white-space: pre-line; }
.feedback-empty { margin: 0; padding: 24px; border: 1px dashed var(--line); color: var(--muted); text-align: center; }
.feedback-dialog { width: min(720px,calc(100vw - 30px)); max-height: calc(100vh - 30px); overflow: auto; }
.feedback-dialog .feedback-form { border: 0; box-shadow: none; }
.feedback-dialog .feedback-form h2 { margin: 0; font: 700 36px Georgia, serif; }
.feedback-close { position: absolute; z-index: 2; top: 10px; right: 10px; width: 40px; height: 40px; border: 0; border-radius: 50%; background: white; font-size: 27px; cursor: pointer; }
.feedback-form { position: relative; display: grid; gap: 18px; padding: 28px; border: 1px solid var(--line); background: #f8efd9; box-shadow: 0 12px 30px rgba(52,37,21,.08); }
.feedback-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.feedback-form label > span:first-child { display: block; margin-bottom: 7px; font-size: 12px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.feedback-form input:not([type="checkbox"]), .feedback-form textarea { width: 100%; padding: 12px; border: 1px solid var(--line); background: #fff; }
.feedback-form textarea { resize: vertical; }
.feedback-form small { display: block; margin-top: 6px; color: var(--muted); }
.feedback-consent { display: flex; align-items: flex-start; gap: 10px; color: var(--muted); font-size: 13px; }
.feedback-consent input { flex: 0 0 auto; width: 18px; height: 18px; margin-top: 2px; accent-color: var(--red); }
.feedback-consent span { margin: 0 !important; font: inherit !important; letter-spacing: 0 !important; text-transform: none !important; }
.feedback-website { position: absolute; left: -10000px; width: 1px; height: 1px; overflow: hidden; }
.feedback-submit { justify-self: start; min-height: 46px; }
.feedback-submit:disabled { opacity: .6; cursor: wait; }
.feedback-status { min-height: 24px; color: var(--red); font-weight: 700; }
.feedback-status.success { color: #276b36; }
footer { display: flex; justify-content: space-between; gap: 24px; padding: 35px clamp(22px,6vw,90px); border-top: 1px solid var(--line); color: var(--muted); background: var(--paper); box-shadow: inset 0 1px 0 rgba(255,255,255,.65); }
footer span, .footer-contact strong { display: block; }
.footer-contact { margin: 0; font-style: normal; text-align: right; }
.footer-contact a { color: var(--red); font-weight: 850; }
.footer-contact span { margin-top: 6px; color: var(--red); font-weight: 700; }
.protected-contact { display: inline-block; margin-top: 6px; color: var(--gold); font-weight: 800; }
dialog { width: min(900px,calc(100vw - 30px)); padding: 0; border: 0; box-shadow: 0 25px 90px rgba(0,0,0,.45); }
dialog::backdrop { background: rgba(23,19,15,.78); }
.close { position: absolute; z-index: 2; right: 10px; top: 10px; width: 40px; height: 40px; border: 0; border-radius: 50%; background: white; font-size: 27px; cursor: pointer; }
.detail-gallery-nav { position: absolute; z-index: 3; top: 50%; width: 44px; height: 58px; padding: 0; border: 0; border-radius: 22px; color: var(--red); background: rgba(255,255,255,.9); box-shadow: 0 4px 18px rgba(0,0,0,.25); font-size: 38px; line-height: 1; cursor: pointer; transform: translateY(-50%); }
.detail-gallery-prev { left: 10px; }
.detail-gallery-next { right: 10px; }
.detail-layout { display: grid; grid-template-columns: minmax(280px,48%) 1fr; }
.detail-cover { aspect-ratio: 1; background: #d9c8aa; }
.detail-info { padding: 45px; }
.detail-layout h2 { margin: 5px 0; font: 700 38px Georgia, serif; }
.detail-layout h3 { margin: 0; color: var(--red); font-size: 18px; font-weight: 800; line-height: 1.2; }
.side-tracks { margin: 18px 0 16px; color: var(--ink); }
.side-tracks p { margin: 4px 0; }
.side-tracks strong { color: var(--red); }
dl { margin: 25px 0; border-top: 1px solid var(--line); }
dl div { display: grid; grid-template-columns: 105px 1fr; padding: 8px 0; border-bottom: 1px solid var(--line); }
dt { color: var(--muted); }
dd { margin: 0; font-weight: 700; }
.notes { padding: 12px; background: var(--cream); }
.discogs-link { color: var(--red); font-weight: 750; }
.detail-playlist-button { min-height: 36px; margin: 14px 0 2px; padding: 0 16px; border: 1px solid #93431f; border-radius: 9px; color: white; background: linear-gradient(#c46a3d,var(--red)); box-shadow: inset 0 1px 0 rgba(255,255,255,.32), 0 3px 0 #7e351a, 0 5px 9px rgba(52,38,15,.18); font-size: 13px; font-weight: 850; cursor: pointer; }
.detail-playlist-button:hover, .detail-playlist-button:focus { filter: brightness(1.05); outline: none; }
.detail-playlist-button.is-selected { color: var(--ink); background: linear-gradient(#b9e9b9,var(--green)); border-color: #6cab6f; box-shadow: inset 0 1px 0 rgba(255,255,255,.45), 0 3px 0 #5c965f, 0 5px 9px rgba(52,38,15,.14); }
.jukebox-playlist { padding: 18px clamp(22px,6vw,90px) 72px; color: #fff7e8; background: linear-gradient(90deg, var(--ink), var(--chrome)); }
.playlist-window { padding: 0; border: 0; background: transparent; box-shadow: none; }
.playlist-heading { display: flex; align-items: end; justify-content: space-between; gap: 18px; margin-bottom: 14px; }
.playlist-heading h2 { margin: 0; font: 700 clamp(25px,3vw,36px)/1 Georgia, serif; letter-spacing: -.015em; }
.playlist-heading p:last-child { flex: 0 0 auto; margin: 0; color: var(--green); font-size: 13px; font-weight: 900; }
.playlist-items { display: grid; grid-template-columns: repeat(auto-fill,minmax(0,360px)); justify-content: start; align-items: start; gap: 10px; min-height: 92px; }
.playlist-empty { grid-column: 1 / -1; margin: 0; padding: 30px; border: 1px dashed rgba(210,184,147,.45); color: #eadfcc; text-align: center; }
.playlist-item { display: grid; grid-template-columns: 54px minmax(0,1fr) auto; align-items: center; gap: 10px; width: 360px; max-width: 100%; min-width: 0; padding: 9px; border: 1px solid rgba(210,184,147,.28); background: rgba(255,250,240,.92); color: var(--ink); cursor: pointer; }
.playlist-item:hover, .playlist-item:focus-visible { border-color: var(--gold); box-shadow: 0 0 0 2px rgba(143,214,143,.2); outline: none; }
.playlist-cover { width: 54px; aspect-ratio: 1; }
.playlist-cover .cover, .playlist-cover img { width: 100%; height: 100%; }
.playlist-item p { margin: 0 0 3px; color: var(--red); font-size: 10px; font-weight: 850; text-transform: uppercase; white-space: nowrap; }
.playlist-item h3, .playlist-item h4 { overflow: hidden; margin: 0; white-space: nowrap; text-overflow: ellipsis; }
.playlist-item h3 { font: 700 14px Georgia, serif; }
.playlist-item h4 { margin-top: 2px; font-size: 12px; }
.playlist-item button { min-height: 28px; padding: 3px 8px; border: 1px solid color-mix(in srgb, var(--red) 55%, var(--line)); border-radius: 999px; color: var(--red); background: rgba(255,250,240,.82); box-shadow: 0 2px 8px rgba(52,37,21,.08); font-size: 10px; font-weight: 850; cursor: pointer; }
.playlist-item button:hover, .playlist-item button:focus { color: white; background: var(--red); outline: none; }
@media (min-width: 761px) {
  #details { width: min(calc(100vw - 28px), calc(80vh + clamp(360px,34vw,620px))); max-width: min(calc(100vw - 28px), calc(80vh + clamp(360px,34vw,620px))); height: 80vh; max-height: 80vh; padding: 0; overflow: hidden; border: 1px solid color-mix(in srgb,var(--gold) 55%,var(--line)); background: #f8efd9; }
  #details .close { right: clamp(18px,2.4vw,34px); top: clamp(18px,2.4vw,34px); }
  .detail-layout { grid-template-columns: minmax(0,1.05fr) minmax(330px,.82fr); gap: 0; height: 100%; min-height: 0; }
  .detail-cover { display: grid; place-items: center; height: 100%; min-height: 0; padding: 0; aspect-ratio: auto; border: 0; background: radial-gradient(circle at 50% 42%,#2c1510 0%,#120804 62%); box-shadow: inset 0 0 0 1px rgba(255,255,255,.04); }
  .detail-cover img { object-fit: contain; background: #120804; }
  .detail-info { display: flex; flex-direction: column; height: 80vh; max-height: 80vh; min-height: 0; overflow: hidden; padding: clamp(18px,2.2vw,32px); border: 0; border-left: 1px solid var(--line); background: rgba(255,250,240,.92); box-shadow: inset 0 1px 0 rgba(255,255,255,.55); }
  .detail-info .eyebrow { flex: 0 0 auto; margin: 0 0 4px; font-size: 11px; line-height: 1.15; }
  .detail-info h2 { flex: 0 0 auto; margin: 0; font-size: clamp(25px,2.4vw,34px); line-height: .95; }
  .detail-info h3 { flex: 0 0 auto; margin: 0; font-size: clamp(17px,1.45vw,21px); line-height: 1.15; }
  .detail-info .side-tracks { flex: 0 0 auto; margin: 13px 0 9px; font-size: 13px; line-height: 1.25; }
  .detail-info .side-tracks p { margin: 2px 0; }
  .detail-info dl { flex: 1 1 auto; min-height: 0; margin: 10px 0; overflow: hidden; border-top: 1px solid var(--line); }
  .detail-info dl div { grid-template-columns: 86px minmax(0,1fr); gap: 10px; min-height: 0; padding: 4px 0; font-size: 12px; line-height: 1.18; }
  .detail-info dd { min-width: 0; overflow: hidden; text-overflow: ellipsis; }
  .detail-info dl .notes { margin: 0; background: transparent; }
  .detail-info dl .notes dd { max-height: 54px; overflow: hidden; font-size: 12px; line-height: 1.25; }
  .detail-info .discogs-link { flex: 0 0 auto; margin-top: auto; font-size: 13px; line-height: 1.2; }
}
@media (min-width: 1181px) {
  .detail-layout { grid-template-columns: minmax(0,80vh) minmax(360px,620px); }
  .detail-cover { width: 80vh; max-width: 100%; height: 80vh; max-height: 100%; }
  .detail-cover img { width: 100%; height: 100%; object-fit: contain; }
}
.hero-copy a, .wurlitzer-page a { color: var(--red); font-weight: 800; }
.wurlitzer-page { padding: 58px clamp(22px,7vw,115px) 88px; }
.wurlitzer-hero { max-width: 880px; margin-bottom: 44px; }
.wurlitzer-hero p:not(.eyebrow) { max-width: 720px; color: var(--muted); font-size: 18px; }
.owner-note { padding: 16px 18px; border-left: 4px solid var(--gold); background: var(--paper); }
.owner-note span { color: var(--red); font-weight: 800; }
.wurlitzer-page .wurlitzer-back { display: inline-flex; align-items: center; min-height: 44px; margin-top: 18px; padding: 0 18px; color: #fff; text-decoration: none; }
.wurlitzer-return { margin-top: 26px; }
.wurlitzer-panels { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 22px; }
.wurlitzer-panels article { padding: 24px; border: 1px solid var(--line); background: var(--paper); box-shadow: 0 12px 30px rgba(52,37,21,.08); }
.wurlitzer-panels h2 { margin: 0 0 12px; font: 700 28px Georgia, serif; }
.wurlitzer-panels p, .wurlitzer-panels li { color: var(--muted); }
.wurlitzer-panels code { color: var(--ink); font-weight: 700; }
.wurlitzer-gallery { display: grid; grid-template-columns: repeat(auto-fit,minmax(112px,1fr)); gap: 8px; min-height: 220px; padding: 10px; border: 1px dashed var(--line); background: #eadfcc; text-align: center; }
.wurlitzer-gallery strong, .wurlitzer-gallery span { display: block; align-self: center; }
.wurlitzer-gallery strong { color: var(--red); font: 700 22px Georgia, serif; }
.wurlitzer-photo { display: block; aspect-ratio: 1; overflow: hidden; border: 1px solid var(--line); background: #eadfcc; }
.wurlitzer-photo img { display: block; width: 100%; height: 100%; object-fit: cover; transition: transform .18s ease; }
.wurlitzer-photo:hover img, .wurlitzer-photo:focus img { transform: scale(1.04); }
.reference-links { display: grid; gap: 7px; padding-left: 22px; }
.document-card { margin: 18px 0; padding: 16px; border: 1px solid var(--line); background: #f8efd9; }
.document-card h3 { margin: 5px 0 8px; font: 700 21px Georgia, serif; }
.document-card p { margin: 6px 0; }
.document-card a { display: inline-block; margin-top: 8px; }
.repair-section { margin-top: 40px; }
.repair-section h2 { margin: 4px 0 12px; font: 700 clamp(34px,5vw,58px)/.95 Georgia, serif; letter-spacing: -.035em; }
.repair-intro { max-width: 760px; color: var(--muted); font-size: 17px; }
.repair-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 18px; margin-top: 24px; }
.repair-card { padding: 20px; border: 1px solid var(--line); background: var(--paper); box-shadow: 0 12px 30px rgba(52,37,21,.08); }
.repair-card h3 { margin: 0 0 8px; font: 700 22px Georgia, serif; }
.repair-card p { margin: 0 0 12px; color: var(--muted); }
.repair-photos { display: grid; grid-template-columns: repeat(auto-fill,minmax(72px,1fr)); gap: 7px; margin-top: 14px; }
.repair-photo { display: block; aspect-ratio: 1; overflow: hidden; border: 1px solid var(--line); background: #eadfcc; }
.repair-photo img { display: block; width: 100%; height: 100%; object-fit: cover; transition: transform .18s ease; }
.repair-photo:hover img, .repair-photo:focus img { transform: scale(1.04); }
body.lightbox-open { overflow: hidden; }
.wurlitzer-lightbox[hidden] { display: none; }
.wurlitzer-lightbox { position: fixed; inset: 0; z-index: 40; display: grid; grid-template-columns: minmax(52px,1fr) minmax(0,1060px) minmax(52px,1fr); align-items: center; gap: 14px; padding: 24px; background: rgba(25,12,4,.92); }
.wurlitzer-lightbox-frame { grid-column: 2; display: grid; gap: 10px; justify-items: center; min-width: 0; margin: 0; }
.wurlitzer-lightbox-frame img { display: block; max-width: 100%; max-height: calc(100vh - 138px); object-fit: contain; background: #120804; box-shadow: 0 18px 60px rgba(0,0,0,.5); }
.wurlitzer-lightbox-caption { max-width: 100%; color: #fff7e8; font-weight: 700; text-align: center; overflow-wrap: anywhere; }
.wurlitzer-lightbox-counter { color: #d2b893; font-size: 13px; font-weight: 800; }
.wurlitzer-lightbox-button { width: 48px; height: 48px; padding: 0; border: 1px solid rgba(255,247,232,.55); border-radius: 50%; color: #fff7e8; background: rgba(52,38,15,.8); font-size: 34px; line-height: 1; cursor: pointer; }
.wurlitzer-lightbox-button:hover, .wurlitzer-lightbox-button:focus { background: var(--red); outline: 2px solid #fff7e8; outline-offset: 2px; }
.wurlitzer-lightbox-button:disabled { opacity: .35; cursor: default; }
.wurlitzer-lightbox-close { position: absolute; top: 18px; right: 18px; }
.wurlitzer-lightbox-prev { grid-column: 1; justify-self: end; }
.wurlitzer-lightbox-next { grid-column: 3; justify-self: start; }
@media (max-width: 1050px) {
  .stats { grid-template-columns: repeat(3,1fr); row-gap: 14px; }
  .grid { grid-template-columns: repeat(4,minmax(0,1fr)); }
  .wurlitzer-panels { grid-template-columns: 1fr; }
  .repair-grid { grid-template-columns: 1fr; }
}
@media (min-width: 761px) and (max-width: 1180px) {
  .collection-banner { min-height: clamp(150px,19vw,210px); background-image: url("/jukebox-collection-banner-tablet.webp"); background-position: center center; }
  .collection-banner-link { max-width: min(88%,760px); padding: 22px clamp(24px,5vw,56px); }
  .collection-banner-title { font-size: clamp(38px,5.6vw,58px); }
  .collection-banner-subtitle { max-width: 430px; font-size: 11px; }
  .stats { grid-template-columns: repeat(4,1fr); padding: 12px clamp(22px,4vw,44px); }
  .stats strong { font-size: 24px; }
  .stats span { font-size: 11px; }
  .catalogue { padding: 0 0 46px; }
  .toolbar {
    grid-template-columns: max-content minmax(0,1fr);
    gap: 10px;
    align-items: center;
  }
  #mobile-filters { grid-column: 1; grid-row: 1; width: 116px; min-width: 116px; min-height: 40px; height: 40px; padding: 0 5px; font-size: 13px; }
  .search-row { grid-column: 2; grid-row: 1; }
  .search-row .artist-only-option { min-height: 40px; height: 40px; padding-inline: 8px; font-size: 11px; }
  .search-row input { min-height: 40px; height: 40px; padding-inline: 13px; font-size: 14px; }
  .search-submit { min-height: 40px; height: 40px; padding: 0 16px !important; font-size: 14px; }
  .search-row .search-reset { min-height: 40px; height: 40px; padding: 0 10px !important; font-size: 11px; }
  .toolbar #summary { display: none; grid-column: 1; grid-row: 2; justify-self: start; font-size: 15px; font-weight: 900; }
  .artist-only-option { font-size: 12px; }
  .view-switcher { grid-column: 2; grid-row: 3; justify-self: start; align-self: center; gap: 4px; }
  .view-switcher button { min-height: 36px; height: 36px; padding: 0 11px; font-size: 12px; }
  .sort-control { grid-column: 2; grid-row: 3; justify-self: end; align-self: center; min-height: 36px; height: 36px; }
  .sort-control label { min-height: 36px; height: 36px; padding: 0 11px; font-size: 12px; }
  .sort-control select { width: 22ch; min-width: 22ch; max-width: 22ch; min-height: 36px; height: 36px; padding: 0 20px 0 8px; font-size: 12px; }
  .grid.view-covers { grid-template-columns: repeat(4,minmax(0,1fr)); gap: 24px 15px; }
  .grid.view-compact { grid-template-columns: repeat(4,minmax(0,1fr)); gap: 18px 12px; }
  .grid.view-list { grid-template-columns: repeat(3,minmax(0,1fr)); gap: 8px; }
  .view-compact .cover-button { width: 76%; }
  .collection-graphics { padding: 0 clamp(20px,4vw,42px) 44px; }
  .graphics-window { padding: 18px; }
  .graphics-intro { grid-template-columns: 86px minmax(0,1fr); gap: 14px; margin-bottom: 14px; }
  .graphics-intro-image { width: 86px; height: 98px; }
  .graphics-intro h2 { font-size: clamp(30px,5vw,39px); }
  .graphics-toolbar { margin: 0 0 12px; }
  .graph-criteria { font-size: 10px !important; }
  .style-table-header,
  .style-category-trigger { grid-template-columns: minmax(0,1fr) 58px 54px 60px; gap: 7px; }
  .style-category-trigger { min-height: 31px; padding: 3px; }
  .style-category-trigger > span { gap: 6px; font-size: .78rem; }
  .style-category-trigger > span::before { flex-basis: 9px; width: 9px; height: 18px; box-shadow: inset 0 -6px 0 var(--style-dark), 0 0 0 1px rgba(32,21,12,.12); }
  .style-category-trigger > div { width: min(48px,100%); height: 14px; }
  .style-selection-count,
  .style-category-trigger > strong { font-size: 10px; }
  .feedback-section { grid-template-columns: 1fr; padding: 24px clamp(20px,4vw,42px) 54px; }
  #details { width: min(calc(100vw - 28px), calc(80vh + clamp(320px,34vw,430px))); max-width: min(calc(100vw - 28px), calc(80vh + clamp(320px,34vw,430px))); height: 80vh; max-height: 80vh; }
  .detail-layout { grid-template-columns: minmax(0,80vh) minmax(320px,430px); height: 100%; min-height: 0; max-height: none; }
  .detail-cover { width: 80vh; max-width: 100%; height: 80vh; max-height: 100%; }
  .detail-info { padding: 24px; }
  .detail-layout h2 { font-size: clamp(29px,4vw,36px); }
  dl div { grid-template-columns: 88px 1fr; padding: 6px 0; }
}
@media (min-width: 761px) and (max-width: 900px) {
  .toolbar { grid-template-columns: max-content minmax(0,1fr); }
  #mobile-filters { width: 108px; min-width: 108px; font-size: 12px; }
  .view-switcher { grid-column: 1 / -1; grid-row: 3; }
  .sort-control { grid-column: 1 / -1; grid-row: 4; justify-self: stretch; }
  .sort-control select { flex: 1 1 auto; width: auto; min-width: 0; max-width: none; }
  .grid.view-covers { grid-template-columns: repeat(3,minmax(0,1fr)); }
  .grid.view-compact { grid-template-columns: repeat(4,minmax(0,1fr)); }
  .grid.view-list { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .graphics-window { display: block; }
  .chart-grid { display: grid; grid-template-columns: minmax(0,1fr); gap: 16px; }
  .chart-card-year .year-chart svg { height: clamp(330px,48vw,410px); min-height: 0; }
  .chart-card-style { padding-top: 0; }
  #details { width: 80vw; max-width: 80vw; height: auto; max-height: calc(100vh - 28px); }
  .detail-layout { display: block; max-height: calc(100vh - 56px); overflow: auto; }
  .detail-cover { max-height: min(52vh,480px); }
}
@media (min-width: 901px) and (max-width: 1180px) {
  .graphics-window {
    display: grid;
    grid-template-columns: minmax(0,1.65fr) minmax(280px,.95fr);
    grid-template-rows: auto auto minmax(300px,1fr);
    column-gap: 18px;
  }
  .chart-card-style { padding-top: 18px; }
  .chart-card-year .year-chart svg { min-height: 300px; }
}
@media (max-width: 760px) {
  header { align-items: flex-start; } header > a:last-child { font-size: 12px; }
  .collection-banner { min-height: 158px; background-image: url("/jukebox-collection-banner-mobile.webp"); background-position: center center; }
  .collection-banner::after {
    background:
      radial-gradient(ellipse at center,rgba(18,4,1,.58) 0%,rgba(18,4,1,.4) 42%,rgba(18,4,1,.16) 78%),
      linear-gradient(180deg,rgba(18,4,1,.24),rgba(18,4,1,.44));
  }
  .collection-banner-link { width: 100%; max-width: 330px; min-height: 158px; padding: 15px 18px; }
  .collection-banner-title { font-size: clamp(26px,8vw,34px); line-height: .92; letter-spacing: -.035em; }
  .collection-banner-title strong { margin-top: .3em; }
  .collection-banner-subtitle { max-width: 260px; font-size: 9px; }
  .collection-banner-rule { margin: 11px 0 7px; }
  #search-form { display: block; flex: 1 1 100%; width: 100%; padding: 0; border: 0; background: transparent; }
  .search-row { display: flex; }
  .search-row .artist-only-option { flex: 0 1 auto; min-width: 0; min-height: 44px; height: 44px; padding: 0 7px; font-size: 10px; }
  .search-row .artist-only-option span { min-width: 0; max-width: 76px; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
  .search-row .artist-only-option input { width: 14px; height: 14px; }
  .search-row input { flex: 1 1 auto; width: auto; min-height: 44px; height: 44px; padding: 0 10px; }
  .search-submit { flex: 0 0 auto; width: auto; min-height: 44px; height: 44px; padding: 0 10px !important; font-size: 11px; }
  .search-row .search-reset { flex: 0 0 auto; width: auto; min-height: 44px; height: 44px; padding: 0 8px !important; font-size: 10px; }
  .stats { grid-template-columns: repeat(2,1fr); padding-inline: 12px; } .stats strong { font-size: 22px; } .stats span { font-size: 11px; }
  .catalogue { display: block; padding: 0 0 42px; }
  .filters {
    top: var(--filter-panel-top, 14px);
    left: var(--filter-panel-left, 18px);
    width: min(300px, calc(100vw - 36px));
    max-height: min(54vh, 420px);
    padding: 10px;
  }
  .filters h2 { font-size: 17px; }
  .filters label { margin: 9px 0 4px; font-size: 9px; }
  .filters select { padding: 6px; font-size: 11px; }
  #mobile-filters { order: 5; flex: 0 0 76px; width: 76px; min-width: 76px; min-height: 30px; height: 30px; padding: 4px 3px; font-size: 10px; }
  .toolbar { display: flex; align-items: center; flex-wrap: wrap; gap: 8px 5px; margin: 0; padding: 12px 18px; color: #fff7e8; background: linear-gradient(90deg, var(--ink), var(--chrome)); box-shadow: 0 10px 24px rgba(52,37,21,.12); } .toolbar #summary { display: none; } .chart-filter { width: calc(100% - 36px); margin: 14px 18px 0; white-space: normal; }
  .sort-control { order: 5; flex: 1 1 auto; width: auto; min-width: 0; max-width: none; gap: 0; padding: 0; border: 0; border-radius: 0; background: transparent; box-shadow: none; }
  .sort-control label { flex: 0 0 auto; min-height: 30px; height: 30px; padding: 0 8px; border: 1px solid var(--line); border-radius: 9px 0 0 9px; color: white; background: linear-gradient(#c46a3d,var(--red)); box-shadow: 0 3px 0 #7e351a, 0 5px 9px rgba(52,38,15,.18); font-size: 10px; font-weight: 800; }
  .sort-control select { flex: 1 1 auto; width: auto; max-width: none; min-width: 0; min-height: 30px; height: 30px; padding: 0 15px 0 6px; border: 1px solid var(--line); border-left: 0; border-radius: 0 9px 9px 0; background: linear-gradient(#fffaf0,var(--paper)); box-shadow: 0 3px 0 rgba(193,142,83,.52), 0 5px 9px rgba(52,38,15,.12); font-size: 10px; font-weight: 800; }
  .sort-control option { font-size: 10px; font-weight: 400; }
  .view-switcher { order: 5; flex: 0 0 auto; width: auto; gap: 3px; }
  .view-switcher button { flex: 0 0 auto; min-height: 30px; height: 30px; padding: 4px 7px; font-size: 10px; }
  .view-switcher [data-view="covers"] { display: none; }
  .grid { grid-template-columns: repeat(2,minmax(0,1fr)); gap: 24px 13px; margin: 24px 18px 0; }
  .grid.view-compact { grid-template-columns: repeat(3,minmax(0,1fr)); }
  #pagination { gap: 5px; margin: 30px 18px 0; }
  #pagination button { min-width: 38px; height: 38px; font-size: 12px; }
  .pagination-ellipsis { min-width: 28px; height: 38px; }
  .grid.view-list { grid-template-columns: repeat(2,minmax(0,1fr)); gap: 8px; }
  .view-list article { height: 66px; padding: 5px 42px 5px 6px; }
  .view-list .cover-button { top: 5px; right: 5px; width: 34px; }
  .view-list .card-copy p { font-size: 9px; }
  .view-list .card-copy h3 { font-size: 11px; }
  .view-list .card-copy h4 { font-size: 9px; }
  .collection-graphics { padding: 0 18px 38px; }
  .graphics-window { padding: 12px; }
  .graphics-intro { grid-template-columns: 76px minmax(0,1fr); gap: 12px; }
  .graphics-intro-image { width: 76px; height: 92px; }
  .graphics-intro h2 { font-size: clamp(23px,7vw,31px); }
  .graphics-toolbar { align-items: flex-start; gap: 8px; margin: -4px 0 12px; }
  .graphics-toolbar .graph-criteria { white-space: normal; }
  .chart-grid { display: grid; grid-template-columns: minmax(0,1fr); gap: 18px; }
  .chart-card { min-width: 0; }
  .year-chart svg { height: clamp(235px,42vw,300px); }
  .year-step-controls { inset: 10px 11px auto 22px; gap: 6px; }
  .year-step-control { min-height: 28px; padding: 2px 3px 2px 5px; gap: 3px; border-radius: 7px; font-size: 7px; }
  .year-step-value { min-width: 35px; height: 24px; padding: 0 4px; border-radius: 5px; font-size: 9px; }
  .year-step-buttons button { width: 16px; height: 11px; border-radius: 3px; font-size: 8px; }
  .feedback-section { grid-template-columns: 1fr; gap: 12px; padding: 22px 18px 46px; }
  .jukebox-playlist { padding: 14px 18px 46px; }
  .playlist-window { padding: 0; }
  .playlist-heading { align-items: start; margin-bottom: 10px; }
  .playlist-heading h2 { font-size: 22px; }
  .playlist-heading p:last-child { font-size: 11px; }
  .playlist-items { grid-template-columns: repeat(2,minmax(0,1fr)); min-height: 82px; gap: 8px; }
  .playlist-item { grid-template-columns: 38px minmax(0,1fr); grid-template-rows: auto auto; width: auto; padding: 6px; gap: 6px; }
  .playlist-cover { grid-row: 1 / span 2; width: 38px; }
  .playlist-item button { grid-column: 2; justify-self: start; min-height: 24px; padding: 2px 7px; font-size: 9px; }
  .playlist-item p { font-size: 9px; }
  .playlist-item h3 { font-size: 12px; }
  .playlist-item h4 { font-size: 10px; }
  .feedback-copy, .feedback-feed { padding: 12px; }
  .feedback-copy h2 { font-size: clamp(21px,6vw,27px); }
  .feedback-copy p:not(.eyebrow) { font-size: 11px; line-height: 1.35; }
  .feedback-feed h3 { font-size: 17px; }
  .feedback-item { padding: 10px 11px; font-size: 12px; }
  .feedback-form { padding: 20px; }
  .feedback-fields { grid-template-columns: 1fr; }
  .style-chart { grid-template-columns: 1fr; gap: 5px; }
  .style-main-list { gap: 2px; }
  .style-table-header { grid-template-columns: minmax(0,1fr) 44px 43px 48px; gap: 5px; padding: 0 3px 2px; font-size: 7px; letter-spacing: .03em; }
  .style-category-trigger { grid-template-columns: minmax(0,1fr) 44px 43px 48px; gap: 5px; min-height: 24px; padding: 2px 3px; font-size: 10px; }
  .style-category-trigger > span { gap: 5px; font-size: .72rem; }
  .style-category-trigger > span::before { flex-basis: 8px; width: 8px; height: 15px; box-shadow: inset 0 -5px 0 var(--style-dark), 0 0 0 1px rgba(32,21,12,.12); }
  .style-category-trigger > div { width: min(38px,100%); height: 12px; }
  .style-selection-count { font-size: 9px; }
  .style-category-trigger > strong { font-size: 9px; }
  .style-subdivision-panel {
    top: calc(50% + 9px);
    gap: 1px;
    min-width: 112px;
    max-height: min(290px,48vh);
    margin: 0;
    padding: 2px;
  }
  .style-subdivision-panel button { min-height: 23px; padding: 2px 3px; font-size: .74rem; }
  .style-subdivision-panel strong { font-size: .74rem; }
  .wurlitzer-page { padding: 42px 18px 62px; }
  .wurlitzer-panels article { padding: 18px; }
  .repair-card { padding: 18px; }
  .wurlitzer-lightbox { grid-template-columns: 1fr 1fr; grid-template-rows: minmax(0,1fr) auto; gap: 10px; padding: 14px; }
  .wurlitzer-lightbox-frame { grid-column: 1 / -1; grid-row: 1; align-self: center; }
  .wurlitzer-lightbox-frame img { max-height: calc(100vh - 156px); }
  .wurlitzer-lightbox-prev { grid-column: 1; grid-row: 2; justify-self: end; }
  .wurlitzer-lightbox-next { grid-column: 2; grid-row: 2; justify-self: start; }
  .wurlitzer-lightbox-close { top: 10px; right: 10px; }
  #details { width: calc(100vw - 28px); height: auto; max-height: calc(100vh - 28px); padding: 10px; }
  .detail-layout { display: block; } .detail-cover { max-width: 100%; } .detail-info { padding: 28px; }
  footer { display: block; } footer span { display: block; margin-top: 8px; } .footer-contact { margin-top: 22px; text-align: left; }
}

/* Final hifi dark theme cascade */
body {
  color: var(--ink);
  background:
    radial-gradient(circle at 80% 0%, rgba(255,138,42,.11), transparent 30rem),
    radial-gradient(circle at 10% 18%, rgba(60,91,126,.18), transparent 28rem),
    linear-gradient(180deg,#080807 0%,#11100d 42%,#080807 100%) !important;
}
.collection-banner {
  min-height: clamp(240px,33vw,430px);
  border-bottom: 1px solid rgba(209,154,83,.55);
  background:
    linear-gradient(90deg,rgba(0,0,0,.9) 0%,rgba(0,0,0,.58) 38%,rgba(0,0,0,.18) 78%),
    url("/images/hifi-turntable-hero-desktop.webp") 58% 58%/cover no-repeat !important;
  box-shadow: inset 0 -90px 120px rgba(0,0,0,.74), 0 18px 55px rgba(0,0,0,.45);
}
.collection-banner::after {
  background:
    radial-gradient(ellipse at 70% 62%,rgba(255,142,52,.18),transparent 28%),
    linear-gradient(180deg,rgba(0,0,0,.1),rgba(0,0,0,.72));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04), inset 0 -32px 60px rgba(0,0,0,.75);
}
.collection-banner-link {
  align-items: flex-start;
  max-width: min(92%,1180px);
  margin: 0;
  padding-left: clamp(28px,8vw,150px);
  color: #fff5e7;
  text-align: left;
}
.collection-banner-kicker,
.collection-banner-title em,
.stats strong,
.filters > div button,
.filter-dropdown-trigger strong,
.card-copy p,
.card-copy h4,
.playlist-item p,
.discogs-link,
.footer-contact a,
.protected-contact { color: var(--tube); }
.collection-banner-title strong,
.filters h2,
.graphics-intro h2,
.playlist-heading h2,
.feedback-copy h2,
.feedback-feed h3,
.detail-layout h2,
.card-copy h3,
.playlist-item h3,
dd { color: #f7ead8; }
.collection-banner-rule {
  margin-left: 0;
  background: linear-gradient(90deg,var(--tube),rgba(209,154,83,.75),transparent);
  box-shadow: 0 0 22px rgba(255,138,42,.38);
}
.collection-banner-subtitle,
.side-tracks,
.stats span,
.card-copy span,
.feedback-copy p:not(.eyebrow),
.feedback-item time,
.feedback-item > span,
dt,
.filter-dropdown-empty,
.style-subdivision-empty,
.grid-loading span:last-child,
footer { color: var(--muted); }
.stats,
.toolbar,
.feedback-section,
.jukebox-playlist,
footer {
  border-color: rgba(209,154,83,.25);
  background: linear-gradient(90deg,#070706,#17130f 50%,#090807) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 12px 34px rgba(0,0,0,.35) !important;
}
.catalogue,
main { background: transparent; }
.search-row .artist-only-option,
.search-row input,
.toolbar select,
.sort-control select,
.view-switcher button,
#mobile-filters,
.filter-dropdown-trigger,
#pagination button {
  color: #f3eadb;
  border-color: rgba(209,154,83,.34) !important;
  background: linear-gradient(#211d17,#14120f) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 3px 0 rgba(0,0,0,.55), 0 8px 18px rgba(0,0,0,.24) !important;
}
.search-row input::placeholder { color: #8f8170; }
.search-submit,
.sort-control label,
.view-switcher button.active,
#mobile-filters.has-active-filters,
#pagination button.active,
#search-form button,
.primary,
.detail-playlist-button {
  color: #140b05 !important;
  border-color: #9b4f20 !important;
  background: linear-gradient(#ffad62,var(--tube)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.34), 0 3px 0 #7e3b14, 0 0 22px rgba(255,138,42,.24) !important;
}
.search-reset,
.search-row .search-reset {
  color: #160c06 !important;
  border-color: #9b4f20 !important;
  background: linear-gradient(#e8b36e,var(--gold)) !important;
}
.chart-filter,
.graph-criteria,
.graphics-window,
.grid-loading,
.empty,
.feedback-copy,
.feedback-feed,
.feedback-form,
.feedback-item,
.playlist-item,
.view-list article {
  color: #f3eadb;
  border-color: rgba(209,154,83,.28) !important;
  background: rgba(20,18,14,.9) !important;
  box-shadow: 0 12px 30px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.04) !important;
}
.filters,
.filter-dropdown-panel,
.style-subdivision-panel {
  color: #f3eadb;
  border-color: rgba(209,154,83,.38);
  background: rgba(18,16,13,.98);
  box-shadow: 0 22px 55px rgba(0,0,0,.56);
}
.filter-dropdown-panel button,
.style-subdivision-panel button,
.style-category-trigger { color: #f3eadb; }
.filter-dropdown-panel button:hover,
.filter-dropdown-panel button:focus-visible,
.filter-dropdown-panel button.selected,
.style-category-trigger:hover,
.style-category-trigger:focus,
.style-category.selected .style-category-trigger {
  color: var(--tube);
  background: rgba(255,138,42,.12);
}
.cover {
  border-color: rgba(209,154,83,.34);
  background: #0d0c0a;
  box-shadow: 0 12px 30px rgba(0,0,0,.48);
}
.result-card:hover .cover,
.result-card:focus-visible .cover {
  border-color: var(--tube);
  box-shadow: 0 14px 36px rgba(0,0,0,.54), 0 0 0 3px rgba(255,138,42,.18), 0 0 26px rgba(255,138,42,.2);
}
.collection-graphics {
  background:
    linear-gradient(rgba(9,9,8,.78),rgba(9,9,8,.9)),
    url("/images/hifi-room-desktop.webp") center 58%/cover fixed no-repeat;
}
.graphics-window { backdrop-filter: blur(2px); }
.graphics-intro-image img {
  filter: saturate(1.08) contrast(1.08) drop-shadow(0 10px 18px rgba(0,0,0,.44));
  mix-blend-mode: normal;
}
.year-chart .axis,
.year-chart .ticks line { stroke: rgba(209,154,83,.3); }
.year-chart text,
.style-table-header,
.style-selection-count,
.style-category-trigger > strong { fill: var(--muted); color: var(--muted); }
.style-category-trigger > div { background: #0d0b09; }
.feedback-form input:not([type="checkbox"]),
.feedback-form textarea {
  color: #f3eadb;
  border-color: rgba(209,154,83,.34);
  background: #100f0d;
}
dialog { background: #0b0a08; }
dialog::backdrop { background: rgba(0,0,0,.82); backdrop-filter: blur(3px); }
.close,
.feedback-close {
  color: #120a05;
  background: #f4e4ce;
}
#details {
  border-color: rgba(209,154,83,.42) !important;
  background: #0c0b09 !important;
}
.detail-cover { background: radial-gradient(circle at 50% 42%,#211912 0%,#080706 66%) !important; }
.detail-info {
  color: #f3eadb;
  border-left-color: rgba(209,154,83,.28) !important;
  background: rgba(18,16,13,.96) !important;
}
.detail-layout h3,
.side-tracks strong { color: var(--tube); }
dl,
dl div,
.detail-info dl,
.detail-info dl div { border-color: rgba(209,154,83,.22) !important; }
.notes { background: rgba(255,138,42,.07); }
.detail-playlist-button.is-selected {
  color: #130a04 !important;
  border-color: #a7712f !important;
  background: linear-gradient(#f2c478,var(--gold)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.32), 0 3px 0 #7c541f !important;
}
#details {
  max-height: 80vh !important;
  overflow: hidden !important;
}
#detail-content,
.detail-layout {
  max-height: 80vh !important;
  min-height: 0;
}
.detail-info {
  max-height: 80vh !important;
  overflow-y: auto !important;
  scrollbar-color: rgba(255,138,42,.58) rgba(255,255,255,.08);
}
.detail-info dl {
  flex: 0 0 auto !important;
  overflow: visible !important;
}
.detail-info dd,
.detail-info dl .notes dd {
  max-height: none !important;
  overflow: visible !important;
  text-overflow: clip !important;
  white-space: normal;
}
.side-tracks {
  display: grid;
  gap: 14px;
  margin: 18px 0 16px !important;
  padding: 16px 18px;
  border: 1px solid rgba(209,154,83,.22);
  border-radius: 8px;
  color: #f2e4d2 !important;
  background: rgba(255,138,42,.055);
}
.side-track-group {
  display: grid;
  gap: 7px;
}
.side-track-group h4 {
  margin: 0;
  color: var(--tube);
  font-size: 12px;
  font-weight: 850;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.side-track-group ul {
  display: grid;
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.side-track-group li {
  position: relative;
  padding-left: 14px;
  line-height: 1.35;
}
.side-track-group li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .62em;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 10px rgba(255,138,42,.34);
}

/* Dark hi-fi graph and dropdown polish */
.style-theme-rock { --style-color: #d65d43; --style-dark: #5f2018; --style-accent: #ffb06f; }
.style-theme-pop { --style-color: #d8ac4c; --style-dark: #6b4714; --style-accent: #ffe3a0; }
.style-theme-electronic-dance { --style-color: #35a7b8; --style-dark: #164b56; --style-accent: #8deef2; }
.style-theme-jazz { --style-color: #8f6fd0; --style-dark: #3c2868; --style-accent: #d7c2ff; }
.style-theme-soul-funk-rnb { --style-color: #c56a9f; --style-dark: #622748; --style-accent: #ffc0dd; }
.style-theme-folk-acoustic { --style-color: #b48a4d; --style-dark: #553817; --style-accent: #e9ca83; }
.style-theme-blues { --style-color: #477fc5; --style-dark: #183963; --style-accent: #9ec8ff; }
.style-theme-stage-screen-other { --style-color: #8f98a8; --style-dark: #3a414b; --style-accent: #d4dbe6; }
.style-theme-reggae-ska { --style-color: #4ca66f; --style-dark: #1f5435; --style-accent: #f4d35b; }
.style-theme-country { --style-color: #bd7b3f; --style-dark: #61330f; --style-accent: #efbf77; }
.style-theme-latin-world { --style-color: #e77b4f; --style-dark: #722912; --style-accent: #ffc4a8; }
.style-theme-hip-hop-rap { --style-color: #c4973c; --style-dark: #21180b; --style-accent: #f1d37b; }
.style-theme-uncategorized,
.style-theme-default { --style-color: #a69b8f; --style-dark: #4e4842; --style-accent: #ded2c5; }

.filter-dropdown-panel,
.style-subdivision-panel {
  border-color: rgba(225,166,84,.42) !important;
  background:
    linear-gradient(180deg,rgba(39,31,22,.98),rgba(14,13,11,.99) 46%,rgba(8,8,7,.99)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    inset 0 -1px 0 rgba(0,0,0,.75),
    0 18px 46px rgba(0,0,0,.68),
    0 0 0 1px rgba(255,138,42,.08) !important;
  scrollbar-color: rgba(255,138,42,.58) rgba(255,255,255,.06);
}
.filter-dropdown-panel button,
.style-subdivision-panel button {
  min-height: 28px;
  border-radius: 5px;
  color: #eadac4 !important;
}
.filter-dropdown-panel button:hover,
.filter-dropdown-panel button:focus-visible {
  color: #fff4e6 !important;
  border-color: rgba(255,138,42,.5) !important;
  background: linear-gradient(90deg,rgba(255,138,42,.2),rgba(209,154,83,.08)) !important;
}
.filter-dropdown-panel button.selected {
  color: #170d06 !important;
  border-color: #e18d45 !important;
  background: linear-gradient(#f2bc74,#d28c39) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.32), 0 0 18px rgba(255,138,42,.18);
}
.style-subdivision-panel {
  border-color: color-mix(in srgb,var(--style-color) 46%,rgba(225,166,84,.34)) !important;
  background:
    linear-gradient(180deg,color-mix(in srgb,var(--style-dark) 48%,#17130f),#0b0a08 72%) !important;
}
.style-subdivision-panel button {
  grid-template-columns: minmax(0,max-content) auto;
  border-color: transparent !important;
}
.style-subdivision-panel button:hover,
.style-subdivision-panel button:focus-visible {
  color: #fff8ee !important;
  border-color: color-mix(in srgb,var(--style-color) 62%,#f2d6a3) !important;
  background:
    linear-gradient(90deg,color-mix(in srgb,var(--style-color) 28%,transparent),rgba(255,255,255,.035)) !important;
}
.style-subdivision-panel button.selected {
  color: #fff8ee !important;
  border-color: color-mix(in srgb,var(--style-color) 76%,#f2d6a3) !important;
  background:
    linear-gradient(90deg,color-mix(in srgb,var(--style-color) 46%,#130f0c),color-mix(in srgb,var(--style-dark) 65%,#0b0a08)) !important;
  box-shadow: inset 3px 0 0 var(--style-accent), 0 0 18px color-mix(in srgb,var(--style-color) 24%,transparent);
}
.style-subdivision-panel strong {
  color: color-mix(in srgb,var(--style-accent) 78%,#f3eadb) !important;
}
.style-select-all {
  color: #fff3e3 !important;
  border-color: color-mix(in srgb,var(--style-color) 62%,#f2d6a3) !important;
  background:
    linear-gradient(90deg,color-mix(in srgb,var(--style-color) 38%,#18110d),rgba(255,255,255,.045)) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.style-select-all.selected {
  background:
    linear-gradient(90deg,color-mix(in srgb,var(--style-color) 58%,#231810),color-mix(in srgb,var(--style-dark) 60%,#100d0b)) !important;
  box-shadow: inset 3px 0 0 var(--style-accent), 0 0 20px color-mix(in srgb,var(--style-color) 26%,transparent) !important;
}
.style-category-trigger {
  border: 1px solid transparent;
  border-radius: 7px;
}
.style-category-trigger > span::before {
  box-shadow: inset 0 -8px 0 var(--style-dark), 0 0 12px color-mix(in srgb,var(--style-color) 28%,transparent);
}
.style-category-trigger > div {
  background: linear-gradient(180deg,#070706,#15110d) !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08), inset 0 2px 5px rgba(0,0,0,.68) !important;
}
.style-category-trigger i {
  background: linear-gradient(90deg,var(--style-dark),var(--style-color),var(--style-accent));
  box-shadow: 0 0 13px color-mix(in srgb,var(--style-color) 38%,transparent);
}
.style-category-trigger:hover,
.style-category:focus-within .style-category-trigger {
  color: #fff6ea !important;
  border-color: color-mix(in srgb,var(--style-color) 42%,rgba(225,166,84,.22));
  background: linear-gradient(90deg,color-mix(in srgb,var(--style-color) 14%,#16120e),rgba(255,255,255,.025)) !important;
}
.style-category.selected .style-category-trigger {
  color: #fff8ee !important;
  border-color: color-mix(in srgb,var(--style-color) 68%,#f2d6a3);
  background: linear-gradient(90deg,color-mix(in srgb,var(--style-color) 24%,#19120d),rgba(255,255,255,.035)) !important;
  outline: 0 !important;
  box-shadow: inset 3px 0 0 var(--style-accent), 0 0 20px color-mix(in srgb,var(--style-color) 18%,transparent);
}
.style-selection-count,
.style-category-trigger > strong {
  color: #d9c8b2 !important;
}
.year-chart .axis,
.year-chart .ticks line {
  stroke: rgba(225,166,84,.24) !important;
}
.year-guides line {
  stroke: rgba(143,111,208,.12) !important;
}
.year-chart text {
  fill: #bca98e !important;
}
.year-stack-segment {
  filter: saturate(1.12) brightness(1.04) drop-shadow(0 0 3px rgba(0,0,0,.36));
}
.year-range-excluded {
  fill: rgba(8,8,7,.5) !important;
  stroke: rgba(225,166,84,.35) !important;
}
.year-range-handle {
  stroke: var(--tube) !important;
  filter: drop-shadow(0 0 5px rgba(255,138,42,.42)) !important;
}
@media (max-width: 1180px) {
  .collection-banner {
    background:
      linear-gradient(90deg,rgba(0,0,0,.9) 0%,rgba(0,0,0,.58) 42%,rgba(0,0,0,.25) 86%),
      url("/images/hifi-turntable-hero-tablet.webp") 58% 58%/cover no-repeat !important;
  }
  .collection-graphics { background-image: linear-gradient(rgba(9,9,8,.8),rgba(9,9,8,.93)), url("/images/hifi-room-tablet.webp"); }
}
@media (max-width: 760px) {
  .collection-banner {
    min-height: 220px;
    background:
      linear-gradient(90deg,rgba(0,0,0,.9),rgba(0,0,0,.55)),
      url("/images/hifi-turntable-hero-mobile.webp") 61% 54%/cover no-repeat !important;
  }
  .collection-banner-link {
    align-items: flex-start;
    max-width: 100%;
    min-height: 220px;
    padding: 22px 20px;
    text-align: left;
  }
  .collection-banner-title { font-size: clamp(34px,10vw,48px); }
  .collection-banner-subtitle { max-width: 250px; }
  .collection-graphics {
    background-image: linear-gradient(rgba(9,9,8,.84),rgba(9,9,8,.96)), url("/images/hifi-room-mobile.webp");
    background-attachment: scroll;
  }
  #details,
  #detail-content,
  .detail-layout {
    max-height: calc(100vh - 28px) !important;
  }
  .detail-info {
    max-height: none !important;
    overflow: visible !important;
  }
  .side-tracks {
    padding: 14px;
  }
}
