/* WeltRadio One v291 - gebündelte aktive CSS-Datei. Reihenfolge entspricht den bisherigen HTML-Einbindungen. */


/* ===== css/00-base.css ===== */
/* Basis, Variablen, Grundlayout und Hauptkomponenten */
:root {
  color-scheme: dark;
  --bg: #0f1117;
  --bg-soft: #151923;
  --panel: rgba(25, 30, 43, 0.92);
  --panel-solid: #191e2b;
  --panel-strong: #20283a;
  --text: #f5f7fb;
  --muted: #a9b1c7;
  --muted-2: #778197;
  --line: rgba(255, 255, 255, 0.1);
  --brand: #ff385c;
  --brand-2: #7c4dff;
  --good: #35d58d;
  --warn: #ffd166;
  --bad: #ff6b6b;
  --shadow: 0 22px 70px rgba(0, 0, 0, 0.32);
  --radius-xl: 28px;
  --radius-lg: 20px;
  --radius-md: 14px;
  --radius-sm: 10px;
  --topbar-h: 76px;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

html[data-theme="light"] {
  color-scheme: light;
  --bg: #f6f7fb;
  --bg-soft: #ffffff;
  --panel: rgba(255, 255, 255, 0.94);
  --panel-solid: #ffffff;
  --panel-strong: #edf0f7;
  --text: #171b27;
  --muted: #5e6678;
  --muted-2: #7d8799;
  --line: rgba(20, 25, 40, 0.12);
  --shadow: 0 18px 50px rgba(30, 40, 70, 0.12);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(255, 56, 92, 0.16), transparent 34rem),
    radial-gradient(circle at 70% 10%, rgba(124, 77, 255, 0.18), transparent 28rem),
    var(--bg);
  color: var(--text);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image: linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 54px 54px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.6), transparent 70%);
}

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

button { cursor: pointer; }

button:disabled { cursor: not-allowed; opacity: 0.55; }

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

.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;
}

.skip-link {
  position: fixed;
  left: 1rem;
  top: -4rem;
  z-index: 30;
  background: var(--brand);
  color: white;
  padding: .85rem 1rem;
  border-radius: var(--radius-sm);
  transition: top .2s ease;
}
.skip-link:focus { top: 1rem; }

.topbar {
  position: sticky;
  top: 0;
  z-index: 20;
  height: var(--topbar-h);
  display: grid;
  grid-template-columns: auto minmax(240px, 1fr) auto;
  gap: 1rem;
  align-items: center;
  padding: .9rem clamp(1rem, 3vw, 2rem);
  background: color-mix(in oklab, var(--bg) 86%, transparent);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(18px);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: .7rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  white-space: nowrap;
}
.brand-mark {
  width: 2.25rem;
  height: 2.25rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  color: white;
  box-shadow: 0 10px 24px rgba(255, 56, 92, .28);
}
.brand-text { font-size: 1.16rem; }

.search-shell {
  display: grid;
  grid-template-columns: 1fr auto;
  max-width: 760px;
  width: 100%;
  justify-self: center;
  border: 1px solid var(--line);
  background: var(--panel-solid);
  border-radius: 999px;
  overflow: hidden;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.02);
}
.search-shell input {
  min-width: 0;
  color: var(--text);
  background: transparent;
  border: 0;
  outline: 0;
  padding: .85rem 1.1rem;
}
.search-shell:focus-within {
  border-color: color-mix(in oklab, var(--brand) 65%, white 20%);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--brand) 18%, transparent);
}

.top-actions, .action-row, .transport-row, .mix-controls, .toolbar-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  align-items: center;
}

.icon-button, .soft-button, .primary-button, .link-button, .favorite-main, .star-button {
  border: 1px solid var(--line);
  background: var(--panel-strong);
  color: var(--text);
  min-height: 42px;
  border-radius: 999px;
  padding: .65rem .92rem;
  transition: transform .16s ease, border-color .16s ease, background .16s ease, box-shadow .16s ease;
}
.icon-button:hover, .soft-button:hover, .primary-button:hover, .favorite-main:hover, .star-button:hover {
  transform: translateY(-1px);
  border-color: color-mix(in oklab, var(--brand) 45%, var(--line));
}
.icon-button:focus-visible, .soft-button:focus-visible, .primary-button:focus-visible, .favorite-main:focus-visible, input:focus-visible, select:focus-visible, .station-card:focus-visible {
  outline: 3px solid color-mix(in oklab, var(--brand) 45%, transparent);
  outline-offset: 3px;
}
.icon-button { min-width: 42px; padding-inline: .75rem; }
.primary-button {
  border-color: transparent;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  color: white;
  font-weight: 800;
  box-shadow: 0 12px 30px rgba(255, 56, 92, .24);
}
.soft-button.small { min-height: 34px; padding: .45rem .65rem; font-size: .83rem; }
.link-button {
  border: 0;
  background: transparent;
  color: var(--muted);
  padding: .3rem .45rem;
  min-height: auto;
  text-decoration: underline transparent;
}
.link-button:hover { color: var(--text); text-decoration-color: currentColor; transform: none; }

.genre-strip {
  position: sticky;
  top: var(--topbar-h);
  z-index: 15;
  display: flex;
  gap: .55rem;
  overflow-x: auto;
  padding: .75rem clamp(1rem, 3vw, 2rem);
  background: color-mix(in oklab, var(--bg) 78%, transparent);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--line);
  scrollbar-width: thin;
}
.genre-chip {
  flex: 0 0 auto;
  border: 1px solid var(--line);
  background: var(--panel-solid);
  color: var(--text);
  border-radius: 999px;
  padding: .6rem .95rem;
  white-space: nowrap;
}
.genre-chip.active {
  background: var(--text);
  color: var(--bg);
  border-color: transparent;
  font-weight: 800;
}

.app-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.42fr) minmax(380px, .78fr);
  gap: 1rem;
  padding: 1rem clamp(1rem, 3vw, 2rem) 2rem;
}
.player-column, .list-column { min-width: 0; display: grid; gap: 1rem; align-content: start; }

.hero-player, .panel, .mix-panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
}
.hero-player { overflow: hidden; }
.visual-stage {
  position: relative;
  aspect-ratio: 16 / 9;
  display: grid;
  place-items: center;
  overflow: hidden;
  isolation: isolate;
  background:
    radial-gradient(circle at 50% 40%, rgba(255,255,255,.08), transparent 32%),
    linear-gradient(135deg, #151824, #0c0e15);
}
.visual-stage img {
  width: min(34%, 240px);
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 26%;
  box-shadow: 0 28px 100px rgba(0,0,0,.38);
  z-index: 2;
  background: rgba(255,255,255,.06);
}
.visual-glow {
  position: absolute;
  inset: 12%;
  border-radius: 50%;
  background: conic-gradient(from 30deg, var(--brand), var(--brand-2), #19d3ff, var(--brand));
  filter: blur(70px);
  opacity: .42;
  animation: rotateGlow 14s linear infinite;
}
@keyframes rotateGlow { to { transform: rotate(360deg); } }
.status-pill {
  position: absolute;
  left: 1rem;
  bottom: 1rem;
  z-index: 3;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(0,0,0,.45);
  color: white;
  padding: .55rem .8rem;
  backdrop-filter: blur(10px);
}
.status-pill.ok { background: color-mix(in oklab, var(--good) 40%, rgba(0,0,0,.62)); }
.status-pill.warn { background: color-mix(in oklab, var(--warn) 42%, rgba(0,0,0,.62)); }
.status-pill.bad { background: color-mix(in oklab, var(--bad) 45%, rgba(0,0,0,.62)); }

.station-headline, .audio-panel, .action-row, .meta-grid, .tag-row { padding-inline: 1.25rem; }
.station-headline {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1rem;
  padding-top: 1.15rem;
  align-items: start;
}
.eyebrow {
  margin: 0 0 .35rem;
  color: var(--brand);
  font-size: .78rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .14em;
}
h1, h2, h3, p { margin-top: 0; }
h1 { margin-bottom: .45rem; font-size: clamp(1.6rem, 3vw, 2.65rem); line-height: 1.05; letter-spacing: -0.05em; }
h2 { margin-bottom: 0; font-size: 1.15rem; }
h3 { margin: 0; font-size: .96rem; line-height: 1.25; }
#stationSubtitle { margin-bottom: 0; color: var(--muted); }
.favorite-main { width: 3rem; height: 3rem; padding: 0; font-size: 1.45rem; }
.favorite-main.active, .star-button.active { color: #ffd166; }

.meta-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .6rem;
  padding-top: 1rem;
}
.meta-grid span, .mini-badge, .badge {
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  background: color-mix(in oklab, var(--panel-strong) 70%, transparent);
  padding: .52rem .75rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: .86rem;
}
.tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  padding-top: .8rem;
  min-height: 44px;
}
.tag { border-radius: 999px; background: color-mix(in oklab, var(--brand-2) 17%, transparent); color: var(--text); padding: .42rem .68rem; font-size: .82rem; }

.audio-panel {
  padding-top: .9rem;
  display: grid;
  gap: .8rem;
}
input[type="range"] { accent-color: var(--brand); width: 100%; }
input, select, textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--panel-strong);
  color: var(--text);
  padding: .75rem .85rem;
  outline: 0;
}
select[multiple] { min-height: 9rem; border-radius: var(--radius-lg); }
.action-row { padding-top: 1rem; padding-bottom: 1.25rem; }

.mix-panel, .panel { padding: 1rem; }
.section-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}
.section-title.compact { margin-bottom: .75rem; }
.mix-grid, .filter-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .8rem;
}
.mix-grid label, .filter-grid label, .mix-options label, .check-grid label {
  color: var(--muted);
  font-size: .9rem;
  display: grid;
  gap: .35rem;
}
.custom-interval { display: none !important; }
.custom-interval.show { display: grid !important; }
.mix-options, .check-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
  margin-top: 1rem;
}
.mix-options input[type="checkbox"], .check-grid input[type="checkbox"] { width: auto; accent-color: var(--brand); }
.mix-controls { margin-top: 1rem; }
.helper-text { color: var(--muted); margin: .8rem 0 0; font-size: .86rem; }


/* ===== css/10-sender-mix-base.css ===== */
/* Sender-Mix Grundfelder und Chips */
/* Sender-Mix: aufgeräumte Felder, Chip-Auswahl und große Switches */
.mix-grid { align-items: start; }
.mix-field, .mix-options .mix-field {
  color: var(--muted);
  font-size: .9rem;
  display: grid;
  gap: .45rem;
  align-content: start;
}
.mix-field > label, .mix-field label {
  color: var(--muted);
  font-size: .9rem;
}
.field-note {
  color: var(--muted-2);
  font-size: .78rem;
}
.mix-genre-native {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  min-height: 1px !important;
  padding: 0 !important;
  border: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
.mix-genre-chips {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  min-height: 3.15rem;
  max-height: 8.4rem;
  overflow: auto;
  padding: .65rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: color-mix(in oklab, var(--panel-strong) 82%, transparent);
  scrollbar-width: thin;
}
.mix-genre-chip {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: color-mix(in oklab, var(--panel-solid) 68%, transparent);
  color: var(--muted);
  min-height: 34px;
  padding: .46rem .74rem;
  font-size: .86rem;
  font-weight: 700;
}
.mix-genre-chip:hover {
  color: var(--text);
  border-color: color-mix(in oklab, var(--brand) 40%, var(--line));
  transform: translateY(-1px);
}
.mix-genre-chip.selected {
  color: white;
  border-color: transparent;
  background: linear-gradient(135deg, color-mix(in oklab, var(--brand) 88%, white 0%), var(--brand-2));
  box-shadow: 0 10px 22px rgba(255, 56, 92, .18);
}
.mix-switch {
  position: relative;
  display: flex !important;
  grid-template-columns: none !important;
  align-items: center;
  gap: .75rem !important;
  min-height: 54px;
  padding: .78rem .88rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: color-mix(in oklab, var(--panel-strong) 82%, transparent);
  color: var(--text) !important;
  cursor: pointer;
}
.mix-switch input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.switch-ui {
  position: relative;
  flex: 0 0 auto;
  width: 46px;
  height: 26px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: color-mix(in oklab, var(--bg) 65%, var(--panel-strong));
  transition: background .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.switch-ui::after {
  content: "";
  position: absolute;
  left: 3px;
  top: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--muted);
  transition: transform .18s ease, background .18s ease;
}
.mix-switch input:checked + .switch-ui {
  border-color: transparent;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  box-shadow: 0 8px 22px rgba(255, 56, 92, .2);
}
.mix-switch input:checked + .switch-ui::after {
  transform: translateX(20px);
  background: white;
}
.mix-switch input:focus-visible + .switch-ui {
  outline: 3px solid color-mix(in oklab, var(--brand) 45%, transparent);
  outline-offset: 3px;
}

.list-column { position: sticky; top: calc(var(--topbar-h) + 58px + 1rem); max-height: calc(100vh - var(--topbar-h) - 72px); }
.filters { display: none; }
.filters.open { display: block; }
.tabs-panel { min-height: 0; display: grid; grid-template-rows: auto auto minmax(0, 1fr) auto; }
.tabs { display: flex; gap: .35rem; padding: .25rem; border-radius: 999px; background: var(--panel-strong); }
.tab {
  flex: 1;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  padding: .58rem .75rem;
}
.tab.active { background: var(--panel-solid); color: var(--text); font-weight: 800; box-shadow: 0 6px 20px rgba(0,0,0,.12); }
.list-toolbar {
  display: flex;
  justify-content: space-between;
  gap: .75rem;
  align-items: center;
  padding: .95rem 0;
}
.list-toolbar p { color: var(--muted); font-size: .82rem; margin: .2rem 0 0; }
.import-label { display: inline-grid; place-items: center; }
.station-list {
  overflow: auto;
  display: grid;
  gap: .7rem;
  padding-right: .15rem;
  min-height: 250px;
  max-height: calc(100vh - 250px);
  scrollbar-width: thin;
}
.station-card {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: .75rem;
  align-items: start;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: color-mix(in oklab, var(--panel-strong) 72%, transparent);
  padding: .72rem;
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
  cursor: pointer;
}
.station-card:hover { transform: translateY(-1px); border-color: color-mix(in oklab, var(--brand) 45%, var(--line)); }
.station-card.active {
  border-color: color-mix(in oklab, var(--brand) 70%, white 10%);
  background: color-mix(in oklab, var(--brand) 15%, var(--panel-strong));
}
.station-card.next-in-mix { border-style: dashed; border-color: color-mix(in oklab, var(--brand-2) 70%, white 10%); }
.station-card.error { opacity: .66; }
.station-card-logo {
  width: 72px;
  height: 72px;
  object-fit: cover;
  border-radius: 20px;
  background: rgba(255,255,255,.05);
}
.station-card-topline { display: grid; grid-template-columns: 1fr auto; gap: .35rem; align-items: start; }
.star-button { min-height: 32px; min-width: 32px; width: 32px; height: 32px; padding: 0; }
.station-card-meta { color: var(--muted); font-size: .82rem; margin: .25rem 0 .4rem; }
.station-card-tags, .station-card-badges { display: flex; gap: .35rem; flex-wrap: wrap; }
.station-card-tags .tag { font-size: .72rem; padding: .28rem .48rem; }
.badge { font-size: .72rem; padding: .32rem .48rem; }
.badge.ok { color: var(--good); }
.badge.warn { color: var(--warn); }
.badge.bad { color: var(--bad); }
.empty-state {
  margin-top: 1rem;
  border: 1px dashed var(--line);
  border-radius: var(--radius-lg);
  padding: 1rem;
  color: var(--muted);
}
.empty-state strong { color: var(--text); }

.footer {
  display: flex;
  flex-wrap: wrap;
  gap: .7rem;
  align-items: center;
  padding: 1rem clamp(1rem, 3vw, 2rem) 2rem;
  color: var(--muted);
  border-top: 1px solid var(--line);
}

.modal {
  width: min(720px, calc(100% - 2rem));
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: var(--panel-solid);
  color: var(--text);
  box-shadow: var(--shadow);
  padding: 1.3rem;
}
.modal::backdrop { background: rgba(0,0,0,.68); backdrop-filter: blur(6px); }
.modal-close { position: absolute; right: 1rem; top: 1rem; }
.modal h2 { font-size: 1.55rem; margin-bottom: .8rem; }
.modal p, .modal li { color: var(--muted); line-height: 1.6; }

.skeleton {
  border-radius: var(--radius-lg);
  height: 96px;
  background: linear-gradient(90deg, var(--panel-strong), color-mix(in oklab, var(--panel-strong) 70%, white 7%), var(--panel-strong));
  background-size: 220% 100%;
  animation: shimmer 1.2s ease-in-out infinite;
}
@keyframes shimmer { to { background-position: -220% 0; } }

@media (max-width: 1180px) {
  .topbar { grid-template-columns: 1fr auto; height: auto; }
  .search-shell { grid-column: 1 / -1; grid-row: 2; max-width: none; }
  .top-actions { justify-content: flex-end; }
  .genre-strip { top: 118px; }
  .app-grid { grid-template-columns: 1fr; }
  .list-column { position: static; max-height: none; }
  .station-list { max-height: none; }
}

@media (max-width: 760px) {
  :root { --topbar-h: 0px; }
  .topbar { position: static; grid-template-columns: 1fr; align-items: stretch; }
  .brand { justify-content: center; }
  .top-actions { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .top-actions > * { width: 100%; }
  .genre-strip { position: static; }
  .app-grid { padding-inline: .75rem; }
  .visual-stage { aspect-ratio: 4 / 3; }
  .visual-stage img { width: min(48%, 190px); }
  .station-headline { grid-template-columns: 1fr; }
  .favorite-main { justify-self: start; }
  .meta-grid, .mix-grid, .filter-grid, .mix-options, .check-grid, .countdown-card { grid-template-columns: 1fr; }
  .list-toolbar { flex-direction: column; align-items: stretch; }
  .toolbar-buttons { display: grid; grid-template-columns: 1fr; }
  .station-card { grid-template-columns: 56px 1fr; }
  .station-card-logo { width: 56px; height: 56px; border-radius: 16px; }
  .hero-player { position: sticky; top: 0; z-index: 10; }
  .action-row, .transport-row, .mix-controls { display: grid; grid-template-columns: 1fr; }
}

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


/* ===== css/20-player-fullscreen.css ===== */
/* Player, Lautstärke, Vollbild und Statusbereiche */
.stage-control-row {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: .65rem;
  padding: .85rem 1.25rem .1rem;
  border-bottom: 1px solid var(--line);
  background: color-mix(in oklab, var(--panel-strong) 34%, transparent);
}
.stage-volume {
  display: grid;
  grid-template-columns: auto minmax(160px, 1fr) auto;
  align-items: center;
  gap: .7rem;
  width: min(100%, 560px);
  color: var(--muted);
}
.stage-volume label {
  white-space: nowrap;
  font-size: .9rem;
}
.fullscreen-stage-button {
  white-space: nowrap;
}
.visual-stage:fullscreen {
  width: 100vw;
  height: 100vh;
  aspect-ratio: auto;
  border-radius: 0;
  background:
    radial-gradient(circle at 50% 40%, rgba(255,255,255,.1), transparent 30%),
    linear-gradient(135deg, #151824, #05070d);
}
.visual-stage:fullscreen img {
  width: min(38vmin, 340px);
}
.visual-stage:fullscreen .status-pill {
  left: 2rem;
  bottom: 2rem;
}
.custom-interval.show {
  grid-column: 2;
}
.custom-interval input:disabled {
  opacity: .55;
}

@media (max-width: 760px) {
  .stage-control-row {
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
  }
  .stage-volume {
    width: 100%;
    grid-template-columns: 1fr;
    align-items: stretch;
  }
  .fullscreen-stage-button {
    width: 100%;
  }
  .custom-interval.show {
    grid-column: 1;
  }
}

.stage-volume.is-muted,
.fullscreen-volume.is-muted {
  color: var(--muted-2);
}
.stage-volume.is-muted input[type="range"],
.fullscreen-volume.is-muted input[type="range"] {
  accent-color: var(--muted-2);
  filter: grayscale(1);
  opacity: .72;
}
.stage-volume.is-muted .soft-button,
.fullscreen-controls.is-muted .soft-button {
  border-color: color-mix(in oklab, var(--muted-2) 50%, transparent);
}
.fullscreen-top-hint,
.fullscreen-bottom-overlay {
  display: none;
}
.visual-stage:fullscreen .fullscreen-top-hint {
  position: absolute;
  top: 1.25rem;
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 12;
  padding: .55rem .85rem;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  color: rgba(255,255,255,.86);
  background: rgba(0,0,0,.42);
  backdrop-filter: blur(14px);
  font-size: .9rem;
}
.visual-stage:fullscreen .fullscreen-bottom-overlay {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1.25rem;
  z-index: 11;
  padding: 5.5rem clamp(1.25rem, 3vw, 2.25rem) clamp(1.25rem, 2.4vw, 1.75rem);
  background: linear-gradient(to top, rgba(0,0,0,.76), rgba(0,0,0,.34) 62%, transparent);
}
.visual-stage:fullscreen .fullscreen-controls {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: .7rem;
  min-width: min(44vw, 520px);
  padding: .65rem .75rem;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 999px;
  background: rgba(10,12,18,.62);
  backdrop-filter: blur(16px);
  box-shadow: 0 18px 60px rgba(0,0,0,.38);
}
.visual-stage:fullscreen .fullscreen-volume {
  display: grid;
  grid-template-columns: auto minmax(120px, 240px);
  align-items: center;
  gap: .65rem;
  color: rgba(255,255,255,.82);
  font-size: .9rem;
  width: auto;
}
.visual-stage:fullscreen .fullscreen-volume input {
  width: min(22vw, 240px);
}
.visual-stage:fullscreen .fullscreen-controls .soft-button {
  color: #fff;
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.16);
  white-space: nowrap;
}
.visual-stage:fullscreen .status-pill {
  left: 1.5rem;
  top: 1.5rem;
  bottom: auto;
}
.visual-stage:fullscreen img {
  transform: translateY(-2vh);
}
.custom-interval {
  display: grid;
}
.custom-interval input {
  opacity: 1;
}
.custom-interval.show,
.custom-interval {
  grid-column: auto;
}
.custom-interval .field-note,
.mix-field .field-note {
  display: block;
  color: var(--muted);
  font-size: .8rem;
  margin-top: .3rem;
}
@media (max-width: 760px) {
  .visual-stage:fullscreen .fullscreen-bottom-overlay {
    flex-direction: column;
    align-items: stretch;
  }
  .visual-stage:fullscreen .fullscreen-controls {
    min-width: 0;
    width: 100%;
    border-radius: var(--radius-lg);
    flex-wrap: wrap;
  }
  .visual-stage:fullscreen .fullscreen-volume {
    grid-template-columns: 1fr;
    flex: 1 1 100%;
  }
  .visual-stage:fullscreen .fullscreen-volume input {
    width: 100%;
  }
}

.hidden-audio-panel {
  display: none;
}
.stage-control-row {
  display: grid;
  grid-template-columns: minmax(280px, auto) minmax(220px, .9fr) minmax(220px, .8fr) auto;
  align-items: center;
  justify-content: stretch;
  gap: .8rem;
  padding: .95rem 1.25rem;
  border-bottom: 1px solid var(--line);
  background: color-mix(in oklab, var(--panel-strong) 42%, transparent);
}
.stage-transport {
  display: flex;
  align-items: center;
  gap: .55rem;
  flex-wrap: wrap;
  min-width: 0;
}
.stage-transport .primary-button,
.stage-transport .soft-button {
  min-height: 38px;
  padding: .55rem .85rem;
}
.stage-volume {
  width: 100%;
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(110px, 1fr) auto;
  align-items: center;
  gap: .7rem;
}
.stage-quality {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(120px, 1fr);
  align-items: center;
  gap: .65rem;
  color: var(--muted);
}
.stage-quality label,
.stage-volume label {
  font-size: .9rem;
  white-space: nowrap;
}
.stage-quality select {
  min-height: 38px;
  padding-block: .55rem;
  border-radius: 999px;
}
.fullscreen-stage-button {
  justify-self: end;
}
.visual-stage:fullscreen .fullscreen-bottom-overlay {
  flex-direction: column;
  align-items: stretch;
  gap: .9rem;
  padding: 5.5rem clamp(1rem, 3vw, 2.25rem) clamp(1rem, 2.2vw, 1.5rem);
}
.visual-stage:fullscreen .fullscreen-controls {
  width: 100%;
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(190px, .8fr) minmax(160px, .6fr) auto auto;
  align-items: center;
  justify-content: stretch;
  gap: .7rem;
  padding: .7rem .8rem;
  border-radius: 24px;
}
.visual-stage:fullscreen .fullscreen-transport {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .5rem;
  min-width: 0;
}
.visual-stage:fullscreen .fullscreen-controls .primary-button,
.visual-stage:fullscreen .fullscreen-controls .soft-button {
  color: #fff;
  border-color: rgba(255,255,255,.16);
  white-space: nowrap;
  min-height: 38px;
}
.visual-stage:fullscreen .fullscreen-controls .primary-button {
  border-color: transparent;
}
.visual-stage:fullscreen .fullscreen-quality,
.visual-stage:fullscreen .fullscreen-volume {
  display: grid;
  grid-template-columns: auto minmax(90px, 1fr);
  align-items: center;
  gap: .65rem;
  min-width: 0;
  color: rgba(255,255,255,.84);
  font-size: .9rem;
}
.visual-stage:fullscreen .fullscreen-quality select {
  min-height: 38px;
  padding: .5rem .75rem;
  border-radius: 999px;
  color: #fff;
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.16);
}
.visual-stage:fullscreen .fullscreen-volume input {
  width: 100%;
}
.visual-stage:fullscreen .fullscreen-controls.is-muted .fullscreen-volume input[type="range"],
.stage-volume.is-muted input[type="range"] {
  accent-color: var(--muted-2);
  filter: grayscale(1);
  opacity: .72;
}
@media (max-width: 1320px) {
  .stage-control-row {
    grid-template-columns: 1fr 1fr;
  }
  .stage-quality,
  .fullscreen-stage-button {
    justify-self: stretch;
  }
  .fullscreen-stage-button { width: 100%; }
  .visual-stage:fullscreen .fullscreen-controls {
    grid-template-columns: 1fr 1fr;
    border-radius: var(--radius-lg);
  }
}
@media (max-width: 820px) {
  .stage-control-row {
    grid-template-columns: 1fr;
  }
  .stage-transport,
  .stage-volume,
  .stage-quality {
    width: 100%;
  }
  .stage-transport .primary-button,
  .stage-transport .soft-button,
  .fullscreen-stage-button {
    flex: 1 1 auto;
  }
  .stage-quality,
  .stage-volume {
    grid-template-columns: 1fr;
    align-items: stretch;
  }
  .visual-stage:fullscreen .fullscreen-controls {
    grid-template-columns: 1fr;
  }
  .visual-stage:fullscreen .fullscreen-quality,
  .visual-stage:fullscreen .fullscreen-volume {
    grid-template-columns: 1fr;
  }
  .visual-stage:fullscreen .fullscreen-transport .primary-button,
  .visual-stage:fullscreen .fullscreen-transport .soft-button {
    flex: 1 1 auto;
  }
}

.stage-control-row {
  grid-template-columns: minmax(300px, auto) minmax(220px, 300px) minmax(240px, 360px) auto;
}
.stage-volume {
  grid-template-columns: auto minmax(110px, 180px) auto;
  justify-content: start;
}
.stage-volume input[type="range"] {
  width: min(18vw, 180px);
  max-width: 180px;
}
.stage-quality select {
  max-width: 360px;
  text-overflow: ellipsis;
}

.visual-stage:fullscreen .fullscreen-bottom-overlay {
  display: grid;
  grid-template-columns: 1fr;
  align-items: end;
  gap: .82rem;
  padding: 5.2rem clamp(1.1rem, 2.6vw, 2.2rem) clamp(.9rem, 1.8vw, 1.35rem);
}
.fullscreen-meta-pills {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .42rem;
}
.fullscreen-meta-pills span {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: .32rem .62rem;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  color: rgba(255,255,255,.84);
  background: rgba(8,10,16,.52);
  backdrop-filter: blur(12px);
  box-shadow: 0 8px 28px rgba(0,0,0,.2);
  font-size: clamp(.76rem, .88vw, .92rem);
  white-space: nowrap;
}
.visual-stage:fullscreen .fullscreen-controls {
  width: 100%;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: .55rem;
  padding: .64rem .72rem;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(8,10,16,.68);
  backdrop-filter: blur(18px);
  box-shadow: 0 18px 60px rgba(0,0,0,.42);
}
.visual-stage:fullscreen .fullscreen-transport {
  flex: 0 1 auto;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .42rem;
  min-width: 0;
}
.visual-stage:fullscreen .fullscreen-controls .primary-button,
.visual-stage:fullscreen .fullscreen-controls .soft-button {
  min-height: 34px;
  padding: .45rem .62rem;
  font-size: .78rem;
  line-height: 1;
}
.visual-stage:fullscreen .fullscreen-controls .primary-button {
  min-width: 66px;
}
.visual-stage:fullscreen .fullscreen-quality {
  flex: 0 1 330px;
  max-width: 330px;
  min-width: 190px;
  display: grid;
  grid-template-columns: auto minmax(120px, 1fr);
  align-items: center;
  gap: .5rem;
  color: rgba(255,255,255,.82);
  font-size: .82rem;
}
.visual-stage:fullscreen .fullscreen-quality select {
  width: 100%;
  max-width: 250px;
  min-height: 34px;
  padding: .43rem .62rem;
  border-radius: 999px;
  color: #fff;
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.16);
  text-overflow: ellipsis;
}
.visual-stage:fullscreen .fullscreen-right-controls {
  margin-left: auto;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: .5rem;
  min-width: 0;
}
.visual-stage:fullscreen .fullscreen-volume {
  flex: 0 0 auto;
  width: auto;
  display: grid;
  grid-template-columns: auto 150px;
  align-items: center;
  gap: .55rem;
  color: rgba(255,255,255,.82);
  font-size: .82rem;
}
.visual-stage:fullscreen .fullscreen-volume input[type="range"] {
  width: 150px !important;
  max-width: 150px;
}
.visual-stage:fullscreen .fullscreen-volume.is-muted input[type="range"],
.visual-stage:fullscreen .fullscreen-controls.is-muted .fullscreen-volume input[type="range"] {
  accent-color: rgba(190,196,212,.82);
  filter: grayscale(1);
  opacity: .68;
}
.visual-stage:fullscreen #fullscreenExitButton {
  min-width: 142px;
}
.visual-stage:fullscreen .status-pill {
  top: 1.35rem;
  left: 1.35rem;
}
.visual-stage:fullscreen img {
  width: min(24vmin, 240px);
  transform: translateY(-3vh);
}

@media (max-width: 1320px) {
  .stage-control-row {
    grid-template-columns: minmax(260px, 1fr) minmax(210px, 290px);
  }
  .stage-volume input[type="range"] {
    width: 100%;
  }
  .visual-stage:fullscreen .fullscreen-controls {
    flex-wrap: wrap;
  }
  .visual-stage:fullscreen .fullscreen-right-controls {
    margin-left: 0;
  }
}
@media (max-width: 900px) {
  .visual-stage:fullscreen .fullscreen-controls {
    align-items: stretch;
  }
  .visual-stage:fullscreen .fullscreen-transport,
  .visual-stage:fullscreen .fullscreen-quality,
  .visual-stage:fullscreen .fullscreen-right-controls {
    flex: 1 1 100%;
    max-width: none;
  }
  .visual-stage:fullscreen .fullscreen-right-controls {
    justify-content: flex-start;
    flex-wrap: wrap;
  }
  .visual-stage:fullscreen .fullscreen-volume {
    grid-template-columns: auto minmax(120px, 180px);
  }
}
@media (max-width: 720px) {
  .stage-control-row {
    grid-template-columns: 1fr;
  }
  .stage-volume,
  .stage-quality {
    grid-template-columns: 1fr;
  }
  .stage-volume input[type="range"],
  .stage-quality select {
    width: 100%;
    max-width: none;
  }
  .fullscreen-meta-pills span {
    font-size: .74rem;
    min-height: 28px;
  }
  .visual-stage:fullscreen .fullscreen-volume {
    grid-template-columns: 1fr;
    width: 100%;
  }
  .visual-stage:fullscreen .fullscreen-volume input[type="range"] {
    width: min(100%, 240px) !important;
    max-width: 240px;
  }
  .visual-stage:fullscreen #fullscreenExitButton {
    min-width: 0;
  }
}

.visual-stage:fullscreen .fullscreen-bottom-overlay {
  display: block;
  padding: 0 clamp(1rem, 2.4vw, 1.6rem) clamp(1rem, 2.2vw, 1.35rem);
  background: linear-gradient(to top, rgba(0,0,0,.84), rgba(0,0,0,.46) 58%, transparent);
}
.visual-stage:fullscreen .fullscreen-controls {
  width: 100%;
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(260px, 1.35fr) minmax(280px, auto) minmax(220px, .85fr) minmax(240px, auto);
  align-items: center;
  gap: .75rem;
  padding: .78rem .9rem;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(8,10,16,.72);
  backdrop-filter: blur(18px);
  box-shadow: 0 18px 60px rgba(0,0,0,.42);
}
.visual-stage:fullscreen .fullscreen-station-bar {
  min-width: 0;
  display: grid;
  gap: .42rem;
  align-self: stretch;
}
.visual-stage:fullscreen .fullscreen-station-bar strong {
  font-size: clamp(1rem, 1.18vw, 1.28rem);
  line-height: 1.1;
  color: #fff;
  text-shadow: 0 3px 16px rgba(0,0,0,.55);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.visual-stage:fullscreen .fullscreen-meta-pills {
  display: flex;
  flex-wrap: wrap;
  gap: .38rem;
}
.visual-stage:fullscreen .fullscreen-meta-pills span {
  min-height: 28px;
  padding: .28rem .58rem;
  font-size: .78rem;
  line-height: 1;
  background: rgba(5,8,14,.4);
  color: rgba(255,255,255,.86);
  border-color: rgba(255,255,255,.12);
  box-shadow: none;
  max-width: 100%;
}
.visual-stage:fullscreen .fullscreen-transport {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: .45rem;
  min-width: 0;
}
.visual-stage:fullscreen .fullscreen-controls .primary-button,
.visual-stage:fullscreen .fullscreen-controls .soft-button {
  min-height: 36px;
  padding: .48rem .7rem;
  font-size: .8rem;
}
.visual-stage:fullscreen .fullscreen-quality {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(120px, 1fr);
  align-items: center;
  gap: .55rem;
  color: rgba(255,255,255,.84);
  font-size: .84rem;
}
.visual-stage:fullscreen .fullscreen-quality span,
.visual-stage:fullscreen .fullscreen-volume span {
  white-space: nowrap;
}
.visual-stage:fullscreen .fullscreen-quality select {
  width: 100%;
  min-width: 0;
  max-width: none;
  min-height: 36px;
  padding: .48rem .72rem;
  border-radius: 999px;
  color: #fff;
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.16);
}
.visual-stage:fullscreen .fullscreen-right-controls {
  min-width: 0;
  margin-left: 0;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: .55rem;
}
.visual-stage:fullscreen .fullscreen-volume {
  display: grid;
  grid-template-columns: auto minmax(120px, 165px);
  align-items: center;
  gap: .55rem;
  width: auto;
  min-width: 0;
  color: rgba(255,255,255,.84);
  font-size: .84rem;
}
.visual-stage:fullscreen .fullscreen-volume input[type="range"] {
  width: 100% !important;
  max-width: 165px;
}
.visual-stage:fullscreen #fullscreenExitButton {
  min-width: 146px;
}
@media (max-width: 1480px) {
  .visual-stage:fullscreen .fullscreen-controls {
    grid-template-columns: minmax(220px, 1.25fr) minmax(250px, auto) minmax(200px, .85fr) minmax(220px, auto);
  }
}
@media (max-width: 1200px) {
  .visual-stage:fullscreen .fullscreen-controls {
    grid-template-columns: 1fr 1fr;
    align-items: start;
  }
  .visual-stage:fullscreen .fullscreen-right-controls {
    justify-content: flex-start;
  }
}
@media (max-width: 820px) {
  .visual-stage:fullscreen .fullscreen-controls {
    grid-template-columns: 1fr;
    border-radius: 18px;
  }
  .visual-stage:fullscreen .fullscreen-station-bar strong {
    white-space: normal;
  }
  .visual-stage:fullscreen .fullscreen-right-controls {
    flex-wrap: wrap;
  }
  .visual-stage:fullscreen .fullscreen-quality,
  .visual-stage:fullscreen .fullscreen-volume {
    grid-template-columns: 1fr;
    justify-items: stretch;
  }
  .visual-stage:fullscreen .fullscreen-volume input[type="range"] {
    max-width: 220px;
  }
}
.stage-overlay-title {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  max-width: 100%;
  padding: .48rem .78rem;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px;
  background: rgba(4,8,14,.52);
  color: #fff;
  backdrop-filter: blur(12px);
  box-shadow: 0 16px 40px rgba(0,0,0,.22);
  font-size: clamp(.98rem, 1.25vw, 1.18rem);
  line-height: 1.15;
  text-shadow: 0 2px 18px rgba(0,0,0,.52);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.visual-stage:fullscreen .stage-overlay-title {
  min-height: 42px;
  padding: .56rem .86rem;
  font-size: clamp(1.15rem, 1.55vw, 1.55rem);
  background: rgba(4,8,14,.42);
}
.visual-stage:fullscreen .fullscreen-station-bar strong {
  display: none;
}
@media (max-width: 900px) {
  .stage-overlay-title {
    white-space: normal;
  }
}
.stage-overlay-title {
  position: absolute;
  top: 1rem;
  left: 1rem;
  z-index: 6;
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  max-width: min(60%, 420px);
  padding: .48rem .78rem;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px;
  background: rgba(4,8,14,.52);
  color: #fff;
  backdrop-filter: blur(12px);
  box-shadow: 0 16px 40px rgba(0,0,0,.22);
  font-size: clamp(.98rem, 1.25vw, 1.18rem);
  line-height: 1.15;
  text-shadow: 0 2px 18px rgba(0,0,0,.52);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.visual-stage:fullscreen .stage-overlay-title {
  top: 1.35rem;
  left: 1.35rem;
  max-width: min(48vw, 700px);
  min-height: 42px;
  padding: .56rem .86rem;
  font-size: clamp(1.15rem, 1.55vw, 1.55rem);
  background: rgba(4,8,14,.42);
}
.visual-stage:fullscreen .status-pill {
  top: auto !important;
  bottom: 1.35rem !important;
  left: 1.35rem !important;
  right: auto !important;
}
@media (max-width: 900px) {
  .stage-overlay-title {
    max-width: calc(100% - 2rem);
    white-space: normal;
  }
}

.visual-stage:fullscreen .status-pill {
  top: auto !important;
  bottom: 5.5rem !important;
  left: 1.35rem !important;
  right: auto !important;
  transition: bottom .24s ease, opacity .24s ease, transform .24s ease;
}
.visual-stage:fullscreen .fullscreen-controls {
  grid-template-columns: minmax(280px, 1fr) auto auto auto;
  align-items: center;
}
.visual-stage:fullscreen .fullscreen-station-bar {
  justify-self: start;
}
.visual-stage:fullscreen .fullscreen-transport {
  justify-self: center;
  align-items: center;
}
.visual-stage:fullscreen .fullscreen-quality {
  justify-self: center;
  min-width: 240px;
}
.visual-stage:fullscreen .fullscreen-right-controls {
  justify-self: end;
}
.visual-stage:fullscreen.controls-hidden .fullscreen-bottom-overlay,
.visual-stage:fullscreen.controls-hidden .fullscreen-top-hint {
  opacity: 0;
  transform: translateY(14px);
  pointer-events: none;
}
.visual-stage:fullscreen .fullscreen-bottom-overlay,
.visual-stage:fullscreen .fullscreen-top-hint {
  transition: opacity .24s ease, transform .24s ease;
}
.visual-stage:fullscreen.controls-hidden .status-pill {
  bottom: 1.35rem !important;
}
@media (max-width: 1320px) {
  .visual-stage:fullscreen .fullscreen-controls {
    grid-template-columns: 1fr auto auto;
  }
  .visual-stage:fullscreen .fullscreen-station-bar {
    grid-column: 1 / -1;
  }
  .visual-stage:fullscreen .fullscreen-transport {
    justify-self: start;
  }
  .visual-stage:fullscreen .fullscreen-quality {
    min-width: 200px;
  }
}
@media (max-width: 900px) {
  .visual-stage:fullscreen .status-pill {
    bottom: 6rem !important;
  }
  .visual-stage:fullscreen.controls-hidden .status-pill {
    bottom: 1.1rem !important;
  }
  .visual-stage:fullscreen .fullscreen-controls {
    grid-template-columns: 1fr;
  }
  .visual-stage:fullscreen .fullscreen-transport,
  .visual-stage:fullscreen .fullscreen-quality,
  .visual-stage:fullscreen .fullscreen-right-controls {
    justify-self: stretch;
  }
}

.visual-stage:fullscreen .status-pill {
  z-index: 14 !important;
  bottom: 6.2rem !important;
  box-shadow: 0 14px 34px rgba(0,0,0,.28);
}
.visual-stage:fullscreen.controls-hidden .status-pill {
  z-index: 14 !important;
  bottom: 1.35rem !important;
}
@media (max-width: 900px) {
  .visual-stage:fullscreen .status-pill {
    bottom: 6.6rem !important;
  }
  .visual-stage:fullscreen.controls-hidden .status-pill {
    bottom: 1.1rem !important;
  }
}


.stage-overlay-title[role="button"],
#fullscreenStationTitle[role="button"] {
  cursor: pointer;
}
#fullscreenStationTitle[role="button"] {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  border-radius: 12px;
  padding: .12rem .18rem;
}
.visual-stage:fullscreen .fullscreen-station-bar #fullscreenStationTitle[role="button"] {
  font-size: clamp(1rem, 1.18vw, 1.28rem);
  line-height: 1.1;
  color: #fff;
  text-shadow: 0 3px 16px rgba(0,0,0,.55);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.stage-overlay-title[role="button"]:focus-visible,
#fullscreenStationTitle[role="button"]:focus-visible {
  outline: 2px solid color-mix(in oklab, var(--brand) 70%, white 30%);
  outline-offset: 2px;
}


.visual-stage:fullscreen .status-pill {
  bottom: 8.6rem !important;
  left: 1.35rem !important;
  z-index: 18 !important;
}
.visual-stage:fullscreen.controls-hidden .status-pill {
  bottom: 2.2rem !important;
  left: 1.35rem !important;
  z-index: 18 !important;
}
@media (max-width: 1320px) {
  .visual-stage:fullscreen .status-pill {
    bottom: 10.2rem !important;
  }
  .visual-stage:fullscreen.controls-hidden .status-pill {
    bottom: 2rem !important;
  }
}
@media (max-width: 900px) {
  .visual-stage:fullscreen .status-pill {
    bottom: 11.4rem !important;
  }
  .visual-stage:fullscreen.controls-hidden .status-pill {
    bottom: 1.5rem !important;
  }
}


/* ===== css/30-mobile-responsive.css ===== */
/* Mobile/Tablet-Reife, Touchflächen und responsive Grundregeln */
html, body {
  max-width: 100%;
  overflow-x: hidden;
}

@media (max-width: 980px) {
  :root {
    --radius-xl: 22px;
    --radius-lg: 18px;
  }

  .topbar {
    position: sticky;
    top: 0;
    height: auto;
    grid-template-columns: 1fr;
    gap: .75rem;
    padding: .75rem .85rem;
  }

  .brand {
    justify-content: flex-start;
  }

  .brand-mark {
    width: 2rem;
    height: 2rem;
  }

  .brand-text {
    font-size: 1.02rem;
  }

  .search-shell {
    grid-column: auto;
    grid-row: auto;
    max-width: none;
    min-height: 46px;
  }

  .search-shell input {
    padding: .78rem .95rem;
    font-size: 1rem;
  }

  .top-actions {
    display: flex;
    gap: .5rem;
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: .1rem;
    scrollbar-width: thin;
    justify-content: flex-start;
  }

  .top-actions > * {
    flex: 0 0 auto;
    min-height: 42px;
    white-space: nowrap;
  }

  .genre-strip {
    position: sticky;
    top: 0;
    z-index: 14;
    padding: .6rem .75rem;
    gap: .45rem;
  }

  .genre-chip {
    padding: .55rem .82rem;
    min-height: 40px;
  }

  .app-grid {
    grid-template-columns: 1fr;
    padding: .75rem .65rem 1.3rem;
    gap: .85rem;
  }

  .player-column,
  .list-column {
    gap: .85rem;
  }

  .list-column {
    position: static;
    max-height: none;
  }

  .hero-player {
    position: static;
    border-radius: 22px;
  }

  .visual-stage {
    aspect-ratio: 4 / 3;
    min-height: 230px;
  }

  .visual-stage img {
    width: min(44vw, 180px);
    border-radius: 24%;
  }

  .visual-glow {
    inset: 6%;
    filter: blur(54px);
  }

  .stage-overlay-title {
    top: .75rem;
    left: .75rem;
    max-width: calc(100% - 1.5rem);
    min-height: 34px;
    padding: .42rem .68rem;
    border-radius: 14px;
    font-size: .96rem;
  }

  .status-pill {
    left: .75rem;
    bottom: .75rem;
    padding: .48rem .7rem;
    font-size: .86rem;
  }

  .stage-control-row {
    grid-template-columns: 1fr;
    gap: .7rem;
    padding: .78rem;
  }

  .stage-transport {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .5rem;
  }

  .stage-transport .primary-button,
  .stage-transport .soft-button {
    width: 100%;
    min-height: 44px;
    padding: .6rem .7rem;
    font-size: .9rem;
  }

  .stage-volume {
    grid-template-columns: auto minmax(110px, 1fr) auto;
    gap: .55rem;
    padding: .65rem .7rem;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: color-mix(in oklab, var(--panel-strong) 64%, transparent);
  }

  .stage-volume input[type="range"] {
    width: 100%;
    max-width: none;
  }

  .stage-quality {
    grid-template-columns: 1fr;
    gap: .4rem;
  }

  .stage-quality select,
  .fullscreen-stage-button {
    width: 100%;
    min-height: 44px;
  }

  .station-headline,
  .action-row,
  .meta-grid,
  .tag-row {
    padding-inline: .9rem;
  }

  .station-headline {
    grid-template-columns: 1fr auto;
    gap: .65rem;
    padding-top: .9rem;
  }

  h1 {
    font-size: clamp(1.35rem, 7vw, 1.85rem);
    line-height: 1.08;
  }

  #stationSubtitle {
    font-size: .92rem;
  }

  .favorite-main {
    width: 2.75rem;
    height: 2.75rem;
  }

  .meta-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .5rem;
  }

  .meta-grid span,
  .mini-badge,
  .badge {
    font-size: .78rem;
    padding: .48rem .62rem;
  }

  .tag-row {
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: thin;
    padding-bottom: .25rem;
  }

  .tag-row .tag {
    flex: 0 0 auto;
  }

  .action-row,
  .mix-controls,
  .toolbar-buttons {
    display: grid;
    grid-template-columns: 1fr;
  }

  .action-row .soft-button,
  .action-row .primary-button,
  .mix-controls .soft-button,
  .mix-controls .primary-button,
  .toolbar-buttons .soft-button,
  .toolbar-buttons .primary-button,
  .toolbar-buttons .import-label {
    width: 100%;
    min-height: 44px;
  }

  .mix-panel,
  .panel {
    padding: .85rem;
    border-radius: 22px;
  }

  .section-title {
    align-items: flex-start;
  }

  .mix-grid,
  .filter-grid,
  .mix-options,
  .check-grid,
  .countdown-card {
    grid-template-columns: 1fr;
    gap: .7rem;
  }

  .mix-genre-chips {
    max-height: none;
    flex-wrap: nowrap;
    overflow-x: auto;
    padding: .55rem;
  }

  .mix-genre-chip {
    flex: 0 0 auto;
    min-height: 40px;
  }

  .mix-switch {
    min-height: 50px;
  }

  .mix-options .mix-field input,
  .mix-grid .mix-field input,
  .mix-grid .mix-field select,
  input,
  select,
  textarea {
    min-height: 46px;
    font-size: 16px;
  }

  .tabs {
    border-radius: 18px;
    overflow-x: auto;
  }

  .tab {
    min-width: max-content;
    min-height: 40px;
  }

  .list-toolbar {
    flex-direction: column;
    align-items: stretch;
    gap: .65rem;
  }

  .station-list {
    max-height: none;
    min-height: 0;
    gap: .55rem;
    padding-right: 0;
  }

  .station-card {
    grid-template-columns: 58px minmax(0, 1fr);
    gap: .65rem;
    padding: .65rem;
    border-radius: 18px;
  }

  .station-card-logo {
    width: 58px;
    height: 58px;
    border-radius: 16px;
  }

  .station-card-topline {
    grid-template-columns: 1fr 36px;
  }

  .station-card h3 {
    font-size: .95rem;
  }

  .station-card-meta {
    font-size: .78rem;
    line-height: 1.35;
  }

  .station-card-tags {
    max-height: 2rem;
    overflow: hidden;
  }

  .footer {
    padding: .85rem .75rem 1.2rem;
    align-items: flex-start;
    font-size: .88rem;
  }

  .modal {
    width: calc(100% - 1rem);
    max-height: calc(100dvh - 1rem);
    overflow: auto;
    padding: 1rem;
    border-radius: 20px;
  }
}

@media (max-width: 560px) {
  .brand {
    justify-content: center;
  }

  .top-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    overflow: visible;
  }

  .top-actions > * {
    width: 100%;
    min-width: 0;
    white-space: normal;
  }

  .genre-strip {
    position: static;
  }

  .app-grid {
    padding-inline: .55rem;
  }

  .visual-stage {
    min-height: 245px;
    aspect-ratio: 1 / .9;
  }

  .visual-stage img {
    width: min(48vw, 155px);
  }

  .stage-transport {
    grid-template-columns: 1fr 1fr;
  }

  .stage-transport #playPauseButton {
    grid-column: 1 / -1;
  }

  .stage-volume {
    grid-template-columns: 1fr auto;
  }

  .stage-volume label {
    grid-column: 1 / -1;
  }

  .stage-volume input[type="range"] {
    min-height: 32px;
  }

  .station-headline {
    grid-template-columns: 1fr;
  }

  .favorite-main {
    justify-self: start;
  }

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

  .station-card {
    grid-template-columns: 52px minmax(0, 1fr);
  }

  .station-card-logo {
    width: 52px;
    height: 52px;
  }

  .station-card-badges .badge:nth-child(n+4) {
    display: none;
  }
}

@media (max-width: 980px) and (orientation: landscape) {
  .visual-stage {
    min-height: 260px;
    aspect-ratio: 16 / 8.5;
  }

  .visual-stage img {
    width: min(26vw, 170px);
  }
}

/* Mobile Vollbild: Steuerung als Bottom-Sheet, sichere Abstände, keine Überlagerung */
@media (max-width: 900px) {
  .visual-stage:fullscreen {
    padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
  }

  .visual-stage:fullscreen img {
    width: min(34vmin, 190px);
    transform: translateY(-4vh);
  }

  .visual-stage:fullscreen .stage-overlay-title {
    top: calc(env(safe-area-inset-top) + .75rem);
    left: calc(env(safe-area-inset-left) + .75rem);
    max-width: calc(100vw - env(safe-area-inset-left) - env(safe-area-inset-right) - 1.5rem);
    min-height: 38px;
    font-size: 1rem;
  }

  .visual-stage:fullscreen .fullscreen-top-hint {
    top: calc(env(safe-area-inset-top) + .75rem);
    right: calc(env(safe-area-inset-right) + .75rem);
    left: auto;
    transform: none;
    max-width: 46vw;
    font-size: .72rem;
    padding: .42rem .58rem;
  }

  .visual-stage:fullscreen .fullscreen-bottom-overlay {
    padding: 0 calc(env(safe-area-inset-right) + .65rem) calc(env(safe-area-inset-bottom) + .65rem) calc(env(safe-area-inset-left) + .65rem);
  }

  .visual-stage:fullscreen .fullscreen-controls {
    display: grid;
    grid-template-columns: 1fr;
    gap: .6rem;
    max-height: min(52dvh, 430px);
    overflow-y: auto;
    padding: .72rem;
    border-radius: 20px;
  }

  .visual-stage:fullscreen .fullscreen-station-bar {
    min-width: 0;
  }

  .visual-stage:fullscreen .fullscreen-meta-pills {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: .1rem;
    scrollbar-width: thin;
  }

  .visual-stage:fullscreen .fullscreen-meta-pills span {
    flex: 0 0 auto;
    min-height: 28px;
    font-size: .72rem;
  }

  .visual-stage:fullscreen .fullscreen-transport {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .5rem;
    justify-self: stretch;
  }

  .visual-stage:fullscreen .fullscreen-transport #fullscreenPlayPauseButton {
    grid-column: 1 / -1;
  }

  .visual-stage:fullscreen .fullscreen-controls .primary-button,
  .visual-stage:fullscreen .fullscreen-controls .soft-button {
    width: 100%;
    min-height: 42px;
    padding: .55rem .62rem;
    font-size: .82rem;
  }

  .visual-stage:fullscreen .fullscreen-quality {
    min-width: 0;
    width: 100%;
    grid-template-columns: 1fr;
    justify-self: stretch;
    gap: .35rem;
  }

  .visual-stage:fullscreen .fullscreen-quality select {
    min-height: 42px;
  }

  .visual-stage:fullscreen .fullscreen-right-controls {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .5rem;
    justify-self: stretch;
  }

  .visual-stage:fullscreen .fullscreen-volume {
    grid-column: 1 / -1;
    grid-template-columns: 1fr;
    gap: .35rem;
  }

  .visual-stage:fullscreen .fullscreen-volume input[type="range"] {
    width: 100% !important;
    max-width: none;
    min-height: 32px;
  }

  .visual-stage:fullscreen #fullscreenExitButton {
    min-width: 0;
  }

  .visual-stage:fullscreen .status-pill {
    left: calc(env(safe-area-inset-left) + .75rem) !important;
    bottom: calc(env(safe-area-inset-bottom) + min(54dvh, 440px) + .75rem) !important;
    max-width: calc(100vw - 1.5rem);
  }

  .visual-stage:fullscreen.controls-hidden .status-pill {
    bottom: calc(env(safe-area-inset-bottom) + .85rem) !important;
  }
}


/* ===== css/40-overview-cards.css ===== */
/* Übersicht, klare Informationshierarchie, Mini-Player und mobile Navigation */
.topbar {
  grid-template-columns: minmax(170px, auto) minmax(280px, 1fr) minmax(300px, auto);
}
.top-actions .soft-button {
  min-height: 40px;
}
.app-grid {
  grid-template-columns: minmax(0, 1.36fr) minmax(390px, .86fr);
  gap: 1.15rem;
  align-items: start;
}
.player-column,
.list-column {
  gap: 1.15rem;
}
.hero-player,
.panel,
.mix-panel {
  border-color: color-mix(in oklab, var(--line) 88%, var(--brand) 12%);
}
.visual-stage {
  min-height: 420px;
}
.stage-overlay-title {
  max-width: min(66%, 560px);
  border-radius: 18px;
  background: rgba(5, 9, 18, .62);
}
.status-pill {
  max-width: min(70%, 520px);
}
.stage-control-row {
  background: color-mix(in oklab, var(--panel-solid) 72%, transparent);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.stage-transport .soft-button,
.stage-transport .primary-button {
  white-space: nowrap;
}
.station-headline {
  padding-top: 1.25rem;
}
.station-headline h1 {
  max-width: 980px;
}
.meta-grid span {
  background: color-mix(in oklab, var(--panel-solid) 76%, transparent);
  border-radius: 16px;
  padding: .68rem .8rem;
}
.action-row {
  padding-bottom: 1.2rem;
}
.overview-panel {
  padding: 1rem;
  overflow: hidden;
}
.overview-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .7rem;
}
.overview-card {
  position: relative;
  min-height: 112px;
  display: grid;
  align-content: space-between;
  gap: .4rem;
  text-align: left;
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: .9rem;
  color: var(--text);
  background:
    radial-gradient(circle at top right, color-mix(in oklab, var(--brand) 14%, transparent), transparent 52%),
    color-mix(in oklab, var(--panel-strong) 74%, transparent);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}
.overview-card:hover {
  transform: translateY(-1px);
  border-color: color-mix(in oklab, var(--brand) 42%, var(--line));
}
.overview-card.active {
  border-color: color-mix(in oklab, var(--brand) 68%, var(--line));
  background:
    radial-gradient(circle at top right, color-mix(in oklab, var(--brand) 24%, transparent), transparent 58%),
    color-mix(in oklab, var(--panel-strong) 86%, var(--brand) 8%);
}
.overview-card span {
  color: var(--muted);
  font-size: .82rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.overview-card strong {
  display: block;
  margin-block: .05rem;
  font-size: clamp(1.55rem, 3vw, 2.2rem);
  line-height: 1;
  letter-spacing: -.06em;
}
.overview-card small {
  color: var(--muted);
  font-size: .82rem;
}
.tabs-panel {
  overflow: hidden;
}
.list-toolbar {
  display: grid;
  grid-template-columns: 1fr;
  gap: .8rem;
  padding: 1rem 1rem .8rem;
  border-bottom: 1px solid var(--line);
}
.list-toolbar > div:first-child {
  display: flex;
  justify-content: space-between;
  gap: .8rem;
  align-items: end;
}
#resultCount {
  font-size: 1.15rem;
  letter-spacing: -.03em;
}
#cacheInfo {
  margin: 0;
  max-width: 36rem;
  color: var(--muted);
  font-size: .86rem;
  text-align: right;
}
.toolbar-buttons {
  gap: .45rem;
}
.toolbar-buttons .soft-button,
.toolbar-buttons .import-label {
  min-height: 36px;
  padding: .46rem .68rem;
}
.station-list {
  padding: .75rem;
  display: grid;
  gap: .7rem;
}
.station-card {
  position: relative;
  display: grid;
  grid-template-columns: 62px minmax(0, 1fr);
  gap: .82rem;
  align-items: center;
  min-height: 88px;
  padding: .78rem;
  border-radius: 22px;
  background: color-mix(in oklab, var(--panel-solid) 64%, transparent);
  border: 1px solid color-mix(in oklab, var(--line) 92%, transparent);
  box-shadow: none;
}
.station-card:hover {
  transform: translateY(-1px);
  border-color: color-mix(in oklab, var(--brand) 42%, var(--line));
  background: color-mix(in oklab, var(--panel-strong) 78%, transparent);
}
.station-card.active {
  border-color: color-mix(in oklab, var(--brand) 70%, white 8%);
  background:
    linear-gradient(90deg, color-mix(in oklab, var(--brand) 15%, transparent), transparent 44%),
    color-mix(in oklab, var(--panel-strong) 86%, transparent);
}
.station-card.next-in-mix::after {
  content: "Als Nächstes";
  position: absolute;
  right: .78rem;
  top: .56rem;
  padding: .22rem .45rem;
  border-radius: 999px;
  background: color-mix(in oklab, var(--warn) 24%, rgba(0,0,0,.4));
  color: var(--text);
  font-size: .68rem;
  font-weight: 800;
}
.station-card.error {
  opacity: .76;
}
.station-card-logo-wrap {
  position: relative;
  width: 62px;
  height: 62px;
}
.station-card-logo {
  width: 62px;
  height: 62px;
  border-radius: 18px;
  object-fit: cover;
  background: rgba(255,255,255,.06);
  box-shadow: 0 12px 30px rgba(0,0,0,.24);
}
.station-live-dot {
  position: absolute;
  right: -2px;
  bottom: -2px;
  width: 16px;
  height: 16px;
  border: 3px solid var(--panel-solid);
  border-radius: 50%;
  background: var(--muted-2);
}
.station-live-dot.ok { background: var(--good); }
.station-live-dot.bad { background: var(--bad); }
.station-card-body {
  min-width: 0;
  display: grid;
  gap: .46rem;
}
.station-card-topline {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .55rem;
  align-items: start;
}
.station-title-block {
  min-width: 0;
  display: grid;
  gap: .2rem;
}
.station-card h3 {
  font-size: .98rem;
  line-height: 1.18;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.station-card-meta {
  margin: 0;
  color: var(--muted);
  font-size: .82rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.star-button {
  width: 36px;
  min-width: 36px;
  height: 36px;
  min-height: 36px;
  padding: 0;
  font-size: 1.05rem;
  background: color-mix(in oklab, var(--panel-strong) 78%, transparent);
}
.station-card-tags {
  display: flex;
  gap: .35rem;
  overflow: hidden;
  min-height: 25px;
}
.station-card-tags .tag {
  flex: 0 0 auto;
  max-width: 34%;
  padding: .26rem .5rem;
  font-size: .72rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.station-card-badges {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
}
.station-card-badges .badge {
  padding: .32rem .54rem;
  font-size: .72rem;
}
.badge.ok {
  color: color-mix(in oklab, var(--good) 75%, white 25%);
  border-color: color-mix(in oklab, var(--good) 35%, var(--line));
}
.badge.warn {
  color: color-mix(in oklab, var(--warn) 78%, white 20%);
  border-color: color-mix(in oklab, var(--warn) 35%, var(--line));
}
.badge.bad {
  color: color-mix(in oklab, var(--bad) 75%, white 20%);
  border-color: color-mix(in oklab, var(--bad) 35%, var(--line));
}
.filters {
  padding: 1rem;
}
.filters .section-title.compact {
  padding: 0 0 .8rem;
}
.filter-grid,
.check-grid {
  gap: .7rem;
}
.filter-grid label,
.check-grid label {
  border-radius: 18px;
}
.mix-panel {
  overflow: hidden;
}
.mix-panel .section-title,
.mix-grid,
.mix-options,
.countdown-card,
.mix-controls,
.mix-panel .helper-text {
  padding-inline: 1rem;
}
.mix-panel .helper-text {
  padding-bottom: 1rem;
}
.footer {
  padding-bottom: 1.4rem;
}

@media (max-width: 1180px) {
  .app-grid {
    grid-template-columns: 1fr;
  }
  .list-column {
    grid-row: auto;
  }
  .overview-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .visual-stage {
    min-height: 360px;
  }
  #cacheInfo {
    text-align: left;
  }
  .list-toolbar > div:first-child {
    align-items: start;
    flex-direction: column;
  }
}

@media (max-width: 760px) {
  .overview-panel {
    padding: .8rem;
  }
  .overview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .55rem;
  }
  .overview-card {
    min-height: 94px;
    padding: .72rem;
    border-radius: 18px;
  }
  .overview-card strong {
    font-size: 1.55rem;
  }
  .toolbar-buttons {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .toolbar-buttons .soft-button,
  .toolbar-buttons .import-label {
    width: 100%;
  }
  .station-list {
    padding: .6rem;
    gap: .6rem;
  }
  .station-card {
    grid-template-columns: 54px minmax(0, 1fr);
    min-height: 82px;
    padding: .68rem;
    border-radius: 20px;
  }
  .station-card-logo-wrap,
  .station-card-logo {
    width: 54px;
    height: 54px;
  }
  .station-card-tags .tag:nth-child(n+3) {
    display: none;
  }
  .station-card-badges .badge:nth-child(n+4) {
    display: none;
  }
}

@media (max-width: 560px) {
  .topbar {
    gap: .7rem;
  }
  .search-shell {
    border-radius: 20px;
  }
  .overview-grid {
    grid-template-columns: 1fr 1fr;
  }
  .overview-card small {
    display: none;
  }
  .list-toolbar {
    padding: .8rem;
  }
  .toolbar-buttons {
    grid-template-columns: 1fr;
  }
  .station-card h3 {
    white-space: normal;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
  .station-card-meta {
    white-space: normal;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
  .station-card-badges .badge:nth-child(n+3) {
    display: none;
  }
  .visual-stage {
    min-height: 270px;
  }
}

.mobile-mini-player,
.mobile-bottom-nav {
  display: none;
}

@media (max-width: 760px) {
  body {
    padding-bottom: calc(148px + env(safe-area-inset-bottom));
  }
  .topbar {
    gap: .7rem;
    padding: .75rem .78rem .55rem;
    border-radius: 0 0 22px 22px;
    background: color-mix(in oklab, var(--bg) 92%, transparent);
    backdrop-filter: blur(18px);
  }
  .brand {
    justify-content: center;
  }
  .brand-text {
    font-size: 1rem;
  }
  .search-shell {
    min-height: 48px;
    border-radius: 999px;
  }
  .search-shell input {
    font-size: 16px;
  }
  .top-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .45rem;
  }
  .top-actions .soft-button,
  .top-actions .icon-button {
    min-height: 44px;
    width: 100%;
    justify-content: center;
  }
  #refreshButton {
    grid-column: 1 / -1;
  }
  .genre-strip {
    top: 0;
    padding: .55rem .75rem;
    gap: .42rem;
  }
  .genre-chip {
    min-height: 40px;
    padding-inline: .82rem;
  }
  .app-grid {
    padding-inline: .72rem;
    gap: .85rem;
  }
  .hero-player,
  .mix-panel,
  .panel {
    border-radius: 22px;
  }
  .visual-stage {
    aspect-ratio: 4 / 3;
    min-height: 260px;
  }
  .stage-overlay-title {
    top: .72rem;
    left: .72rem;
    max-width: calc(100% - 1.45rem);
    min-height: 34px;
    padding: .42rem .66rem;
    border-radius: 14px;
    font-size: .95rem;
  }
  .status-pill {
    left: .72rem;
    bottom: .72rem;
    min-height: 34px;
    padding: .43rem .66rem;
    font-size: .84rem;
  }
  .stage-control-row {
    gap: .55rem;
    padding: .72rem;
  }
  .stage-transport {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .45rem;
  }
  .stage-transport .primary-button,
  .stage-transport .soft-button {
    min-height: 44px;
    padding: .55rem .5rem;
  }
  .stage-volume,
  .stage-quality {
    border: 1px solid var(--line);
    border-radius: 16px;
    padding: .6rem;
    background: color-mix(in oklab, var(--panel-strong) 50%, transparent);
  }
  .fullscreen-stage-button {
    min-height: 44px;
  }
  .station-headline,
  .action-row,
  .meta-grid,
  .tag-row {
    padding-inline: .85rem;
  }
  .station-headline {
    grid-template-columns: 1fr auto;
    gap: .65rem;
  }
  h1 {
    font-size: clamp(1.35rem, 8vw, 1.9rem);
  }
  .meta-grid {
    grid-template-columns: 1fr 1fr;
    gap: .48rem;
  }
  .action-row,
  .mix-controls,
  .toolbar-buttons {
    display: grid;
    grid-template-columns: 1fr;
  }
  .action-row button,
  .mix-controls button,
  .toolbar-buttons button,
  .toolbar-buttons label {
    width: 100%;
    min-height: 44px;
    justify-content: center;
  }
  .mix-grid,
  .mix-options,
  .filter-grid,
  .check-grid {
    grid-template-columns: 1fr !important;
  }
  .overview-panel {
    order: -1;
  }
  .overview-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .55rem;
  }
  .overview-card {
    min-height: 92px;
    padding: .75rem;
  }
  .overview-card strong {
    font-size: 1.25rem;
  }
  .list-toolbar {
    display: grid;
    grid-template-columns: 1fr;
    gap: .75rem;
  }
  .station-list {
    max-height: none;
    overflow: visible;
  }
  .station-card {
    grid-template-columns: 58px 1fr;
    gap: .7rem;
    padding: .72rem;
    min-height: 86px;
  }
  .station-card-logo-wrap,
  .station-card-logo {
    width: 58px;
    height: 58px;
    border-radius: 17px;
  }
  .station-card-topline {
    gap: .4rem;
  }
  .star-button {
    min-width: 38px;
    min-height: 38px;
  }
  .station-card-tags {
    display: none;
  }
  .station-card-badges {
    gap: .28rem;
  }
  .station-card-badges .badge:nth-child(n+4) {
    display: none;
  }
  #filterPanel {
    position: fixed;
    left: .65rem;
    right: .65rem;
    bottom: calc(74px + env(safe-area-inset-bottom));
    top: auto;
    max-height: min(78dvh, 720px);
    overflow: auto;
    z-index: 60;
    transform: translateY(calc(100% + 92px));
    opacity: 0;
    pointer-events: none;
    transition: transform .22s ease, opacity .22s ease;
    border-radius: 24px;
    box-shadow: 0 24px 80px rgba(0,0,0,.46);
    background: color-mix(in oklab, var(--panel) 96%, black 4%);
  }
  #filterPanel.open {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }
  .mobile-mini-player {
    position: fixed;
    left: .65rem;
    right: .65rem;
    bottom: calc(68px + env(safe-area-inset-bottom));
    z-index: 70;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto auto;
    align-items: center;
    gap: .45rem;
    padding: .48rem;
    border: 1px solid var(--line);
    border-radius: 22px;
    background: color-mix(in oklab, var(--panel-strong) 90%, transparent);
    backdrop-filter: blur(18px);
    box-shadow: 0 14px 44px rgba(0,0,0,.36);
  }
  .mobile-mini-main {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr);
    align-items: center;
    gap: .55rem;
    border: 0;
    background: transparent;
    color: var(--text);
    text-align: left;
    min-width: 0;
    padding: .12rem;
  }
  .mobile-mini-main img {
    width: 44px;
    height: 44px;
    border-radius: 14px;
    object-fit: cover;
    background: rgba(255,255,255,.06);
  }
  .mobile-mini-text {
    min-width: 0;
    display: grid;
    gap: .12rem;
  }
  .mobile-mini-text strong,
  .mobile-mini-text small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .mobile-mini-text small {
    color: var(--muted);
    font-size: .75rem;
  }
  .mobile-mini-button,
  .mobile-mini-fav {
    min-width: 42px;
    min-height: 42px;
    border-radius: 14px;
    border: 1px solid var(--line);
    background: color-mix(in oklab, var(--panel) 70%, white 4%);
    color: var(--text);
    font-weight: 800;
  }
  .mobile-mini-fav.active {
    color: #ffd772;
    border-color: rgba(255,215,114,.45);
  }
  .mobile-bottom-nav {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 75;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    padding: .4rem .45rem calc(.42rem + env(safe-area-inset-bottom));
    border-top: 1px solid var(--line);
    background: color-mix(in oklab, var(--panel-strong) 94%, transparent);
    backdrop-filter: blur(18px);
  }
  .mobile-bottom-nav button {
    display: grid;
    place-items: center;
    gap: .1rem;
    min-height: 50px;
    border: 0;
    border-radius: 16px;
    background: transparent;
    color: var(--muted);
    font-weight: 800;
  }
  .mobile-bottom-nav button span {
    font-size: 1.1rem;
    line-height: 1;
  }
  .mobile-bottom-nav button small {
    font-size: .68rem;
  }
  .mobile-bottom-nav button.active {
    color: var(--text);
    background: color-mix(in oklab, var(--brand) 20%, transparent);
  }
}

@media (max-width: 420px) {
  .stage-transport {
    grid-template-columns: 1fr;
  }
  .overview-grid {
    grid-template-columns: 1fr;
  }
  .mobile-mini-player {
    grid-template-columns: minmax(0, 1fr) auto auto;
  }
  #miniFavoriteButton {
    display: none;
  }
  .mobile-mini-button {
    min-width: 38px;
    padding-inline: .45rem;
    font-size: .78rem;
  }
  .mobile-bottom-nav button small {
    font-size: .64rem;
  }
}


/* ===== css/50-discover.css ===== */
/* Entdecken-Bereich und Schnellstart */
.discover-panel {
  display: grid;
  gap: 1rem;
}
.daily-station-card {
  width: 100%;
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr) auto;
  align-items: center;
  gap: .9rem;
  padding: .85rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 0 0, color-mix(in oklab, var(--brand) 24%, transparent), transparent 42%),
    color-mix(in oklab, var(--panel-strong) 84%, transparent);
  color: var(--text);
  text-align: left;
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.daily-station-card:hover,
.daily-station-card:focus-visible {
  transform: translateY(-1px);
  border-color: color-mix(in oklab, var(--brand) 58%, var(--line));
}
.daily-art {
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  border-radius: 18px;
  color: white;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  box-shadow: 0 14px 40px color-mix(in oklab, var(--brand) 22%, transparent);
}
.daily-copy {
  min-width: 0;
  display: grid;
  gap: .18rem;
}
.daily-copy small,
.daily-copy em,
.discover-chip span {
  color: var(--muted);
  font-style: normal;
}
.daily-copy strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.daily-play {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding-inline: .85rem;
  border-radius: 999px;
  background: var(--brand);
  color: white;
  font-weight: 800;
}
.discover-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .65rem;
}
.discover-chip {
  min-height: 76px;
  display: grid;
  align-content: center;
  gap: .2rem;
  padding: .75rem .85rem;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: color-mix(in oklab, var(--panel-strong) 70%, transparent);
  color: var(--text);
  text-align: left;
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.discover-chip:hover,
.discover-chip:focus-visible {
  transform: translateY(-1px);
  border-color: color-mix(in oklab, var(--brand) 48%, var(--line));
  background: color-mix(in oklab, var(--brand) 10%, var(--panel-strong));
}
.discover-chip strong {
  font-size: .98rem;
}
.discover-chip span {
  font-size: .78rem;
  line-height: 1.25;
}
@media (max-width: 1180px) {
  .discover-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  .discover-panel {
    order: -1;
  }
  .daily-station-card {
    grid-template-columns: 48px minmax(0, 1fr);
  }
  .daily-art {
    width: 48px;
    height: 48px;
    border-radius: 16px;
  }
  .daily-play {
    grid-column: 1 / -1;
    width: 100%;
  }
  .discover-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .55rem;
  }
  .discover-chip {
    min-height: 72px;
    padding: .72rem;
  }
}
@media (max-width: 420px) {
  .discover-grid {
    grid-template-columns: 1fr;
  }
}


/* ===== css/60-station-details.css ===== */
/* Senderdetails, Varianten und ähnliche Sender */
.station-detail-panel {
  margin: 0 1.25rem 1.25rem;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: color-mix(in oklab, var(--panel-strong) 68%, transparent);
  display: grid;
  gap: 1rem;
}
.detail-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}
.detail-head h2 {
  margin: .12rem 0 0;
  font-size: clamp(1.05rem, 1.8vw, 1.35rem);
  line-height: 1.12;
}
.detail-head-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: .5rem;
  flex-wrap: wrap;
}
.detail-head-actions .soft-button.active {
  border-color: color-mix(in oklab, var(--brand) 55%, var(--line));
  color: var(--brand);
}
.detail-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .65rem;
}
.detail-grid > div {
  min-width: 0;
  padding: .78rem .8rem;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: color-mix(in oklab, var(--bg-soft) 72%, transparent);
}
.detail-grid span,
.detail-section-head small,
.detail-chip small {
  display: block;
  color: var(--muted);
  font-size: .78rem;
}
.detail-grid strong {
  display: block;
  margin-top: .22rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.detail-section {
  display: grid;
  gap: .65rem;
}
.detail-section-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: .7rem;
}
.detail-section-head h3 {
  margin: 0;
  font-size: 1rem;
}
.detail-chip-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: .55rem;
}
.detail-chip {
  appearance: none;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: color-mix(in oklab, var(--panel) 88%, transparent);
  color: var(--text);
  text-align: left;
  padding: .75rem .8rem;
  min-height: 74px;
  display: grid;
  gap: .15rem;
  cursor: pointer;
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}
.detail-chip:hover,
.detail-chip:focus-visible {
  transform: translateY(-1px);
  border-color: color-mix(in oklab, var(--brand) 56%, var(--line));
  outline: none;
}
.detail-chip.active {
  border-color: color-mix(in oklab, var(--brand) 72%, var(--line));
  background: color-mix(in oklab, var(--brand) 16%, var(--panel));
}
.detail-chip strong,
.detail-chip span,
.detail-chip small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.detail-chip span {
  color: var(--muted-2);
  font-size: .86rem;
}
.detail-chip.similar {
  min-height: 86px;
}
.detail-empty {
  display: block;
  grid-column: 1 / -1;
  padding: .85rem;
  border: 1px dashed var(--line);
  border-radius: 18px;
  color: var(--muted);
  background: color-mix(in oklab, var(--bg-soft) 62%, transparent);
}
.station-card-actions {
  display: flex;
  align-items: center;
  gap: .4rem;
  flex-shrink: 0;
}
.station-detail-button {
  appearance: none;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: color-mix(in oklab, var(--panel-strong) 72%, transparent);
  color: var(--muted-2);
  min-height: 34px;
  padding: .38rem .62rem;
  font: inherit;
  font-size: .78rem;
  cursor: pointer;
}
.station-detail-button:hover,
.station-detail-button:focus-visible {
  color: var(--text);
  border-color: color-mix(in oklab, var(--brand) 50%, var(--line));
  outline: none;
}
@media (max-width: 1100px) {
  .detail-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 680px) {
  .detail-head {
    display: grid;
  }
  .detail-head-actions {
    justify-content: stretch;
  }
  .detail-head-actions .soft-button,
  .detail-head-actions .icon-button {
    flex: 1 1 auto;
  }
  .detail-grid {
    grid-template-columns: 1fr;
    gap: .5rem;
  }
  .detail-section-head {
    display: grid;
    align-items: start;
  }
  .detail-chip-list {
    grid-template-columns: 1fr;
  }
  .station-detail-button {
    min-height: 32px;
    padding-inline: .55rem;
  }
}
kbd {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.75rem;
  min-height: 1.45rem;
  padding: .1rem .42rem;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: color-mix(in oklab, var(--panel-strong) 80%, transparent);
  color: var(--text);
  box-shadow: inset 0 -1px 0 color-mix(in oklab, var(--line) 75%, transparent);
  font: 700 .78rem/1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
.station-list[role="list"] .station-card[role="listitem"] {
  outline: none;
}
.station-card:focus-visible,
.station-card button:focus-visible,
.mobile-bottom-nav button:focus-visible,
.mobile-mini-player button:focus-visible,
.stage-control-row button:focus-visible,
.stage-control-row select:focus-visible,
.stage-control-row input:focus-visible,
.filter-grid input:focus-visible,
.filter-grid select:focus-visible,
.mix-panel input:focus-visible,
.mix-panel select:focus-visible,
.mix-panel button:focus-visible {
  outline: 3px solid color-mix(in oklab, var(--brand) 72%, white);
  outline-offset: 3px;
}
.station-card[aria-current="true"] {
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--brand) 60%, transparent), var(--shadow);
}
.load-more-row {
  display: flex;
  justify-content: center;
  padding: .85rem 1rem 1.05rem;
}
.load-more-row .soft-button {
  min-width: min(100%, 280px);
}
.load-more-row .soft-button[hidden] {
  display: none;
}
.status-pill {
  max-width: min(70%, 540px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (max-width: 860px) {
  .load-more-row {
    padding-bottom: 5.9rem;
  }
  .station-list {
    content-visibility: auto;
    contain-intrinsic-size: 720px;
  }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
  }
}


/* ===== css/70-settings-help-release.css ===== */
/* Einstellungen, Hilfe, Onboarding und Veröffentlichungsbereiche */
.settings-intro {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}
.settings-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .65rem;
}
.settings-stats div {
  display: grid;
  gap: .18rem;
  padding: .75rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in oklab, var(--panel-strong) 58%, transparent);
}
.settings-stats span {
  color: var(--muted);
  font-size: .78rem;
}
.settings-stats strong {
  font-size: 1.05rem;
}
.settings-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}
.settings-actions .soft-button,
.settings-actions .import-label {
  min-height: 38px;
}
.danger-soft {
  border-color: color-mix(in oklab, var(--bad) 48%, var(--line));
  color: color-mix(in oklab, var(--bad) 78%, var(--text));
}
.danger-soft:hover,
.danger-soft:focus-visible {
  background: color-mix(in oklab, var(--bad) 14%, var(--panel-strong));
}
#settingsFeedback {
  margin: 0;
}
@media (max-width: 760px) {
  .settings-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .settings-actions {
    display: grid;
    grid-template-columns: 1fr;
  }
  .settings-actions .soft-button,
  .settings-actions .import-label {
    justify-content: center;
    width: 100%;
  }
}

.help-panel {
  display: grid;
  gap: 1rem;
}
.help-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}
.help-head h2 {
  margin: .15rem 0 0;
}
.quick-start-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
}
.quick-start-card {
  min-width: 0;
  padding: .95rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: color-mix(in oklab, var(--panel-strong) 56%, transparent);
}
.quick-start-card span {
  width: 32px;
  height: 32px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  margin-bottom: .7rem;
  color: white;
  font-weight: 800;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  box-shadow: 0 12px 26px color-mix(in oklab, var(--brand) 28%, transparent);
}
.quick-start-card strong {
  display: block;
  margin-bottom: .35rem;
  color: var(--text);
}
.quick-start-card p,
.help-disclosure p {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
  font-size: .92rem;
}
.empty-state {
  border: 1px dashed color-mix(in oklab, var(--brand) 42%, var(--line));
  background: color-mix(in oklab, var(--brand) 9%, var(--panel));
}
.empty-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .6rem;
  margin-top: .9rem;
}
.modal kbd,
.player-shortcut-hint kbd {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.8em;
  padding: .12rem .42rem;
  border: 1px solid var(--line);
  border-radius: .45rem;
  background: color-mix(in oklab, var(--panel-strong) 75%, transparent);
  color: var(--text);
  font-size: .86em;
  box-shadow: inset 0 -1px 0 rgba(255,255,255,.08);
}
@media (max-width: 1120px) {
  .quick-start-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 760px) {
  .help-head {
    display: grid;
  }
  .help-head .soft-button {
    width: 100%;
  }
  .quick-start-card {
    padding: .85rem;
  }
  .empty-actions .soft-button,
  .empty-actions .primary-button {
    flex: 1 1 100%;
  }
}

.install-action[hidden] {
  display: none !important;
}
.section-title.compact {
  padding-bottom: .85rem;
}


@media (max-width: 760px) {
  .topbar {
    display: grid !important;
    grid-template-columns: 1fr !important;
    align-items: stretch !important;
    overflow: hidden;
  }
  .brand {
    justify-content: flex-start !important;
    min-width: 0;
  }
  .search-shell {
    grid-column: auto !important;
    grid-row: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    justify-self: stretch !important;
    box-sizing: border-box;
  }
  .search-shell input {
    width: 100%;
    min-width: 0;
  }
  .top-actions {
    width: 100%;
    min-width: 0;
  }
  .top-actions > * {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .mobile-bottom-nav {
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  }
  .mobile-bottom-nav button {
    min-width: 0;
    padding-inline: .18rem;
  }
}
@media (max-width: 420px) {
  .mobile-bottom-nav button small {
    font-size: .58rem;
  }
  .mobile-bottom-nav button span {
    font-size: 1rem;
  }
}

.visual-stage::after {
  content: "";
  position: absolute;
  width: min(34%, 240px);
  aspect-ratio: 1;
  border-radius: 26%;
  background: url("data:image/svg+xml;charset=UTF-8,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20viewBox%3D%220%200%20512%20512%22%20role%3D%22img%22%20aria-label%3D%22Radioplatzhalter%22%3E%0A%20%20%3Cdefs%3E%0A%20%20%20%20%3ClinearGradient%20id%3D%22bg%22%20x1%3D%220%22%20y1%3D%220%22%20x2%3D%221%22%20y2%3D%221%22%3E%3Cstop%20offset%3D%220%22%20stop-color%3D%22%23ff385c%22/%3E%3Cstop%20offset%3D%221%22%20stop-color%3D%22%237c4dff%22/%3E%3C/linearGradient%3E%0A%20%20%20%20%3CradialGradient%20id%3D%22shine%22%20cx%3D%2235%25%22%20cy%3D%2225%25%22%20r%3D%2270%25%22%3E%3Cstop%20offset%3D%220%22%20stop-color%3D%22%23ffffff%22%20stop-opacity%3D%22.58%22/%3E%3Cstop%20offset%3D%221%22%20stop-color%3D%22%23ffffff%22%20stop-opacity%3D%220%22/%3E%3C/radialGradient%3E%0A%20%20%3C/defs%3E%0A%20%20%3Crect%20width%3D%22512%22%20height%3D%22512%22%20rx%3D%22120%22%20fill%3D%22url%28%23bg%29%22/%3E%0A%20%20%3Crect%20width%3D%22512%22%20height%3D%22512%22%20rx%3D%22120%22%20fill%3D%22url%28%23shine%29%22/%3E%0A%20%20%3Cg%20fill%3D%22none%22%20stroke%3D%22%23fff%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%2224%22%3E%0A%20%20%20%20%3Cpath%20d%3D%22M132%20235h248c28%200%2050%2022%2050%2050v82c0%2028-22%2050-50%2050H132c-28%200-50-22-50-50v-82c0-28%2022-50%2050-50Z%22%20opacity%3D%22.96%22/%3E%0A%20%20%20%20%3Cpath%20d%3D%22M150%20235%20348%20111%22%20opacity%3D%22.9%22/%3E%0A%20%20%20%20%3Ccircle%20cx%3D%22174%22%20cy%3D%22326%22%20r%3D%2239%22%20fill%3D%22%23fff%22%20opacity%3D%22.95%22/%3E%0A%20%20%20%20%3Cpath%20d%3D%22M276%20310h91M276%20352h62%22/%3E%0A%20%20%3C/g%3E%0A%3C/svg%3E%0A") center / cover no-repeat;
  box-shadow: 0 28px 100px rgba(0,0,0,.24);
  z-index: 1;
  opacity: .92;
  pointer-events: none;
}
.visual-stage img {
  position: relative;
  z-index: 2;
  color: transparent;
  font-size: 0;
}
.visual-stage img[src=""],
.mobile-mini-main img[src=""] {
  opacity: 0;
}
.mobile-mini-main img {
  flex-shrink: 0;
  color: transparent;
  font-size: 0;
}
.overview-card strong:empty::before,
.settings-stats strong:empty::before {
  content: "Lädt …";
  color: var(--muted-2);
  font-size: .95rem;
}

@media (min-width: 761px) and (max-width: 1040px) {
  :root {
    --topbar-h: 132px;
  }
  .topbar {
    height: auto;
    min-height: var(--topbar-h);
    grid-template-columns: minmax(165px, auto) minmax(0, 1fr) !important;
    grid-template-rows: auto auto;
    align-items: center;
    gap: .75rem;
    padding-block: .8rem;
    overflow: visible;
  }
  .brand {
    min-width: 0;
  }
  .search-shell {
    min-width: 0;
    width: 100%;
    max-width: none;
    justify-self: stretch;
  }
  .top-actions {
    grid-column: 1 / -1;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: .55rem;
    overflow: visible;
  }
  .top-actions .soft-button,
  .top-actions .icon-button {
    width: 100%;
    min-width: 0;
    justify-content: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  #refreshButton {
    grid-column: auto;
  }
  .genre-strip {
    top: var(--topbar-h);
  }
}

@media (max-width: 760px) {
  body {
    padding-bottom: calc(8.6rem + env(safe-area-inset-bottom));
  }
  .app-grid {
    padding-bottom: calc(8.2rem + env(safe-area-inset-bottom));
  }
  .top-actions {
    grid-template-columns: 1fr 1fr !important;
    gap: .48rem;
  }
  #shareAppButton,
  #installAppButton {
    display: none !important;
  }
  #refreshButton {
    grid-column: 1 / 2 !important;
  }
  #themeToggle {
    grid-column: 2 / 3;
    width: 100%;
  }
  .mobile-mini-player {
    bottom: calc(78px + env(safe-area-inset-bottom)) !important;
    min-height: 62px;
    grid-template-columns: minmax(0, 1fr) auto auto auto;
    gap: .42rem;
    padding: .5rem;
  }
  .mobile-mini-main {
    min-width: 0;
    overflow: hidden;
  }
  .mobile-mini-main img {
    width: 46px;
    height: 46px;
  }
  .mobile-bottom-nav {
    min-height: calc(68px + env(safe-area-inset-bottom));
  }
  .footer {
    margin-bottom: calc(7.4rem + env(safe-area-inset-bottom));
  }
  #filterPanel {
    bottom: calc(150px + env(safe-area-inset-bottom)) !important;
    max-height: min(70dvh, 680px);
  }
  .overview-card strong {
    min-height: 1.35em;
  }
}

@media (max-width: 420px) {
  .mobile-mini-player {
    left: .5rem;
    right: .5rem;
    grid-template-columns: minmax(0, 1fr) auto auto;
  }
  .mobile-mini-main {
    grid-template-columns: 42px minmax(0, 1fr);
    gap: .48rem;
  }
  .mobile-mini-main img {
    width: 42px;
    height: 42px;
    border-radius: 13px;
  }
  .mobile-mini-button {
    min-width: 40px;
    min-height: 40px;
  }
  #miniNextButton {
    max-width: 58px;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  #miniFavoriteButton {
    display: none !important;
  }
  .mobile-bottom-nav button small {
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
}


#settingsPanel.settings-dialog {
  width: min(980px, calc(100vw - 2rem));
  max-width: 980px;
  padding: 0;
  border-radius: clamp(24px, 4vw, 32px);
  border: 1px solid color-mix(in oklab, var(--brand) 32%, var(--line));
  background: linear-gradient(180deg, color-mix(in oklab, var(--panel-strong) 94%, transparent), color-mix(in oklab, var(--panel) 98%, transparent));
  box-shadow: 0 36px 96px rgba(0, 0, 0, .42);
  overflow: hidden;
}
#settingsPanel.settings-dialog::backdrop {
  background: rgba(3, 8, 20, .72);
  backdrop-filter: blur(7px);
}
#settingsPanel.settings-dialog .settings-dialog-shell {
  display: grid;
  gap: 1rem;
  padding: 1.15rem 1.15rem 1.25rem;
}
#settingsPanel.settings-dialog .settings-dialog-head {
  align-items: flex-start;
  gap: 1rem;
  padding-right: 3.25rem;
}
#settingsPanel.settings-dialog .settings-dialog-title-copy {
  display: grid !important;
  align-items: start !important;
  gap: .28rem !important;
  min-width: 0 !important;
  max-width: 100% !important;
}
#settingsPanel.settings-dialog .settings-dialog-title-copy .eyebrow,
#settingsPanel.settings-dialog .settings-dialog-title-copy h2 {
  white-space: normal !important;
}
#settingsPanel.settings-dialog .settings-storage-badge {
  justify-self: start;
  width: fit-content;
  max-width: 100%;
  margin-top: .1rem;
  white-space: nowrap;
}
#settingsPanel.settings-dialog .settings-dialog-head-right {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-left: auto;
}
#settingsPanel.settings-dialog .modal-close {
  right: 1rem;
  top: 1rem;
}
#settingsPanel.settings-dialog .settings-stats {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
#settingsPanel.settings-dialog .settings-actions {
  align-items: stretch;
}
#settingsPanel.settings-dialog .settings-actions .soft-button,
#settingsPanel.settings-dialog .settings-actions .import-label {
  min-height: 42px;
}
@media (max-width: 860px) {
  #settingsPanel.settings-dialog {
    width: min(100vw - 1rem, 760px);
  }
  #settingsPanel.settings-dialog .settings-dialog-shell {
    padding: 1rem;
  }
  #settingsPanel.settings-dialog .settings-dialog-head {
    display: grid;
    padding-right: 2.75rem;
  }
  #settingsPanel.settings-dialog .settings-dialog-head-right {
    width: auto;
    justify-content: flex-end;
    margin-left: 0;
  }
}
@media (max-width: 760px) {
  #settingsPanel.settings-dialog {
    width: calc(100vw - .5rem);
    max-height: calc(100vh - .5rem);
  }
  #settingsPanel.settings-dialog .settings-dialog-shell {
    gap: .9rem;
    padding: .9rem .85rem 1rem;
  }
  #settingsPanel.settings-dialog .settings-dialog-head {
    padding-right: 2.35rem;
  }
  #settingsPanel.settings-dialog .settings-storage-badge {
    font-size: .76rem;
    max-width: calc(100vw - 6rem);
    overflow: hidden;
    text-overflow: ellipsis;
  }
  #settingsPanel.settings-dialog .settings-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  #settingsPanel.settings-dialog .settings-actions {
    display: grid;
    grid-template-columns: 1fr;
  }
  #settingsPanel.settings-dialog .settings-actions .soft-button,
  #settingsPanel.settings-dialog .settings-actions .import-label {
    width: 100%;
    justify-content: center;
  }
}


/* ===== css/80-discover-extended.css ===== */
/* Erweiterter Entdecken-Bereich */
@media (max-width: 420px) {
  .search-shell input::placeholder {
    font-size: 14px;
  }
}
.featured-discover-card {
  min-height: 90px;
}
.discover-section {
  display: grid;
  gap: .65rem;
}
.discover-section-title {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  padding-inline: .1rem;
}
.discover-section-title strong {
  font-size: .98rem;
}
.discover-section-title span {
  color: var(--muted);
  font-size: .85rem;
  text-align: right;
}
.discover-grid-primary {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.discover-grid-compact {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}
.discover-chip-large {
  min-height: 108px;
  align-content: start;
}
.discover-icon {
  width: 36px;
  height: 36px;
  display: inline-grid;
  place-items: center;
  margin-bottom: .35rem;
  border-radius: 14px;
  color: white;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  font-weight: 900;
  box-shadow: 0 14px 32px color-mix(in oklab, var(--brand) 18%, transparent);
}
.discover-mix-callout {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  padding: .85rem;
  border: 1px solid color-mix(in oklab, var(--brand) 32%, var(--line));
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 0 0, color-mix(in oklab, var(--brand) 18%, transparent), transparent 45%),
    color-mix(in oklab, var(--panel-strong) 78%, transparent);
}
.discover-mix-callout div {
  display: grid;
  gap: .2rem;
}
.discover-mix-callout span {
  color: var(--muted);
  font-size: .86rem;
}
@media (max-width: 1280px) {
  .discover-grid-primary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .discover-grid-compact {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  .discover-grid-primary,
  .discover-grid-compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .discover-section-title {
    align-items: flex-start;
    flex-direction: column;
    gap: .25rem;
  }
  .discover-section-title span {
    text-align: left;
  }
  .discover-chip-large {
    min-height: 96px;
  }
  .discover-mix-callout {
    grid-template-columns: 1fr;
  }
  .discover-mix-callout .primary-button {
    width: 100%;
  }
}
@media (max-width: 420px) {
  .discover-grid-primary,
  .discover-grid-compact {
    grid-template-columns: 1fr;
  }
}


/* ===== css/90-station-cards-v2.css ===== */
/* Professionellere Senderkarten und Detailansicht */
.station-card {
  position: relative;
  overflow: hidden;
}
.station-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: transparent;
  transition: background .18s ease;
}
.station-card.active::before {
  background: linear-gradient(180deg, var(--brand), var(--brand-2));
}
.station-card.error::before {
  background: var(--bad);
}
.station-card-logo-wrap {
  align-self: center;
}
.station-card .station-title-block h3 {
  letter-spacing: -.02em;
}
.station-card-actions {
  align-items: center;
}
.station-detail-button {
  min-height: 34px;
  padding: .45rem .7rem;
  border-radius: 999px;
  font-weight: 700;
}
.station-card-badges .badge.ok,
.detail-status-badge.ok {
  border-color: color-mix(in oklab, var(--good) 38%, transparent);
}
.station-card-badges .badge.bad,
.detail-status-badge.bad {
  border-color: color-mix(in oklab, var(--bad) 45%, transparent);
}
.detail-title-wrap {
  display: grid;
  grid-template-columns: 68px 1fr;
  align-items: center;
  gap: .9rem;
  min-width: 0;
}
.detail-logo {
  width: 68px;
  height: 68px;
  border-radius: 20px;
  object-fit: cover;
  background: rgba(255,255,255,.06);
  box-shadow: 0 18px 45px rgba(0,0,0,.22);
}
.detail-status-badge {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  margin-top: .45rem;
  padding: .28rem .62rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: color-mix(in oklab, var(--panel) 70%, transparent);
  color: var(--muted);
  font-size: .78rem;
  font-weight: 800;
}
.detail-status-badge.ok {
  color: var(--good);
  background: color-mix(in oklab, var(--good) 12%, transparent);
}
.detail-status-badge.warn {
  color: var(--warn);
  background: color-mix(in oklab, var(--warn) 12%, transparent);
}
.detail-status-badge.bad {
  color: var(--bad);
  background: color-mix(in oklab, var(--bad) 12%, transparent);
}
.detail-grid > div {
  min-height: 76px;
}
.detail-grid strong {
  line-height: 1.28;
}
.detail-section.compact-tags {
  margin-top: .9rem;
}
.detail-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
}
.detail-tag {
  min-height: 34px;
  padding: .42rem .72rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: color-mix(in oklab, var(--panel) 82%, transparent);
  color: var(--text);
  cursor: pointer;
  font: inherit;
  font-size: .84rem;
  font-weight: 750;
}
.detail-tag:hover,
.detail-tag:focus-visible {
  border-color: color-mix(in oklab, var(--brand) 50%, var(--line));
  background: color-mix(in oklab, var(--brand) 12%, var(--panel));
}
.detail-chip {
  text-align: left;
  min-width: min(100%, 210px);
}
.detail-chip.active {
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--brand) 45%, transparent) inset;
}
.detail-chip strong {
  color: var(--text);
}
.detail-chip.similar strong {
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 760px) {
  .detail-title-wrap {
    grid-template-columns: 56px 1fr;
  }
  .detail-logo {
    width: 56px;
    height: 56px;
    border-radius: 18px;
  }
  .detail-head-actions {
    grid-template-columns: 1fr 1fr auto;
  }
  .detail-chip-list {
    display: grid;
    grid-template-columns: 1fr;
  }
  .detail-chip {
    width: 100%;
  }
  .station-card-actions {
    gap: .35rem;
  }
  .station-detail-button {
    min-height: 36px;
  }
}


.station-card-logo-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: center;
  overflow: hidden;
}
.station-card-logo {
  display: block;
  margin: 0;
  object-position: center center;
  align-self: center;
}
@media (max-width: 860px) {
  .station-card-logo-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .station-card-logo {
    display: block;
    object-position: center center;
  }
}


.station-list {
  align-content: start;
  align-items: start;
  grid-auto-rows: max-content;
}
.station-card {
  align-self: start;
  align-items: center;
}
.station-card-logo-wrap {
  width: 62px;
  height: 62px;
  display: grid;
  place-items: center;
  place-self: center;
  margin: 0;
  line-height: 0;
  overflow: visible;
}
.station-card-logo {
  width: 62px;
  height: 62px;
  display: block;
  margin: 0;
  vertical-align: middle;
  object-fit: cover;
  object-position: center center;
}
.station-card-body {
  align-self: center;
}

@media (max-width: 860px) {
  .station-list {
    align-content: start;
    align-items: start;
    grid-auto-rows: max-content;
  }
  .station-card {
    align-self: start;
  }
}


/* ===== css/91-mix-assistant.css ===== */
/* Sender-Mix-Assistent */
.mix-wizard {
  margin: 1rem 0 1.15rem;
  padding: 1rem;
  border: 1px solid color-mix(in oklab, var(--brand) 28%, var(--line));
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at top left, color-mix(in oklab, var(--brand) 18%, transparent), transparent 42%),
    color-mix(in oklab, var(--panel-strong) 72%, transparent);
  box-shadow: 0 18px 60px rgba(0,0,0,.18);
}
.mix-wizard-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: .9rem;
}
.mix-wizard-head h3 {
  margin: .08rem 0 .28rem;
  font-size: clamp(1.08rem, 1.8vw, 1.35rem);
}
.mix-wizard-head p {
  margin: 0;
  color: var(--muted);
  max-width: 72ch;
}
.mix-advanced-settings {
  margin-top: .4rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: color-mix(in oklab, var(--panel) 76%, transparent);
  overflow: hidden;
}
.mix-advanced-settings summary {
  cursor: pointer;
  padding: .85rem 1rem;
  font-weight: 700;
  color: var(--text);
}
.mix-advanced-settings[open] summary {
  border-bottom: 1px solid var(--line);
}
@media (max-width: 920px) {
  .mix-wizard-head {
    flex-direction: column;
  }
}
@media (max-width: 560px) {
  .mix-wizard {
    margin-inline: -.25rem;
    padding: .8rem;
  }
}


/* ===== css/92-queue.css ===== */
/* Warteschlange / Als Nächstes */
.queue-panel {
  display: grid;
  gap: 1rem;
}
.queue-actions {
  display: flex;
  gap: .6rem;
  flex-wrap: wrap;
}
.queue-list {
  display: grid;
  gap: .65rem;
  max-height: 420px;
  overflow: auto;
  padding-right: .2rem;
}
.queue-item {
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr) auto;
  align-items: center;
  gap: .75rem;
  padding: .7rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: color-mix(in oklab, var(--panel-strong) 34%, transparent);
}
.queue-item img {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  object-fit: cover;
  background: rgba(255,255,255,.06);
}
.queue-item-text {
  min-width: 0;
  display: grid;
  gap: .2rem;
}
.queue-item-text strong,
.queue-item-text span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.queue-item-text span {
  color: var(--muted);
  font-size: .82rem;
}
.queue-item-actions {
  display: flex;
  align-items: center;
  gap: .35rem;
}
.soft-button.tiny {
  min-height: 30px;
  padding: .34rem .5rem;
  border-radius: 999px;
  font-size: .78rem;
}
.danger-lite {
  color: color-mix(in oklab, var(--bad) 80%, white);
}
.station-queue-button {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: color-mix(in oklab, var(--panel-strong) 55%, transparent);
  color: var(--text);
  padding: .42rem .64rem;
  min-height: 32px;
  cursor: pointer;
  font: inherit;
  font-size: .82rem;
}
.station-queue-button:hover,
.station-queue-button.queued {
  border-color: color-mix(in oklab, var(--brand) 62%, var(--line));
  background: color-mix(in oklab, var(--brand) 22%, var(--panel-strong));
}
@media (max-width: 920px) {
  .queue-item {
    grid-template-columns: 42px minmax(0, 1fr);
  }
  .queue-item-actions {
    grid-column: 1 / -1;
    justify-content: flex-end;
  }
}
@media (max-width: 560px) {
  .queue-actions .primary-button,
  .queue-actions .soft-button {
    width: 100%;
  }
  .station-card-actions {
    gap: .35rem;
    flex-wrap: wrap;
    justify-content: flex-end;
  }
  .station-queue-button,
  .station-detail-button {
    font-size: .78rem;
    padding-inline: .52rem;
  }
}


.queue-item.mix-planned {
  border-color: color-mix(in oklab, var(--brand) 45%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in oklab, var(--brand) 12%, transparent), transparent 42%),
    color-mix(in oklab, var(--panel-strong) 38%, transparent);
}
.queue-plan-badge {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: .34rem .55rem;
  border: 1px solid color-mix(in oklab, var(--brand) 55%, var(--line));
  border-radius: 999px;
  color: var(--text);
  background: color-mix(in oklab, var(--brand) 18%, transparent);
  font-size: .78rem;
  font-weight: 800;
}


/* ===== css/93-player-control-fix.css ===== */
.stage-control-row {
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px) minmax(260px, 340px) auto;
  align-items: center;
  gap: .85rem;
}
.stage-volume {
  width: 100%;
  max-width: 360px;
  min-width: 0;
  justify-self: stretch;
  display: grid;
  grid-template-columns: max-content minmax(0, 1fr) max-content;
  align-items: center;
  column-gap: .72rem;
  overflow: visible;
}
.stage-volume label {
  grid-column: 1;
  min-width: max-content;
}
.stage-volume input[type="range"] {
  grid-column: 2;
  width: 100% !important;
  min-width: 0;
  max-width: none !important;
  display: block;
}
.stage-volume #muteButton,
#muteButton {
  grid-column: 3;
  position: static;
  margin: 0;
  min-width: 58px;
  white-space: nowrap;
  justify-self: end;
  flex-shrink: 0;
}
.stage-quality {
  min-width: 0;
}
.stage-quality select {
  width: 100%;
  min-width: 0;
}
@media (max-width: 1180px) {
  .stage-control-row {
    grid-template-columns: 1fr 1fr;
  }
  .stage-transport {
    grid-column: 1 / -1;
  }
  .stage-volume,
  .stage-quality {
    max-width: none;
    width: 100%;
  }
  .fullscreen-stage-button {
    width: 100%;
  }
}
@media (max-width: 760px) {
  .stage-control-row {
    grid-template-columns: 1fr;
  }
  .stage-volume {
    grid-template-columns: 1fr;
    row-gap: .45rem;
  }
  .stage-volume label,
  .stage-volume input[type="range"],
  .stage-volume #muteButton,
  #muteButton {
    grid-column: 1;
    justify-self: stretch;
  }
}


/* ===== css/94-search-modal-player.css ===== */
.search-shell {
  grid-template-columns: 1fr auto;
  align-items: center;
  padding: .22rem;
  gap: .3rem;
  border-radius: 999px;
  background: linear-gradient(180deg, color-mix(in oklab, var(--panel-solid) 96%, transparent), color-mix(in oklab, var(--panel) 90%, transparent));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.025), 0 10px 32px rgba(0,0,0,.14);
}
.search-shell input {
  padding: .95rem 1.15rem;
  font-size: .98rem;
}
.search-shell input::placeholder {
  color: color-mix(in oklab, var(--muted) 88%, white 8%);
}
.search-shell .search-submit {
  width: 48px;
  min-width: 48px;
  height: 48px;
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  margin-right: .08rem;
  background: linear-gradient(180deg, color-mix(in oklab, var(--panel) 82%, white 8%), color-mix(in oklab, var(--panel-strong) 90%, transparent));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03);
}
.search-shell .search-submit:hover,
.search-shell .search-submit:focus-visible {
  border-color: color-mix(in oklab, var(--brand) 42%, var(--line));
  background: linear-gradient(180deg, color-mix(in oklab, var(--brand) 10%, var(--panel)), color-mix(in oklab, var(--panel-strong) 92%, transparent));
}
.search-submit-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  color: color-mix(in oklab, var(--text) 88%, white 6%);
}
.search-submit-icon svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.station-title-trigger {
  appearance: none;
  border: 1px solid color-mix(in oklab, var(--line) 88%, transparent);
  background: color-mix(in oklab, var(--bg-soft) 82%, transparent);
  color: var(--text);
  border-radius: 18px;
  padding: .65rem .9rem;
  display: inline-grid;
  gap: .22rem;
  align-items: start;
  text-align: left;
  cursor: pointer;
  transition: border-color .16s ease, transform .16s ease, background .16s ease, box-shadow .16s ease;
  max-width: min(100%, 560px);
}
.station-title-trigger:hover,
.station-title-trigger:focus-visible {
  transform: translateY(-1px);
  border-color: color-mix(in oklab, var(--brand) 52%, var(--line));
  background: color-mix(in oklab, var(--brand) 10%, var(--bg-soft));
  box-shadow: 0 10px 28px rgba(0,0,0,.14);
  outline: none;
}
.station-title-trigger #stationTitle {
  font-size: clamp(1.25rem, 2.2vw, 2rem);
  font-weight: 800;
  line-height: 1.12;
}
.station-title-hint {
  color: var(--muted);
  font-size: .82rem;
}
.player-similar-panel {
  margin: 0 1.25rem 1.25rem;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: color-mix(in oklab, var(--panel-strong) 66%, transparent);
  display: grid;
  gap: .75rem;
}
.player-similar-panel .detail-chip-list.similar {
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}
.player-similar-panel .detail-empty {
  padding: .9rem 1rem;
  border: 1px dashed var(--line);
  border-radius: 16px;
  color: var(--muted);
}
.modal.station-details-dialog {
  max-width: min(1120px, calc(100vw - 2rem));
  width: min(1120px, calc(100vw - 2rem));
  padding: 1.1rem;
}
.modal.station-details-dialog #modalContent {
  display: grid;
  gap: 1rem;
}
.station-detail-modal-note {
  color: var(--muted);
  font-size: .88rem;
}
.station-detail-modal .detail-head-actions {
  align-items: flex-start;
}
.station-detail-modal .detail-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.station-detail-modal .detail-chip-list {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.station-detail-modal .detail-head {
  margin-right: 2.3rem;
}
.station-detail-modal .detail-title-wrap {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}
.station-detail-modal .detail-logo {
  width: 68px;
  height: 68px;
  border-radius: 20px;
  object-fit: cover;
  border: 1px solid var(--line);
  background: color-mix(in oklab, var(--panel) 85%, transparent);
}
.station-detail-modal .detail-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}
.station-detail-modal .detail-tag {
  appearance: none;
  border: 1px solid var(--line);
  background: color-mix(in oklab, var(--panel) 88%, transparent);
  color: var(--text);
  padding: .5rem .78rem;
  border-radius: 999px;
  cursor: pointer;
}
.station-detail-modal .detail-tag:hover,
.station-detail-modal .detail-tag:focus-visible {
  border-color: color-mix(in oklab, var(--brand) 48%, var(--line));
  outline: none;
}
@media (max-width: 900px) {
  .station-detail-modal .detail-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  .search-shell {
    padding: .18rem;
  }
  .search-shell .search-submit {
    width: 44px;
    min-width: 44px;
    height: 44px;
    min-height: 44px;
  }
  .station-title-trigger {
    width: 100%;
    max-width: none;
  }
  .player-similar-panel {
    margin-inline: .82rem;
    padding: .88rem;
  }
  .modal.station-details-dialog {
    width: calc(100vw - 1rem);
    max-width: calc(100vw - 1rem);
    padding: .9rem;
  }
  .station-detail-modal .detail-head {
    margin-right: 0;
    flex-direction: column;
  }
  .station-detail-modal .detail-head-actions {
    width: 100%;
  }
  .station-detail-modal .detail-head-actions .soft-button {
    flex: 1 1 calc(50% - .5rem);
    justify-content: center;
  }
  .station-detail-modal .detail-grid {
    grid-template-columns: 1fr;
  }
}


/* ===== css/95-quickstart-fullwidth.css ===== */
.visual-stage::after {
  display: none !important;
  content: none !important;
}
.visual-stage img {
  z-index: 2;
}
.help-panel-wide {
  max-width: none;
  width: calc(100% - 2rem);
  margin: .9rem auto 1rem;
  box-sizing: border-box;
}
.help-panel-wide .quick-start-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.help-panel-wide .quick-start-card {
  min-height: 154px;
}
@media (max-width: 1180px) {
  .help-panel-wide .quick-start-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  .help-panel-wide {
    width: calc(100% - 1.2rem);
    margin: .7rem auto .8rem;
    padding: .9rem;
  }
  .help-panel-wide .help-head {
    display: grid;
    gap: .7rem;
  }
  .help-panel-wide .quick-start-grid {
    grid-template-columns: 1fr;
  }
  .help-panel-wide .quick-start-card {
    min-height: auto;
  }
}


.quickstart-panel {
  padding: 0;
  overflow: hidden;
}
.quickstart-disclosure {
  border: 0;
}
.quickstart-disclosure > summary {
  list-style: none;
}
.quickstart-disclosure > summary::-webkit-details-marker {
  display: none;
}
.quickstart-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.1rem;
  cursor: pointer;
  transition: background-color .18s ease, box-shadow .18s ease;
}
.quickstart-summary:hover,
.quickstart-summary:focus-visible {
  background: color-mix(in oklab, var(--bg-soft) 36%, transparent);
  outline: none;
}
.quickstart-summary-copy h2 {
  margin: .15rem 0 0;
}
.quickstart-summary-right {
  display: inline-flex;
  align-items: center;
  gap: .75rem;
  color: var(--muted);
  white-space: nowrap;
}
.quickstart-summary-label {
  min-height: 34px;
  padding: .5rem .78rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  background: color-mix(in oklab, var(--panel-strong) 58%, transparent);
}
.quickstart-summary-chevron {
  width: 10px;
  height: 10px;
  border-right: 2px solid color-mix(in oklab, var(--muted) 88%, white 10%);
  border-bottom: 2px solid color-mix(in oklab, var(--muted) 88%, white 10%);
  transform: rotate(45deg);
  transition: transform .18s ease, border-color .18s ease;
  margin-right: .15rem;
}
.quickstart-disclosure[open] .quickstart-summary-chevron {
  transform: rotate(-135deg);
  border-right-color: color-mix(in oklab, var(--text) 96%, white 4%);
  border-bottom-color: color-mix(in oklab, var(--text) 96%, white 4%);
}
.quickstart-body {
  padding: 0 1.1rem 1.1rem;
  display: grid;
  gap: 1rem;
}
.quickstart-toolbar {
  margin-top: -.1rem;
}
.quickstart-intro {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}
#stageOverlayTitle,
#fullscreenStationTitle {
  cursor: pointer;
}
#stageOverlayTitle:hover,
#stageOverlayTitle:focus-visible,
#fullscreenStationTitle:hover,
#fullscreenStationTitle:focus-visible {
  border-color: color-mix(in oklab, var(--brand) 52%, rgba(255,255,255,.18));
  background: color-mix(in oklab, var(--brand) 14%, rgba(4,8,14,.52));
  outline: none;
}
@media (max-width: 760px) {
  .quickstart-summary,
  .quickstart-body {
    padding-left: .9rem;
    padding-right: .9rem;
  }
  .quickstart-summary {
    align-items: flex-start;
    flex-direction: column;
  }
  .quickstart-summary-right {
    width: 100%;
    justify-content: space-between;
  }
  .quickstart-toolbar {
    display: grid;
    gap: .7rem;
  }
}


.quickstart-summary-copy,
.section-summary-inline {
  display: flex;
  align-items: baseline;
  gap: .8rem;
  flex-wrap: wrap;
}
.quickstart-summary-copy .eyebrow,
.section-summary-inline .eyebrow {
  margin: 0;
}
.quickstart-summary-copy h2,
.section-summary-inline h2 {
  margin: 0;
}
.quickstart-summary {
  padding-top: .85rem;
  padding-bottom: .85rem;
}
.quickstart-panel .eyebrow {
  margin-bottom: 0;
}
.quickstart-panel h2 {
  font-size: clamp(1.05rem, 1.18vw, 1.55rem);
}
.disclosure-panel {
  padding: 0;
  overflow: hidden;
}
.section-disclosure > summary {
  list-style: none;
}
.section-disclosure > summary::-webkit-details-marker {
  display: none;
}
.section-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.1rem;
  cursor: pointer;
  transition: background-color .18s ease, box-shadow .18s ease;
}
.section-summary:hover,
.section-summary:focus-visible {
  background: color-mix(in oklab, var(--bg-soft) 32%, transparent);
  outline: none;
}
.section-summary-right {
  display: inline-flex;
  align-items: center;
  gap: .7rem;
  flex-shrink: 0;
}
.section-summary-chevron {
  width: 10px;
  height: 10px;
  border-right: 2px solid color-mix(in oklab, var(--muted) 88%, white 12%);
  border-bottom: 2px solid color-mix(in oklab, var(--muted) 88%, white 12%);
  transform: rotate(45deg);
  transition: transform .18s ease;
}
.section-disclosure[open] .section-summary-chevron {
  transform: rotate(-135deg);
}
.section-disclosure-body {
  padding: 0 1.1rem 1.1rem;
  display: grid;
  gap: 1rem;
}
.compact-section-body {
  padding-top: .1rem;
}
.section-body-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}
.section-body-head .section-subtitle {
  margin: 0;
}
.list-column {
  gap: 1rem;
}
.list-column > .tabs-panel {
  order: 1;
}
.list-column > .overview-panel {
  order: 2;
}
.list-column > .discover-panel {
  order: 3;
}
.list-column > .filters {
  order: 5;
}
.list-column > .queue-panel {
  order: 6;
}
@media (max-width: 860px) {
  .section-summary,
  .section-disclosure-body,
  .quickstart-summary,
  .quickstart-body {
    padding-left: .9rem;
    padding-right: .9rem;
  }
  .section-summary {
    align-items: flex-start;
    flex-direction: column;
  }
  .section-summary-right,
  .quickstart-summary-right {
    width: 100%;
    justify-content: space-between;
  }
  .section-body-head {
    display: grid;
  }
}


.quickstart-summary-copy,
.section-summary-copy.section-summary-inline {
  display: flex;
  align-items: center;
  gap: .7rem;
  flex-wrap: nowrap;
}
.quickstart-summary-copy .eyebrow,
.section-summary-copy.section-summary-inline .eyebrow {
  margin: 0;
  line-height: 1;
}
.quickstart-summary-copy h2,
.section-summary-copy.section-summary-inline h2 {
  margin: 0;
  font-size: 1.08rem;
  line-height: 1.2;
  font-weight: 800;
}
.quickstart-summary {
  padding-top: .9rem;
  padding-bottom: .9rem;
}
.quickstart-summary-right {
  align-self: center;
}
.quickstart-summary-label {
  font-size: .86rem;
}
.section-summary {
  padding-top: .9rem;
  padding-bottom: .9rem;
}
.mix-panel .queue-panel {
  margin: 0 0 1rem;
}
.mix-panel .queue-panel .section-title.compact {
  margin-bottom: .8rem;
}
.mix-panel .queue-panel .queue-actions {
  margin-bottom: .8rem;
}
.list-column > .overview-panel,
.list-column > .discover-panel,
.list-column > .settings-panel {
  margin-top: 0;
}
@media (max-width: 860px) {
  .quickstart-summary-copy,
  .section-summary-copy.section-summary-inline {
    flex-wrap: wrap;
    row-gap: .3rem;
  }
  .quickstart-summary-copy h2,
  .section-summary-copy.section-summary-inline h2 {
    font-size: 1rem;
  }
}


.help-panel-wide {
  width: auto;
  max-width: none;
  margin: .9rem clamp(1rem, 3vw, 2rem) 1rem;
}
@media (max-width: 760px) {
  .help-panel-wide {
    width: auto;
    margin: .7rem .9rem .8rem;
  }
}


/* ===== css/95-mix-compact.css ===== */
.mix-wizard-compact {
  padding: 1rem;
  border: 1px solid color-mix(in oklab, var(--brand) 28%, var(--line));
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 0 0, color-mix(in oklab, var(--brand) 12%, transparent), transparent 28%),
    color-mix(in oklab, var(--panel-strong) 72%, transparent);
  display: grid;
  gap: 1rem;
}

.mix-wizard-compact .mix-wizard-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  padding: 0;
  border: 0;
  background: transparent;
}

.mix-select-stack {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .75rem;
  align-items: start;
}

.mix-select-box {
  border: 1px solid var(--line);
  border-radius: 20px;
  background: color-mix(in oklab, var(--panel) 86%, transparent);
  overflow: clip;
  min-width: 0;
}

.mix-select-box[open] {
  border-color: color-mix(in oklab, var(--brand) 38%, var(--line));
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--brand) 9%, var(--panel)), color-mix(in oklab, var(--panel) 88%, transparent));
}

.mix-select-box summary {
  list-style: none;
  cursor: pointer;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: .65rem;
  align-items: center;
  padding: .82rem .9rem;
  min-height: 64px;
}

.mix-select-box summary::-webkit-details-marker {
  display: none;
}

.mix-select-box summary::after {
  content: "▾";
  color: var(--muted);
  font-size: .9rem;
  transition: transform .16s ease;
}

.mix-select-box[open] summary::after {
  transform: rotate(180deg);
}

.mix-select-box summary strong {
  min-width: 0;
  font-size: .98rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mix-select-box summary small {
  grid-column: 2 / 3;
  color: var(--muted);
  font-size: .78rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wizard-number {
  width: 32px;
  height: 32px;
  display: inline-grid;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  font-weight: 800;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  box-shadow: 0 10px 22px color-mix(in oklab, var(--brand) 30%, transparent);
}

.mix-select-content {
  display: grid;
  gap: .55rem;
  padding: 0 .9rem .9rem;
}

.mix-select-content label {
  display: grid;
  gap: .4rem;
  color: var(--muted-2);
  font-size: .86rem;
}

.mix-select-content select,
.mix-select-content input {
  width: 100%;
  min-height: 46px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
  color: var(--text);
  padding: .72rem .85rem;
}

.mix-select-content select:focus,
.mix-select-content input:focus {
  outline: none;
  border-color: color-mix(in oklab, var(--brand) 55%, var(--line));
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand) 16%, transparent);
}

.mix-optional-grid {
  grid-template-columns: 1fr;
}

.mix-interval-compact {
  grid-template-columns: 1fr;
}

.wizard-custom-duration {
  display: none !important;
}

.mix-interval-compact.is-custom .wizard-custom-duration {
  display: grid !important;
}

.mix-controls {
  padding-top: .2rem;
}

.mix-controls #mixStartButton {
  min-width: 185px;
}

@media (max-width: 1180px) {
  .mix-select-stack {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .mix-wizard-compact {
    padding: .85rem;
  }
  .mix-wizard-compact .mix-wizard-head {
    display: grid;
  }
  .mix-select-stack {
    grid-template-columns: 1fr;
  }
  .mix-select-box summary {
    min-height: 58px;
    padding: .75rem .8rem;
  }
  .mix-select-content {
    padding-inline: .8rem;
  }
}


/* ===== css/96-mix-floating-advanced.css ===== */
.mix-panel,
.mix-wizard-compact,
.mix-select-stack,
.mix-advanced-compact,
.pro-select-stack {
  overflow: visible !important;
}

.mix-wizard-compact {
  position: relative;
  z-index: 8;
}

.mix-select-stack {
  position: relative;
  align-items: start;
}

.mix-select-box,
.pro-select-box {
  position: relative;
  overflow: visible !important;
  min-height: 74px;
}

.mix-select-box > summary,
.pro-select-box > summary {
  position: relative;
  z-index: 2;
  border-radius: inherit;
}

.mix-select-box > .mix-select-content,
.pro-select-box > .pro-select-content {
  position: absolute;
  top: calc(100% + .55rem);
  left: 0;
  right: 0;
  z-index: 50;
  min-width: min(420px, calc(100vw - 2rem));
  padding: .9rem;
  border: 1px solid color-mix(in oklab, var(--brand) 42%, var(--line));
  border-radius: 18px;
  background: color-mix(in oklab, var(--panel-solid) 98%, transparent);
  box-shadow: 0 24px 70px rgba(0,0,0,.45);
  backdrop-filter: blur(18px);
}

.mix-select-box:nth-child(3) > .mix-select-content,
.mix-select-box:nth-child(4) > .mix-select-content,
.pro-select-box:nth-child(3) > .pro-select-content,
.pro-select-box:nth-child(4) > .pro-select-content {
  left: auto;
  right: 0;
}

.mix-select-box:not([open]) > .mix-select-content,
.pro-select-box:not([open]) > .pro-select-content {
  display: none !important;
}

.mix-select-box[open],
.pro-select-box[open] {
  z-index: 60;
}

.mix-select-box[open]::before,
.pro-select-box[open]::before {
  content: "";
  position: absolute;
  left: 1.2rem;
  bottom: -.65rem;
  width: 14px;
  height: 14px;
  z-index: 51;
  transform: rotate(45deg);
  border-left: 1px solid color-mix(in oklab, var(--brand) 42%, var(--line));
  border-top: 1px solid color-mix(in oklab, var(--brand) 42%, var(--line));
  background: color-mix(in oklab, var(--panel-solid) 98%, transparent);
}

.mix-select-box:nth-child(3)[open]::before,
.mix-select-box:nth-child(4)[open]::before,
.pro-select-box:nth-child(3)[open]::before,
.pro-select-box:nth-child(4)[open]::before {
  left: auto;
  right: 1.2rem;
}

.mix-advanced-compact {
  margin-top: 1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: color-mix(in oklab, var(--panel-strong) 56%, transparent);
}

.mix-advanced-compact > summary {
  cursor: pointer;
  padding: 1rem;
  font-weight: 800;
  list-style: none;
}

.mix-advanced-compact > summary::-webkit-details-marker {
  display: none;
}

.mix-advanced-compact > summary::before {
  content: "▸";
  display: inline-block;
  margin-right: .45rem;
  transition: transform .16s ease;
}

.mix-advanced-compact[open] > summary::before {
  transform: rotate(90deg);
}

.pro-select-stack {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .75rem;
  padding: 0 1rem 1rem;
}

.pro-select-box {
  border: 1px solid var(--line);
  border-radius: 20px;
  background: color-mix(in oklab, var(--panel) 86%, transparent);
  min-width: 0;
}

.pro-select-box[open] {
  border-color: color-mix(in oklab, var(--brand) 38%, var(--line));
  background: linear-gradient(180deg, color-mix(in oklab, var(--brand) 8%, var(--panel)), color-mix(in oklab, var(--panel) 88%, transparent));
}

.pro-select-box > summary {
  list-style: none;
  cursor: pointer;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: .65rem;
  align-items: center;
  min-height: 64px;
  padding: .82rem .9rem;
}

.pro-select-box > summary::-webkit-details-marker {
  display: none;
}

.pro-select-box > summary::after {
  content: "▾";
  color: var(--muted);
  font-size: .9rem;
  transition: transform .16s ease;
}

.pro-select-box[open] > summary::after {
  transform: rotate(180deg);
}

.pro-select-box summary strong,
.pro-select-box summary small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.pro-select-box summary small {
  grid-column: 2 / 3;
  color: var(--muted);
  font-size: .78rem;
}

.pro-select-content {
  display: grid;
  gap: .7rem;
}

.pro-select-content label,
.pro-select-content .mix-switch {
  display: grid;
  gap: .45rem;
  color: var(--muted-2);
  font-size: .86rem;
}

.pro-select-content select,
.pro-select-content input {
  width: 100%;
  min-height: 46px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
  color: var(--text);
  padding: .72rem .85rem;
}

.pro-select-content select:focus,
.pro-select-content input:focus {
  outline: none;
  border-color: color-mix(in oklab, var(--brand) 55%, var(--line));
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand) 16%, transparent);
}

.pro-select-content .mix-genre-native {
  min-height: 145px;
}

.pro-two-col,
.pro-three-col,
.pro-options-grid {
  grid-template-columns: 1fr;
}

.pro-options-grid .mix-switch {
  grid-template-columns: auto 1fr;
  align-items: center;
  min-height: 52px;
  padding: .55rem .7rem;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: color-mix(in oklab, var(--bg-soft) 78%, transparent);
}

.pro-options-grid .mix-switch input {
  width: auto;
  min-height: 0;
  padding: 0;
}

.mix-advanced-compact .mix-genre-chips {
  max-height: 185px;
  overflow: auto;
  padding-right: .25rem;
}

.mix-advanced-compact .field-note {
  color: var(--muted);
}

.mix-panel:has(.mix-select-box[open]) .countdown-card,
.mix-panel:has(.pro-select-box[open]) .countdown-card,
.mix-panel:has(.mix-select-box[open]) .mix-controls,
.mix-panel:has(.pro-select-box[open]) .mix-controls {
  position: relative;
  z-index: 1;
}

@media (max-width: 1180px) {
  .pro-select-stack {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .pro-select-box:nth-child(2) > .pro-select-content,
  .pro-select-box:nth-child(4) > .pro-select-content {
    left: auto;
    right: 0;
  }
}

@media (max-width: 720px) {
  .pro-select-stack {
    grid-template-columns: 1fr;
    padding-inline: .8rem;
  }
  .mix-select-box > .mix-select-content,
  .pro-select-box > .pro-select-content {
    position: fixed;
    left: .75rem !important;
    right: .75rem !important;
    top: auto;
    bottom: calc(5.8rem + env(safe-area-inset-bottom));
    min-width: 0;
    max-height: min(72vh, 520px);
    overflow: auto;
    z-index: 95;
  }
  .mix-select-box[open]::before,
  .pro-select-box[open]::before {
    display: none;
  }
}


/* ===== css/97-mix-true-floating.css ===== */
.mix-panel,
.mix-wizard-compact,
.mix-select-stack,
.mix-advanced-compact,
.pro-select-stack {
  overflow: visible !important;
}

.mix-wizard-compact {
  position: relative;
  z-index: 20;
  padding-bottom: 1rem;
}

.mix-select-stack,
.pro-select-stack {
  position: relative;
  align-items: start;
}

.mix-select-box,
.pro-select-box {
  position: relative !important;
  height: 74px !important;
  min-height: 74px !important;
  max-height: 74px !important;
  overflow: visible !important;
  isolation: isolate;
}

.mix-select-box[open],
.pro-select-box[open] {
  z-index: 300 !important;
}

.mix-select-box > summary,
.pro-select-box > summary {
  height: 74px;
  min-height: 74px;
  position: relative;
  z-index: 2;
  border-radius: 18px;
}

.mix-select-box > .mix-select-content,
.pro-select-box > .pro-select-content {
  position: absolute !important;
  top: calc(100% + .62rem) !important;
  left: .25rem !important;
  right: auto !important;
  width: max(100%, min(420px, calc(100vw - 2.5rem))) !important;
  min-width: 0 !important;
  max-width: calc(100vw - 2.5rem) !important;
  z-index: 320 !important;
  padding: .95rem !important;
  border: 1px solid color-mix(in oklab, var(--brand) 48%, var(--line)) !important;
  border-radius: 16px !important;
  background: color-mix(in oklab, var(--panel-solid) 98%, transparent) !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.5) !important;
  backdrop-filter: blur(18px);
}

.mix-select-box:nth-child(3) > .mix-select-content,
.mix-select-box:nth-child(4) > .mix-select-content,
.pro-select-box:nth-child(3) > .pro-select-content,
.pro-select-box:nth-child(4) > .pro-select-content {
  left: auto !important;
  right: .25rem !important;
}

.mix-select-box:not([open]) > .mix-select-content,
.pro-select-box:not([open]) > .pro-select-content {
  display: none !important;
}

.mix-select-box[open]::before,
.pro-select-box[open]::before {
  bottom: -.72rem !important;
  z-index: 321 !important;
}

/* Der geöffnete Inhalt darf die Mutterkarte optisch nicht verlängern. */
.mix-select-box[open] .mix-select-content,
.pro-select-box[open] .pro-select-content {
  display: grid !important;
}

/* Profi-Bereich: mehr Innenabstand, ruhigeres Untermenü-Design */
.mix-advanced-compact {
  margin-top: 1.15rem;
  border-radius: 22px !important;
  overflow: visible !important;
}

.mix-advanced-compact > summary {
  padding: 1rem 1.15rem !important;
}

.pro-select-stack {
  padding: .9rem 1.15rem 1.15rem !important;
  gap: .85rem !important;
}

.pro-select-box {
  border-radius: 16px !important;
  background: color-mix(in oklab, var(--panel) 82%, transparent) !important;
}

.pro-select-box > summary {
  padding-inline: .82rem !important;
}

.pro-select-box > .pro-select-content {
  left: .35rem !important;
  right: auto !important;
}

.pro-select-content select,
.pro-select-content input,
.mix-select-content select,
.mix-select-content input {
  border-radius: 13px !important;
}

.pro-options-grid .mix-switch {
  border-radius: 13px !important;
}

/* Wenn ein Profi-Menü offen ist, bleibt der Countdown-/Button-Bereich darunter unverändert. */
.mix-panel:has(.mix-select-box[open]) .countdown-card,
.mix-panel:has(.pro-select-box[open]) .countdown-card,
.mix-panel:has(.mix-select-box[open]) .mix-controls,
.mix-panel:has(.pro-select-box[open]) .mix-controls {
  transform: none !important;
}

@media (max-width: 1180px) {
  .mix-select-box:nth-child(2) > .mix-select-content,
  .mix-select-box:nth-child(4) > .mix-select-content,
  .pro-select-box:nth-child(2) > .pro-select-content,
  .pro-select-box:nth-child(4) > .pro-select-content {
    left: auto !important;
    right: .25rem !important;
  }
}

@media (max-width: 760px) {
  .mix-select-box,
  .pro-select-box,
  .mix-select-box > summary,
  .pro-select-box > summary {
    height: 66px !important;
    min-height: 66px !important;
    max-height: 66px !important;
  }
  .mix-select-box > .mix-select-content,
  .pro-select-box > .pro-select-content {
    left: 0 !important;
    right: auto !important;
    width: min(100%, calc(100vw - 2rem)) !important;
    max-width: calc(100vw - 2rem) !important;
  }
  .mix-select-box:nth-child(n) > .mix-select-content,
  .pro-select-box:nth-child(n) > .pro-select-content {
    left: 0 !important;
    right: auto !important;
  }
  .pro-select-stack {
    padding-inline: .85rem !important;
  }
}


/* ===== css/98-pro-settings-polish.css ===== */
.mix-panel,
.mix-panel .mix-advanced-compact,
.mix-panel .pro-select-stack,
.mix-panel .pro-select-box {
  overflow: visible !important;
}

.mix-advanced-compact {
  margin: 1.15rem 1rem 0 !important;
  border-radius: 22px !important;
  border: 1px solid color-mix(in oklab, var(--line) 82%, transparent) !important;
  background: color-mix(in oklab, var(--panel-strong) 50%, transparent) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.025);
  position: relative;
  z-index: 35;
}

.mix-advanced-compact > summary {
  min-height: 54px;
  display: flex !important;
  align-items: center;
  gap: .55rem;
  padding: .95rem 1.05rem !important;
  border-radius: 22px 22px 0 0;
  border-bottom: 1px solid color-mix(in oklab, var(--line) 72%, transparent);
  background: color-mix(in oklab, var(--bg-soft) 28%, transparent);
}

.mix-advanced-compact:not([open]) > summary {
  border-bottom: 0;
  border-radius: 22px;
}

.pro-select-stack {
  box-sizing: border-box;
  width: calc(100% - 2rem) !important;
  margin: 1rem !important;
  padding: .85rem !important;
  border: 1px solid color-mix(in oklab, var(--line) 70%, transparent);
  border-radius: 18px !important;
  background: color-mix(in oklab, var(--bg-soft) 38%, transparent);
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .8rem !important;
  align-items: start;
}

.pro-select-box {
  height: 64px !important;
  min-height: 64px !important;
  max-height: 64px !important;
  min-width: 0;
  border-radius: 15px !important;
  border: 1px solid color-mix(in oklab, var(--line) 86%, transparent) !important;
  background: color-mix(in oklab, var(--panel) 78%, transparent) !important;
  box-shadow: none !important;
  position: relative !important;
  isolation: isolate;
}

.pro-select-box[open] {
  z-index: 420 !important;
  border-color: color-mix(in oklab, var(--brand) 54%, var(--line)) !important;
  background: color-mix(in oklab, var(--brand) 8%, var(--panel)) !important;
}

.pro-select-box > summary {
  min-height: 64px !important;
  height: 64px !important;
  padding: .65rem .78rem !important;
  border-radius: 15px !important;
  display: grid !important;
  grid-template-columns: auto minmax(0, auto) minmax(0, 1fr) auto;
  align-items: center;
  gap: .45rem !important;
}

.pro-select-box > summary .wizard-number {
  width: 32px;
  height: 32px;
  min-width: 32px;
  font-size: .88rem;
}

.pro-select-box > summary strong,
.pro-select-box > summary small {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.pro-select-box > summary strong {
  font-size: .95rem;
}

.pro-select-box > summary small {
  grid-column: auto !important;
  color: var(--muted);
  font-size: .78rem;
}

.pro-select-box > .pro-select-content {
  position: absolute !important;
  top: calc(100% + .7rem) !important;
  left: .25rem !important;
  right: auto !important;
  z-index: 450 !important;
  display: grid !important;
  width: max(100%, min(560px, calc(100vw - 4rem))) !important;
  max-width: calc(100vw - 4rem) !important;
  min-width: min(360px, calc(100vw - 4rem)) !important;
  box-sizing: border-box;
  padding: 1rem !important;
  gap: .8rem !important;
  border: 1px solid color-mix(in oklab, var(--brand) 50%, var(--line)) !important;
  border-radius: 14px !important;
  background: color-mix(in oklab, var(--panel-solid) 98%, transparent) !important;
  box-shadow: 0 28px 80px rgba(0,0,0,.52) !important;
  backdrop-filter: blur(18px);
}

.pro-select-box:not([open]) > .pro-select-content {
  display: none !important;
}

.pro-select-box:nth-child(3) > .pro-select-content,
.pro-select-box:nth-child(4) > .pro-select-content {
  left: auto !important;
  right: .25rem !important;
}

.pro-select-box[open]::before {
  content: "";
  position: absolute;
  left: 1.05rem;
  bottom: -.78rem;
  width: 14px;
  height: 14px;
  transform: rotate(45deg);
  z-index: 451 !important;
  border-left: 1px solid color-mix(in oklab, var(--brand) 50%, var(--line));
  border-top: 1px solid color-mix(in oklab, var(--brand) 50%, var(--line));
  background: color-mix(in oklab, var(--panel-solid) 98%, transparent);
}

.pro-select-box:nth-child(3)[open]::before,
.pro-select-box:nth-child(4)[open]::before {
  left: auto;
  right: 1.05rem;
}

.pro-select-content .mix-genre-chips,
.pro-select-content .pro-two-col,
.pro-select-content .pro-three-col,
.pro-select-content .pro-options-grid {
  border: 1px solid color-mix(in oklab, var(--line) 78%, transparent);
  border-radius: 12px !important;
  padding: .8rem !important;
  background: color-mix(in oklab, var(--bg-soft) 64%, transparent);
}

.pro-select-content .mix-genre-chips {
  max-height: 220px !important;
  overflow: auto;
}

.pro-select-content input,
.pro-select-content select {
  border-radius: 12px !important;
  min-height: 46px;
}

.pro-select-content .mix-switch {
  border-radius: 12px !important;
}

/* Die darunterliegenden Steuerbereiche bleiben an Ort und Stelle. */
.mix-panel:has(.pro-select-box[open]) .countdown-card,
.mix-panel:has(.pro-select-box[open]) .mix-controls,
.mix-panel:has(.mix-select-box[open]) .countdown-card,
.mix-panel:has(.mix-select-box[open]) .mix-controls {
  position: relative;
  z-index: 1;
  transform: none !important;
}

@media (max-width: 1180px) {
  .pro-select-stack {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .pro-select-box:nth-child(2) > .pro-select-content,
  .pro-select-box:nth-child(4) > .pro-select-content {
    left: auto !important;
    right: .25rem !important;
  }
}

@media (max-width: 760px) {
  .mix-advanced-compact {
    margin-inline: .72rem !important;
  }
  .pro-select-stack {
    width: calc(100% - 1.2rem) !important;
    margin: .6rem !important;
    padding: .6rem !important;
    grid-template-columns: 1fr;
    gap: .65rem !important;
  }
  .pro-select-box,
  .pro-select-box > summary {
    height: 60px !important;
    min-height: 60px !important;
    max-height: 60px !important;
  }
  .pro-select-box > .pro-select-content,
  .pro-select-box:nth-child(n) > .pro-select-content {
    left: 0 !important;
    right: auto !important;
    width: min(100%, calc(100vw - 2rem)) !important;
    min-width: 0 !important;
    max-width: calc(100vw - 2rem) !important;
  }
}


/* ===== css/98b-mix-pro-final-polish.css ===== */
.mix-panel {
  overflow: visible !important;
  position: relative;
}
.mix-wizard-compact,
.mix-advanced-compact {
  box-sizing: border-box !important;
  width: 100% !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}
.mix-wizard-compact {
  position: relative !important;
  z-index: 60 !important;
  padding: 1rem !important;
}
.mix-wizard-compact:has(.mix-select-box[open]) {
  z-index: 1600 !important;
}
.mix-advanced-compact {
  margin-top: 1.15rem !important;
  position: relative !important;
  z-index: 40 !important;
  overflow: visible !important;
  border-radius: 24px !important;
  border-color: color-mix(in oklab, var(--line) 76%, transparent) !important;
  background: color-mix(in oklab, var(--panel-strong) 46%, transparent) !important;
}
.mix-advanced-compact:has(.pro-select-box[open]) {
  z-index: 1700 !important;
}
.mix-select-stack,
.pro-select-stack {
  overflow: visible !important;
  position: relative !important;
}
.mix-select-box,
.pro-select-box {
  position: relative !important;
  overflow: visible !important;
  isolation: isolate;
}
.mix-select-box[open],
.pro-select-box[open] {
  z-index: 1800 !important;
}
/* Pfeilspitzen entfernen: die sahen eckig/unsauber aus und bringen keinen Mehrwert. */
.mix-select-box[open]::before,
.pro-select-box[open]::before {
  display: none !important;
  content: none !important;
}
.mix-select-box > .mix-select-content,
.pro-select-box > .pro-select-content {
  top: calc(100% + .55rem) !important;
  border-radius: 20px !important;
  border: 1px solid color-mix(in oklab, var(--brand) 42%, var(--line)) !important;
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--panel-solid) 98%, transparent), color-mix(in oklab, var(--panel) 94%, transparent)) !important;
  box-shadow: 0 22px 68px rgba(0,0,0,.48), 0 0 0 1px rgba(255,255,255,.02) inset !important;
  backdrop-filter: blur(18px) !important;
  z-index: 1900 !important;
}
.mix-select-box > .mix-select-content {
  left: 0 !important;
  right: auto !important;
  width: min(420px, calc(100vw - 2.25rem)) !important;
  min-width: min(320px, calc(100vw - 2.25rem)) !important;
  max-width: calc(100vw - 2.25rem) !important;
  padding: 1rem !important;
}
.mix-select-box:nth-child(3) > .mix-select-content,
.mix-select-box:nth-child(4) > .mix-select-content {
  left: auto !important;
  right: 0 !important;
}
/* Intervall rechts unten darf Profi-Einstellungen überlagern, nicht darunter verschwinden. */
.mix-select-box:nth-child(4) > .mix-select-content {
  width: min(360px, calc(100vw - 2.25rem)) !important;
  min-width: min(300px, calc(100vw - 2.25rem)) !important;
}
/* Profi-Container: gleiche Außenbreite wie der Assistent, aber innen klar eingerückt. */
.mix-advanced-compact > summary {
  min-height: 58px !important;
  padding: 1rem 1.1rem !important;
  border-radius: 24px 24px 0 0 !important;
  background: color-mix(in oklab, var(--bg-soft) 32%, transparent) !important;
}
.mix-advanced-compact:not([open]) > summary {
  border-radius: 24px !important;
}
.pro-select-stack {
  width: auto !important;
  margin: 0 !important;
  padding: 1rem !important;
  border: 0 !important;
  border-top: 1px solid color-mix(in oklab, var(--line) 58%, transparent) !important;
  border-radius: 0 0 24px 24px !important;
  background: color-mix(in oklab, var(--bg-soft) 20%, transparent) !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: .85rem !important;
}
.pro-select-box {
  height: 66px !important;
  min-height: 66px !important;
  max-height: 66px !important;
  border-radius: 18px !important;
  background: color-mix(in oklab, var(--panel) 82%, transparent) !important;
}
.pro-select-box > summary {
  height: 66px !important;
  min-height: 66px !important;
  max-height: 66px !important;
  border-radius: 18px !important;
  padding: .72rem .82rem !important;
}
.pro-select-box > .pro-select-content {
  left: 0 !important;
  right: auto !important;
  width: min(560px, calc(100vw - 2.5rem)) !important;
  min-width: min(360px, calc(100vw - 2.5rem)) !important;
  max-width: calc(100vw - 2.5rem) !important;
  padding: 1rem !important;
}
.pro-select-box:nth-child(3) > .pro-select-content,
.pro-select-box:nth-child(4) > .pro-select-content {
  left: auto !important;
  right: 0 !important;
}
/* Geöffnete Innenbereiche etwas ruhiger als Karten, nicht wie harte Kästen. */
.pro-select-content .mix-genre-chips,
.pro-select-content .pro-two-col,
.pro-select-content .pro-three-col,
.pro-select-content .pro-options-grid {
  margin: 0 !important;
  border-radius: 16px !important;
  padding: .9rem !important;
  border-color: color-mix(in oklab, var(--line) 66%, transparent) !important;
  background: color-mix(in oklab, var(--bg-soft) 52%, transparent) !important;
}
.pro-select-content label,
.pro-select-content .mix-switch,
.mix-select-content label {
  margin: 0 !important;
}
/* Untere Steuerung bleibt ruhig an Ort und Stelle. */
.mix-panel:has(.mix-select-box[open]) .mix-controls,
.mix-panel:has(.pro-select-box[open]) .mix-controls,
.mix-panel:has(.mix-select-box[open]) .countdown-card,
.mix-panel:has(.pro-select-box[open]) .countdown-card {
  transform: none !important;
  position: relative !important;
  z-index: 1 !important;
}
@media (max-width: 1180px) {
  .pro-select-stack {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .mix-select-box:nth-child(2) > .mix-select-content,
  .mix-select-box:nth-child(4) > .mix-select-content,
  .pro-select-box:nth-child(2) > .pro-select-content,
  .pro-select-box:nth-child(4) > .pro-select-content {
    left: auto !important;
    right: 0 !important;
  }
}
@media (max-width: 760px) {
  .mix-wizard-compact,
  .mix-advanced-compact {
    border-radius: 20px !important;
  }
  .mix-select-stack,
  .pro-select-stack {
    grid-template-columns: 1fr !important;
  }
  .pro-select-stack {
    padding: .8rem !important;
    gap: .65rem !important;
  }
  .mix-select-box > .mix-select-content,
  .mix-select-box:nth-child(n) > .mix-select-content,
  .pro-select-box > .pro-select-content,
  .pro-select-box:nth-child(n) > .pro-select-content {
    left: 0 !important;
    right: auto !important;
    width: min(100%, calc(100vw - 1.5rem)) !important;
    min-width: 0 !important;
    max-width: calc(100vw - 1.5rem) !important;
  }
}


/* ===== css/98c-mix-summary-inline.css ===== */
.mix-select-box > summary {
  display: grid !important;
  grid-template-columns: auto auto minmax(0, 1fr) auto !important;
  grid-template-rows: 1fr !important;
  align-items: center !important;
  column-gap: .68rem !important;
  row-gap: 0 !important;
  min-height: 66px !important;
  padding: .8rem .9rem !important;
}
.mix-select-box > summary .wizard-number {
  grid-column: 1 !important;
  grid-row: 1 !important;
  width: 34px !important;
  height: 34px !important;
  flex: 0 0 auto !important;
}
.mix-select-box > summary strong {
  grid-column: 2 !important;
  grid-row: 1 !important;
  font-size: 1rem !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  overflow: visible !important;
  text-overflow: clip !important;
}
.mix-select-box > summary small {
  grid-column: 3 !important;
  grid-row: 1 !important;
  justify-self: start !important;
  align-self: center !important;
  min-width: 0 !important;
  max-width: 100% !important;
  margin-top: 0 !important;
  color: var(--muted) !important;
  font-size: .83rem !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.mix-select-box > summary::after {
  grid-column: 4 !important;
  grid-row: 1 !important;
  justify-self: end !important;
  align-self: center !important;
  content: "⌄" !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 22px !important;
  height: 22px !important;
  border-radius: 999px !important;
  color: color-mix(in oklab, var(--muted) 80%, white 12%) !important;
  font-size: .95rem !important;
  transform: none !important;
  transition: transform .16s ease, color .16s ease, background .16s ease !important;
}
.mix-select-box[open] > summary::after {
  content: "⌃" !important;
  transform: none !important;
  color: var(--text) !important;
  background: color-mix(in oklab, var(--brand) 18%, transparent) !important;
}
.mix-select-box > summary:hover::after,
.mix-select-box > summary:focus-visible::after {
  color: var(--text) !important;
  background: color-mix(in oklab, var(--brand) 12%, transparent) !important;
}
.mix-select-box[open] > summary {
  border-radius: 20px !important;
}
/* Geöffnete Dropdowns beginnen immer unter der gesamten Karte. */
.mix-select-box > .mix-select-content {
  top: calc(100% + .65rem) !important;
}
/* Im Desktop sollen alle vier Karten einheitlich hoch bleiben. */
.mix-select-box {
  min-height: 66px !important;
  max-height: 66px !important;
}
.mix-select-box[open] {
  max-height: 66px !important;
}
/* Inhalt schwebt, die Karte selbst wächst nicht. */
.mix-select-box[open] > .mix-select-content {
  position: absolute !important;
}
/* Profi-Einstellungen bekommen den gleichen zusammengefassten Kopfaufbau. */
.pro-select-box > summary {
  display: grid !important;
  grid-template-columns: auto auto minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: .68rem !important;
}
.pro-select-box > summary .wizard-number {
  grid-column: 1 !important;
}
.pro-select-box > summary strong {
  grid-column: 2 !important;
  white-space: nowrap !important;
}
.pro-select-box > summary small {
  grid-column: 3 !important;
  justify-self: start !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.pro-select-box > summary::after {
  grid-column: 4 !important;
  justify-self: end !important;
  content: "⌄" !important;
  color: var(--muted) !important;
}
.pro-select-box[open] > summary::after {
  content: "⌃" !important;
  color: var(--text) !important;
}
@media (max-width: 760px) {
  .mix-select-box > summary,
  .pro-select-box > summary {
    grid-template-columns: auto minmax(0, auto) minmax(0, 1fr) auto !important;
    column-gap: .55rem !important;
    min-height: 62px !important;
    padding: .72rem .78rem !important;
  }
  .mix-select-box > summary strong,
  .pro-select-box > summary strong {
    font-size: .94rem !important;
  }
  .mix-select-box > summary small,
  .pro-select-box > summary small {
    font-size: .78rem !important;
  }
}
@media (max-width: 460px) {
  .mix-select-box > summary,
  .pro-select-box > summary {
    grid-template-columns: auto minmax(0, 1fr) auto !important;
  }
  .mix-select-box > summary small,
  .pro-select-box > summary small {
    grid-column: 2 !important;
    grid-row: 2 !important;
    margin-top: .32rem !important;
  }
  .mix-select-box > summary::after,
  .pro-select-box > summary::after {
    grid-column: 3 !important;
    grid-row: 1 / span 2 !important;
  }
}


.mix-select-box > summary,
.pro-select-box > summary {
  display: flex !important;
  align-items: center !important;
  gap: .72rem !important;
  min-height: 66px !important;
}
.mix-select-box > summary .wizard-number,
.pro-select-box > summary .wizard-number {
  flex: 0 0 auto !important;
}
.mix-select-box > summary strong,
.pro-select-box > summary strong {
  flex: 0 1 auto !important;
  min-width: 0 !important;
  line-height: 1.05 !important;
  margin: 0 !important;
}
.mix-select-box > summary small,
.pro-select-box > summary small {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  line-height: 1.05 !important;
  margin: 0 !important;
  align-self: center !important;
}
.mix-select-box > summary::after,
.pro-select-box > summary::after {
  margin-left: auto !important;
  flex: 0 0 auto !important;
  position: static !important;
  inset: auto !important;
  align-self: center !important;
  justify-self: auto !important;
  line-height: 1 !important;
}

@media (max-width: 760px) {
  .mix-select-box > summary,
  .pro-select-box > summary {
    gap: .58rem !important;
    min-height: 62px !important;
  }
  .mix-select-box > summary strong,
  .pro-select-box > summary strong {
    font-size: .94rem !important;
  }
  .mix-select-box > summary small,
  .pro-select-box > summary small {
    font-size: .78rem !important;
  }
}

@media (max-width: 460px) {
  .mix-select-box > summary,
  .pro-select-box > summary {
    gap: .46rem !important;
  }
}


.mix-select-box > summary,
.pro-select-box > summary {
  display: grid !important;
  grid-template-columns: auto auto minmax(0, 1fr) auto !important;
  grid-template-rows: 1fr !important;
  align-items: center !important;
  column-gap: .72rem !important;
  row-gap: 0 !important;
}
.mix-select-box > summary .wizard-number,
.pro-select-box > summary .wizard-number {
  grid-column: 1 !important;
  grid-row: 1 !important;
  align-self: center !important;
}
.mix-select-box > summary strong,
.pro-select-box > summary strong {
  grid-column: 2 !important;
  grid-row: 1 !important;
  align-self: center !important;
  line-height: 1 !important;
}
.mix-select-box > summary small,
.pro-select-box > summary small {
  grid-column: 3 !important;
  grid-row: 1 !important;
  align-self: center !important;
  justify-self: start !important;
  line-height: 1 !important;
  margin: 0 !important;
}
.mix-select-box > summary::after,
.pro-select-box > summary::after {
  grid-column: 4 !important;
  grid-row: 1 !important;
  align-self: center !important;
  justify-self: end !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  min-height: 20px !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1 !important;
  vertical-align: middle !important;
  position: relative !important;
  top: 0 !important;
  bottom: auto !important;
  transform: none !important;
  translate: 0 0 !important;
  content: "⌄" !important;
}
.mix-select-box[open] > summary::after,
.pro-select-box[open] > summary::after {
  content: "⌃" !important;
  transform: none !important;
  top: 0 !important;
}
@media (max-width: 460px) {
  .mix-select-box > summary,
  .pro-select-box > summary {
    grid-template-columns: auto auto minmax(0, 1fr) auto !important;
  }
  .mix-select-box > summary small,
  .pro-select-box > summary small {
    grid-column: 3 !important;
    grid-row: 1 !important;
    margin-top: 0 !important;
  }
  .mix-select-box > summary::after,
  .pro-select-box > summary::after {
    grid-column: 4 !important;
    grid-row: 1 !important;
  }
}


.mix-select-box > summary,
.pro-select-box > summary,
.mix-advanced-compact > summary {
  cursor: pointer !important;
  transition: background-color .18s ease, border-color .18s ease, box-shadow .18s ease, color .18s ease !important;
}

.mix-select-box > summary:hover,
.mix-select-box > summary:focus-visible,
.pro-select-box > summary:hover,
.pro-select-box > summary:focus-visible,
.mix-advanced-compact > summary:hover,
.mix-advanced-compact > summary:focus-visible {
  background: color-mix(in oklab, var(--bg-soft) 40%, transparent) !important;
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--line) 78%, transparent) !important;
}

.mix-select-box > summary::after,
.pro-select-box > summary::after {
  content: "" !important;
  width: 10px !important;
  height: 10px !important;
  min-width: 10px !important;
  min-height: 10px !important;
  border-right: 2px solid color-mix(in oklab, var(--muted) 88%, white 10%) !important;
  border-bottom: 2px solid color-mix(in oklab, var(--muted) 88%, white 10%) !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  transform: rotate(45deg) !important;
  transform-origin: center center !important;
  margin: 0 !important;
  padding: 0 !important;
  position: static !important;
  top: auto !important;
  inset: auto !important;
  align-self: center !important;
  justify-self: end !important;
}
.mix-select-box[open] > summary::after,
.pro-select-box[open] > summary::after {
  content: "" !important;
  transform: rotate(-135deg) !important;
  border-right-color: color-mix(in oklab, var(--text) 96%, white 4%) !important;
  border-bottom-color: color-mix(in oklab, var(--text) 96%, white 4%) !important;
  background: transparent !important;
}
.mix-select-box > summary:hover::after,
.mix-select-box > summary:focus-visible::after,
.pro-select-box > summary:hover::after,
.pro-select-box > summary:focus-visible::after {
  border-right-color: color-mix(in oklab, var(--text) 96%, white 4%) !important;
  border-bottom-color: color-mix(in oklab, var(--text) 96%, white 4%) !important;
  background: transparent !important;
}

.mix-advanced-compact > summary::before {
  content: "" !important;
  display: inline-block !important;
  width: 10px !important;
  height: 10px !important;
  min-width: 10px !important;
  min-height: 10px !important;
  margin-right: .7rem !important;
  border-right: 2px solid color-mix(in oklab, var(--muted) 88%, white 10%) !important;
  border-bottom: 2px solid color-mix(in oklab, var(--muted) 88%, white 10%) !important;
  transform: rotate(45deg) !important;
  transform-origin: center center !important;
  transition: transform .18s ease, border-color .18s ease !important;
  align-self: center !important;
}
.mix-advanced-compact[open] > summary::before {
  transform: rotate(-135deg) !important;
  border-right-color: color-mix(in oklab, var(--text) 96%, white 4%) !important;
  border-bottom-color: color-mix(in oklab, var(--text) 96%, white 4%) !important;
}
.mix-advanced-compact > summary:hover::before,
.mix-advanced-compact > summary:focus-visible::before {
  border-right-color: color-mix(in oklab, var(--text) 96%, white 4%) !important;
  border-bottom-color: color-mix(in oklab, var(--text) 96%, white 4%) !important;
}


/* ===== css/99-update-toast.css ===== */
.update-toast {
  position: fixed;
  left: max(1rem, env(safe-area-inset-left));
  right: max(1rem, env(safe-area-inset-right));
  bottom: calc(1rem + env(safe-area-inset-bottom));
  z-index: 80;
  max-width: 720px;
  margin-inline: auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: .85rem;
  padding: .85rem;
  border: 1px solid color-mix(in oklab, var(--brand) 36%, var(--line));
  border-radius: 18px;
  background: color-mix(in oklab, var(--panel-solid) 94%, transparent);
  box-shadow: 0 18px 70px rgba(0,0,0,.36);
  backdrop-filter: blur(18px);
  transform: translateY(1rem);
  opacity: 0;
  transition: opacity .18s ease, transform .18s ease;
}
.update-toast.show {
  transform: translateY(0);
  opacity: 1;
}
.update-toast div {
  min-width: 0;
  display: grid;
  gap: .15rem;
}
.update-toast strong {
  font-size: .95rem;
}
.update-toast span {
  color: var(--muted);
  font-size: .86rem;
}
@media (max-width: 720px) {
  .update-toast {
    bottom: calc(5.9rem + env(safe-area-inset-bottom));
    grid-template-columns: 1fr auto;
  }
  .update-toast div {
    grid-column: 1 / -1;
  }
  .update-toast .primary-button {
    width: 100%;
  }
}

.stage-control-row {
  grid-template-columns: minmax(0, 1fr) minmax(300px, 390px) minmax(320px, 430px) auto;
  align-items: center;
  gap: .9rem;
}
.stage-transport .primary-button,
.stage-transport .soft-button,
#muteButton,
#fullscreenStageButton {
  min-height: 42px;
  padding: .65rem .92rem;
  font-size: .98rem;
}
#muteButton,
#fullscreenStageButton {
  min-width: 96px;
}
.stage-volume {
  max-width: 390px;
  grid-template-columns: max-content minmax(0, 1fr) max-content;
  gap: .8rem;
}
.stage-quality {
  max-width: 430px;
  grid-template-columns: max-content minmax(0, 1fr);
  gap: .8rem;
}
.stage-quality select,
#qualityVariantSelect {
  width: 100%;
  min-width: 0;
  min-height: 42px;
  padding: .65rem 2.4rem .65rem .92rem;
}

.stage-volume input[type="range"],
.fullscreen-volume input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 18px;
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  cursor: pointer;
  --range-progress: 85%;
  --range-fill: #ff456f;
  --range-rest: rgba(255,255,255,.22);
}
.stage-volume input[type="range"]::-webkit-slider-runnable-track,
.fullscreen-volume input[type="range"]::-webkit-slider-runnable-track {
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--range-fill) 0%, var(--range-fill) var(--range-progress), var(--range-rest) var(--range-progress), var(--range-rest) 100%);
}
.stage-volume input[type="range"]::-webkit-slider-thumb,
.fullscreen-volume input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 18px;
  height: 18px;
  margin-top: -5px;
  border-radius: 50%;
  background: #ff456f;
  border: 2px solid #fff;
  box-shadow: 0 4px 14px rgba(255,69,111,.35);
}
.stage-volume input[type="range"]::-moz-range-track,
.fullscreen-volume input[type="range"]::-moz-range-track {
  height: 8px;
  border: 0;
  border-radius: 999px;
  background: var(--range-rest);
}
.stage-volume input[type="range"]::-moz-range-progress,
.fullscreen-volume input[type="range"]::-moz-range-progress {
  height: 8px;
  border-radius: 999px;
  background: var(--range-fill);
}
.stage-volume input[type="range"]::-moz-range-thumb,
.fullscreen-volume input[type="range"]::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #ff456f;
  border: 2px solid #fff;
  box-shadow: 0 4px 14px rgba(255,69,111,.35);
}
.stage-volume.is-muted input[type="range"],
.fullscreen-volume.is-muted input[type="range"] {
  --range-fill: #98a2b8;
  --range-rest: rgba(255,255,255,.14);
}

@media (max-width: 1320px) {
  .stage-control-row {
    grid-template-columns: 1fr 1fr;
  }
  .stage-transport {
    grid-column: 1 / -1;
  }
  .stage-volume,
  .stage-quality,
  #fullscreenStageButton {
    max-width: none;
    width: 100%;
  }
}
@media (max-width: 760px) {
  .stage-control-row {
    grid-template-columns: 1fr;
  }
  .stage-volume,
  .stage-quality {
    grid-template-columns: 1fr;
  }
  #muteButton,
  #fullscreenStageButton,
  .stage-quality select,
  #qualityVariantSelect {
    width: 100%;
  }
}

.stage-control-row {
  grid-template-columns: minmax(620px, 1fr) minmax(260px, 310px) minmax(300px, 380px) max-content !important;
  align-items: center !important;
  gap: .65rem !important;
  padding: .72rem 1rem !important;
}
.stage-transport {
  flex-wrap: nowrap !important;
  gap: .42rem !important;
  min-width: 0 !important;
}
.stage-transport .primary-button,
.stage-transport .soft-button,
#muteButton,
#fullscreenStageButton {
  min-height: 38px !important;
  padding: .5rem .72rem !important;
  font-size: .9rem !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}
.stage-transport .primary-button {
  min-width: 70px !important;
}
.stage-volume {
  width: 100% !important;
  max-width: 310px !important;
  grid-template-columns: max-content minmax(120px, 1fr) max-content !important;
  gap: .55rem !important;
  justify-self: stretch !important;
}
.stage-volume label,
.stage-quality label {
  font-size: .86rem !important;
  white-space: nowrap !important;
}
#muteButton {
  min-width: 74px !important;
  justify-self: end !important;
}
.stage-quality {
  width: 100% !important;
  max-width: 380px !important;
  grid-template-columns: max-content minmax(170px, 1fr) !important;
  gap: .55rem !important;
  justify-self: stretch !important;
}
#qualityVariantSelect {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 38px !important;
  padding: .5rem 2.05rem .5rem .8rem !important;
  font-size: .9rem !important;
  text-overflow: ellipsis !important;
}
#fullscreenStageButton {
  min-width: 104px !important;
  justify-self: end !important;
}

@media (max-width: 1680px) {
  .stage-control-row {
    grid-template-columns: minmax(560px, 1fr) minmax(230px, 280px) minmax(260px, 330px) max-content !important;
    gap: .55rem !important;
  }
  .stage-transport .primary-button,
  .stage-transport .soft-button,
  #muteButton,
  #fullscreenStageButton {
    padding-inline: .62rem !important;
    font-size: .86rem !important;
  }
  .stage-volume {
    max-width: 280px !important;
    grid-template-columns: max-content minmax(90px, 1fr) max-content !important;
  }
  .stage-quality {
    max-width: 330px !important;
    grid-template-columns: max-content minmax(140px, 1fr) !important;
  }
}

@media (max-width: 1320px) {
  .stage-control-row {
    grid-template-columns: 1fr 1fr !important;
  }
  .stage-transport {
    grid-column: 1 / -1 !important;
    flex-wrap: wrap !important;
  }
  .stage-volume,
  .stage-quality,
  #fullscreenStageButton {
    max-width: none !important;
    width: 100% !important;
  }
}

@media (max-width: 760px) {
  .stage-control-row {
    grid-template-columns: 1fr !important;
  }
  .stage-transport {
    flex-wrap: wrap !important;
  }
  .stage-transport .primary-button,
  .stage-transport .soft-button,
  #muteButton,
  #fullscreenStageButton {
    min-height: 42px !important;
    font-size: .95rem !important;
  }
}

.modal.station-details-dialog {
  position: relative;
  box-sizing: border-box;
  max-width: min(1120px, calc(100vw - 3rem));
  width: min(1120px, calc(100vw - 3rem));
  max-height: calc(100vh - 3rem);
  overflow: auto;
  padding: 1.15rem 1.15rem 1.25rem;
}
.modal.station-details-dialog .modal-close {
  position: absolute;
  top: .95rem;
  right: .95rem;
  z-index: 5;
  width: 44px;
  min-width: 44px;
  height: 44px;
  min-height: 44px;
  padding: 0;
}
.modal.station-details-dialog #modalContent {
  min-width: 0;
}
.station-detail-modal {
  min-width: 0;
}
.station-detail-modal .detail-head {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(220px, auto);
  align-items: start;
  gap: 1rem;
  margin-right: 0 !important;
  padding-right: 3.2rem;
  min-width: 0;
}
.station-detail-modal .detail-title-wrap {
  min-width: 0;
  align-items: center;
}
.station-detail-modal .detail-title-wrap > div {
  min-width: 0;
}
.station-detail-modal .detail-title-wrap h2 {
  max-width: 100%;
  overflow-wrap: anywhere;
}
.station-detail-modal .detail-head-actions {
  min-width: 0;
  max-width: 100%;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: .5rem;
  flex-wrap: wrap;
  padding-right: 0;
}
.station-detail-modal .detail-head-actions .soft-button {
  min-height: 38px;
  white-space: nowrap;
}
.station-detail-modal .detail-grid {
  align-items: stretch;
}
.station-detail-modal .detail-grid > div {
  min-width: 0;
  min-height: 74px;
  overflow: hidden;
}
.station-detail-modal .detail-grid strong {
  white-space: normal;
  overflow-wrap: anywhere;
  line-height: 1.25;
}
.station-detail-modal .detail-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .75rem;
  flex-wrap: wrap;
}
.station-detail-modal .detail-section-head h3 {
  flex: 0 0 auto;
}
.station-detail-modal .detail-section-head small {
  flex: 1 1 260px;
  min-width: 0;
  text-align: right;
  line-height: 1.35;
}
.station-detail-modal .detail-chip-list {
  min-width: 0;
}
.station-detail-modal .detail-chip {
  min-width: 0;
  width: 100%;
  overflow: hidden;
}
.station-detail-modal .detail-chip strong,
.station-detail-modal .detail-chip span,
.station-detail-modal .detail-chip small {
  white-space: normal;
  overflow-wrap: anywhere;
  line-height: 1.25;
}
.station-detail-modal-note {
  margin: 0;
  line-height: 1.45;
}
@media (max-width: 980px) {
  .station-detail-modal .detail-head {
    grid-template-columns: 1fr;
    padding-right: 3.2rem;
  }
  .station-detail-modal .detail-head-actions {
    justify-content: flex-start;
  }
}
@media (max-width: 760px) {
  .modal.station-details-dialog {
    width: calc(100vw - 1rem);
    max-width: calc(100vw - 1rem);
    max-height: calc(100vh - 1rem);
    padding: .95rem;
  }
  .modal.station-details-dialog .modal-close {
    top: .65rem;
    right: .65rem;
  }
  .station-detail-modal .detail-head {
    padding-right: 2.8rem;
    gap: .85rem;
  }
  .station-detail-modal .detail-title-wrap {
    gap: .75rem;
  }
  .station-detail-modal .detail-head-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 100%;
  }
  .station-detail-modal .detail-head-actions .soft-button {
    width: 100%;
    justify-content: center;
  }
  .station-detail-modal .detail-section-head small {
    flex-basis: 100%;
    text-align: left;
  }
}
@media (max-width: 460px) {
  .station-detail-modal .detail-head-actions {
    grid-template-columns: 1fr;
  }
  .station-detail-modal .detail-title-wrap {
    align-items: flex-start;
  }
}

.modal.station-details-dialog,
.modal.station-details-dialog * {
  box-sizing: border-box;
}
.modal.station-details-dialog {
  overflow-x: hidden !important;
}
.station-detail-modal {
  display: grid !important;
  gap: 1rem !important;
}
.station-detail-modal .detail-head {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: .95rem !important;
  padding-right: 3.4rem !important;
  align-items: start !important;
}
.station-detail-modal .detail-title-wrap {
  display: grid !important;
  grid-template-columns: 78px minmax(0, 1fr) !important;
  gap: 1rem !important;
  align-items: start !important;
  min-width: 0 !important;
}
.station-detail-modal .detail-logo {
  width: 78px !important;
  height: 78px !important;
  max-width: 78px !important;
  max-height: 78px !important;
  object-fit: contain !important;
  object-position: center center !important;
  align-self: start !important;
}
.station-detail-modal .detail-title-wrap > div {
  min-width: 0 !important;
  display: grid !important;
  gap: .35rem !important;
}
.station-detail-modal .detail-title-wrap h2 {
  margin: 0 !important;
  min-width: 0 !important;
  max-width: 100% !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  line-height: 1.16 !important;
}
.station-detail-modal .detail-status-badge {
  align-self: start !important;
  max-width: 100% !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  line-height: 1.2 !important;
}
.station-detail-modal .detail-head-actions {
  width: 100% !important;
  justify-content: flex-start !important;
  padding-right: 0 !important;
}
.station-detail-modal .detail-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 230px), 1fr)) !important;
  gap: .75rem !important;
  align-items: stretch !important;
  width: 100% !important;
  min-width: 0 !important;
}
.station-detail-modal .detail-grid > div {
  min-width: 0 !important;
  min-height: auto !important;
  height: auto !important;
  overflow: visible !important;
  display: grid !important;
  align-content: start !important;
  gap: .35rem !important;
  padding: .82rem .9rem !important;
}
.station-detail-modal .detail-grid span,
.station-detail-modal .detail-grid strong {
  min-width: 0 !important;
  max-width: 100% !important;
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: unset !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  hyphens: auto !important;
}
.station-detail-modal .detail-grid strong {
  line-height: 1.22 !important;
}
.station-detail-modal .detail-section,
.station-detail-modal .compact-tags,
.station-detail-modal .detail-tag-list,
.station-detail-modal .detail-chip-list,
.station-detail-modal .detail-chip {
  min-width: 0 !important;
  max-width: 100% !important;
}
.station-detail-modal .detail-section-head {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: start !important;
  gap: .7rem !important;
}
.station-detail-modal .detail-section-head h3,
.station-detail-modal .detail-section-head small {
  min-width: 0 !important;
  max-width: 100% !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
}
.station-detail-modal .detail-section-head small {
  text-align: right !important;
}
@media (max-width: 700px) {
  .station-detail-modal .detail-head {
    padding-right: 2.9rem !important;
  }
  .station-detail-modal .detail-title-wrap {
    grid-template-columns: 64px minmax(0, 1fr) !important;
    gap: .75rem !important;
  }
  .station-detail-modal .detail-logo {
    width: 64px !important;
    height: 64px !important;
    max-width: 64px !important;
    max-height: 64px !important;
  }
  .station-detail-modal .detail-grid {
    grid-template-columns: 1fr !important;
  }
  .station-detail-modal .detail-section-head {
    grid-template-columns: 1fr !important;
  }
  .station-detail-modal .detail-section-head small {
    text-align: left !important;
  }
}
@media (max-width: 430px) {
  .station-detail-modal .detail-title-wrap {
    grid-template-columns: 56px minmax(0, 1fr) !important;
  }
  .station-detail-modal .detail-logo {
    width: 56px !important;
    height: 56px !important;
    max-width: 56px !important;
    max-height: 56px !important;
  }
}

.station-detail-modal .detail-status-badge {
  width: fit-content !important;
  max-width: min(100%, 360px) !important;
  display: inline-flex !important;
  justify-self: start !important;
  align-self: start !important;
  padding-inline: .72rem !important;
  white-space: nowrap !important;
}
@media (max-width: 520px) {
  .station-detail-modal .detail-status-badge {
    max-width: 100% !important;
    white-space: normal !important;
  }
}

.modal-close,
.modal.station-details-dialog .modal-close {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  text-align: center !important;
  font-size: 1.15rem !important;
  font-weight: 800 !important;
  padding: 0 !important;
}
.modal-close::before,
.modal-close::after {
  line-height: 1 !important;
}

.stage-overlay-title:not(.is-station-detail-trigger),
#fullscreenStationTitle:not(.is-station-detail-trigger) {
  cursor: default !important;
  pointer-events: none;
}

.stage-overlay-title[aria-disabled="true"],
#fullscreenStationTitle[aria-disabled="true"] {
  border-color: rgba(255,255,255,.08);
  box-shadow: 0 10px 24px rgba(0,0,0,.14);
}

.stage-overlay-title.is-station-detail-trigger,
#fullscreenStationTitle.is-station-detail-trigger {
  cursor: pointer;
}

.station-title-trigger:disabled,
.station-title-trigger[aria-disabled="true"] {
  cursor: default !important;
  pointer-events: none;
  transform: none !important;
  box-shadow: none !important;
}

.station-title-trigger:disabled .station-title-hint,
.station-title-trigger[aria-disabled="true"] .station-title-hint {
  display: none;
}

.stage-control-row {
  padding: .56rem 1rem .66rem !important;
}

.player-shortcuts-button {
  min-width: 44px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: .35rem !important;
}

@media (max-width: 1680px) {
  .player-shortcuts-button {
    min-width: 42px !important;
    padding-inline: .58rem !important;
  }
}


.mix-panel > .section-title.mix-panel-title {
  align-items: center !important;
}

.mix-panel-title-copy {
  display: flex !important;
  align-items: center !important;
  gap: .72rem !important;
  min-width: 0 !important;
  flex-wrap: nowrap !important;
}

.mix-panel-title-copy .eyebrow,
.mix-panel-title-copy h2 {
  margin: 0 !important;
}

.mix-panel-title-copy .eyebrow {
  line-height: 1 !important;
  white-space: nowrap !important;
}

.mix-panel-title-copy h2 {
  font-size: 1.08rem !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
}

.star-button[aria-pressed="true"],
.favorite-main[aria-pressed="true"],
.mobile-mini-fav[aria-pressed="true"],
[data-modal-action="favorite"][aria-pressed="true"] {
  color: #ffd166 !important;
}

@media (max-width: 430px) {
  .mix-panel > .section-title.mix-panel-title {
    gap: .5rem !important;
  }
  .mix-panel-title-copy {
    gap: .46rem !important;
  }
  .mix-panel-title-copy .eyebrow {
    font-size: .64rem !important;
    letter-spacing: .08em !important;
  }
  .mix-panel-title-copy h2 {
    font-size: .96rem !important;
  }
  .mix-panel > .section-title.mix-panel-title .mini-badge {
    font-size: .72rem !important;
    padding: .42rem .54rem !important;
  }
}

button:not(:disabled),
.icon-button:not(:disabled),
.soft-button:not(:disabled),
.primary-button:not(:disabled),
.link-button:not(:disabled),
.favorite-main:not(:disabled),
.star-button:not(:disabled),
.station-queue-button:not(:disabled),
.station-detail-button:not(:disabled),
.player-shortcuts-button:not(:disabled),
#muteButton:not(:disabled),
#fullscreenMuteButton:not(:disabled) {
  cursor: pointer !important;
}

button:disabled,
button[aria-disabled="true"] {
  cursor: default !important;
}

.stage-control-row,
.stage-volume,
.fullscreen-right-controls,
.fullscreen-volume {
  position: relative !important;
}

.stage-control-row {
  z-index: 8 !important;
  isolation: isolate !important;
}

#muteButton,
#fullscreenMuteButton {
  position: relative !important;
  z-index: 9 !important;
  pointer-events: auto !important;
  touch-action: manipulation !important;
  user-select: none !important;
}

#muteButton:not(:disabled):hover,
#fullscreenMuteButton:not(:disabled):hover {
  border-color: color-mix(in oklab, var(--brand) 58%, var(--line)) !important;
  background: color-mix(in oklab, var(--panel-strong) 76%, var(--brand) 24%) !important;
}

.visual-stage {
  background:
    radial-gradient(circle at 14% 82%, rgba(0, 212, 255, .34), transparent 34%),
    radial-gradient(circle at 25% 22%, rgba(255, 64, 129, .34), transparent 31%),
    radial-gradient(circle at 50% 12%, rgba(255, 214, 10, .22), transparent 32%),
    radial-gradient(circle at 74% 24%, rgba(0, 230, 118, .26), transparent 36%),
    radial-gradient(circle at 82% 76%, rgba(124, 77, 255, .38), transparent 39%),
    radial-gradient(circle at 48% 52%, rgba(255, 255, 255, .08), transparent 32%),
    linear-gradient(135deg, #101522 0%, #090b14 48%, #05070d 100%) !important;
}

.visual-glow {
  inset: 8% !important;
  background: conic-gradient(
    from 20deg,
    #ff1744,
    #ff6d00,
    #ffd600,
    #00e676,
    #00c853,
    #00b0ff,
    #304ffe,
    #7c4dff,
    #d500f9,
    #ff4081,
    #ff1744
  ) !important;
  filter: blur(78px) saturate(1.45) !important;
  opacity: .48 !important;
  mix-blend-mode: screen !important;
}

.visual-stage:fullscreen {
  background:
    radial-gradient(circle at 10% 84%, rgba(0, 212, 255, .34), transparent 34%),
    radial-gradient(circle at 26% 18%, rgba(255, 64, 129, .32), transparent 33%),
    radial-gradient(circle at 52% 12%, rgba(255, 214, 10, .22), transparent 32%),
    radial-gradient(circle at 78% 26%, rgba(0, 230, 118, .26), transparent 36%),
    radial-gradient(circle at 86% 76%, rgba(124, 77, 255, .36), transparent 40%),
    radial-gradient(circle at 48% 48%, rgba(255, 255, 255, .09), transparent 31%),
    linear-gradient(135deg, #101522 0%, #080b14 46%, #05070d 100%) !important;
}

.visual-stage:fullscreen .visual-glow {
  inset: 6% !important;
  filter: blur(92px) saturate(1.5) !important;
  opacity: .5 !important;
}

.update-toast[hidden],
.update-toast:not(.show) {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.update-toast.show {
  display: grid !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

.hero-player,
.stage-control-row,
.stage-volume,
.stage-quality,
#muteButton {
  position: relative !important;
}

.hero-player {
  z-index: 12 !important;
}

.stage-control-row {
  z-index: 120 !important;
  pointer-events: auto !important;
}

.stage-volume {
  z-index: 125 !important;
  pointer-events: auto !important;
}

#muteButton {
  z-index: 130 !important;
  pointer-events: auto !important;
  cursor: pointer !important;
}

#muteButton:disabled {
  cursor: default !important;
}

.visual-glow {
  --glow-blur: 78px;
  --glow-saturation: 1.55;
  background: conic-gradient(
    from 20deg,
    #ff0033 0deg,
    #ff3d00 24deg,
    #ff9100 48deg,
    #ffd600 72deg,
    #aeea00 96deg,
    #00e676 120deg,
    #00c853 144deg,
    #00e5ff 168deg,
    #00b0ff 192deg,
    #2979ff 216deg,
    #304ffe 240deg,
    #651fff 264deg,
    #aa00ff 288deg,
    #d500f9 312deg,
    #ff4081 336deg,
    #ff0033 360deg
  ) !important;
  filter: blur(var(--glow-blur)) saturate(var(--glow-saturation)) hue-rotate(0deg) !important;
  animation: rotateGlow 14s linear infinite, glowSpectrumShift 96s linear infinite !important;
}

.visual-stage:fullscreen .visual-glow {
  --glow-blur: 92px;
  --glow-saturation: 1.6;
}

@keyframes glowSpectrumShift {
  0% {
    filter: blur(var(--glow-blur)) saturate(var(--glow-saturation)) hue-rotate(0deg);
  }
  25% {
    filter: blur(var(--glow-blur)) saturate(var(--glow-saturation)) hue-rotate(90deg);
  }
  50% {
    filter: blur(var(--glow-blur)) saturate(var(--glow-saturation)) hue-rotate(180deg);
  }
  75% {
    filter: blur(var(--glow-blur)) saturate(var(--glow-saturation)) hue-rotate(270deg);
  }
  100% {
    filter: blur(var(--glow-blur)) saturate(var(--glow-saturation)) hue-rotate(360deg);
  }
}

@property --glow-palette-01 { syntax: '<color>'; inherits: false; initial-value: #ff0033; }
@property --glow-palette-02 { syntax: '<color>'; inherits: false; initial-value: #ff3d00; }
@property --glow-palette-03 { syntax: '<color>'; inherits: false; initial-value: #ff9100; }
@property --glow-palette-04 { syntax: '<color>'; inherits: false; initial-value: #ffd600; }
@property --glow-palette-05 { syntax: '<color>'; inherits: false; initial-value: #aeea00; }
@property --glow-palette-06 { syntax: '<color>'; inherits: false; initial-value: #64dd17; }
@property --glow-palette-07 { syntax: '<color>'; inherits: false; initial-value: #00e676; }
@property --glow-palette-08 { syntax: '<color>'; inherits: false; initial-value: #00c853; }
@property --glow-palette-09 { syntax: '<color>'; inherits: false; initial-value: #1de9b6; }
@property --glow-palette-10 { syntax: '<color>'; inherits: false; initial-value: #00e5ff; }
@property --glow-palette-11 { syntax: '<color>'; inherits: false; initial-value: #00b0ff; }
@property --glow-palette-12 { syntax: '<color>'; inherits: false; initial-value: #2979ff; }
@property --glow-palette-13 { syntax: '<color>'; inherits: false; initial-value: #304ffe; }
@property --glow-palette-14 { syntax: '<color>'; inherits: false; initial-value: #651fff; }
@property --glow-palette-15 { syntax: '<color>'; inherits: false; initial-value: #7c4dff; }
@property --glow-palette-16 { syntax: '<color>'; inherits: false; initial-value: #aa00ff; }
@property --glow-palette-17 { syntax: '<color>'; inherits: false; initial-value: #d500f9; }
@property --glow-palette-18 { syntax: '<color>'; inherits: false; initial-value: #ff4081; }

.visual-glow {
  --glow-blur: 78px;
  --glow-saturation: 1.62;
  --glow-palette-01: #ff0033;
  --glow-palette-02: #ff3d00;
  --glow-palette-03: #ff9100;
  --glow-palette-04: #ffd600;
  --glow-palette-05: #aeea00;
  --glow-palette-06: #64dd17;
  --glow-palette-07: #00e676;
  --glow-palette-08: #00c853;
  --glow-palette-09: #1de9b6;
  --glow-palette-10: #00e5ff;
  --glow-palette-11: #00b0ff;
  --glow-palette-12: #2979ff;
  --glow-palette-13: #304ffe;
  --glow-palette-14: #651fff;
  --glow-palette-15: #7c4dff;
  --glow-palette-16: #aa00ff;
  --glow-palette-17: #d500f9;
  --glow-palette-18: #ff4081;
  background: conic-gradient(
    from 20deg,
    var(--glow-palette-01) 0deg,
    var(--glow-palette-02) 20deg,
    var(--glow-palette-03) 40deg,
    var(--glow-palette-04) 60deg,
    var(--glow-palette-05) 80deg,
    var(--glow-palette-06) 100deg,
    var(--glow-palette-07) 120deg,
    var(--glow-palette-08) 140deg,
    var(--glow-palette-09) 160deg,
    var(--glow-palette-10) 180deg,
    var(--glow-palette-11) 200deg,
    var(--glow-palette-12) 220deg,
    var(--glow-palette-13) 240deg,
    var(--glow-palette-14) 260deg,
    var(--glow-palette-15) 280deg,
    var(--glow-palette-16) 300deg,
    var(--glow-palette-17) 320deg,
    var(--glow-palette-18) 340deg,
    var(--glow-palette-01) 360deg
  ) !important;
  filter: blur(var(--glow-blur)) saturate(var(--glow-saturation)) !important;
  animation: rotateGlow 14s linear infinite, glowPaletteOrbit 72s linear infinite !important;
}

.visual-stage:fullscreen .visual-glow {
  --glow-blur: 92px;
  --glow-saturation: 1.68;
}

@keyframes glowPaletteOrbit {
  0% {
    --glow-palette-01: #ff0033;
    --glow-palette-02: #ff3d00;
    --glow-palette-03: #ff9100;
    --glow-palette-04: #ffd600;
    --glow-palette-05: #aeea00;
    --glow-palette-06: #64dd17;
    --glow-palette-07: #00e676;
    --glow-palette-08: #00c853;
    --glow-palette-09: #1de9b6;
    --glow-palette-10: #00e5ff;
    --glow-palette-11: #00b0ff;
    --glow-palette-12: #2979ff;
    --glow-palette-13: #304ffe;
    --glow-palette-14: #651fff;
    --glow-palette-15: #7c4dff;
    --glow-palette-16: #aa00ff;
    --glow-palette-17: #d500f9;
    --glow-palette-18: #ff4081;
  }
  20% {
    --glow-palette-01: #aeea00;
    --glow-palette-02: #64dd17;
    --glow-palette-03: #00e676;
    --glow-palette-04: #00c853;
    --glow-palette-05: #1de9b6;
    --glow-palette-06: #00e5ff;
    --glow-palette-07: #00b0ff;
    --glow-palette-08: #2979ff;
    --glow-palette-09: #304ffe;
    --glow-palette-10: #651fff;
    --glow-palette-11: #7c4dff;
    --glow-palette-12: #aa00ff;
    --glow-palette-13: #d500f9;
    --glow-palette-14: #ff4081;
    --glow-palette-15: #ff0033;
    --glow-palette-16: #ff3d00;
    --glow-palette-17: #ff9100;
    --glow-palette-18: #ffd600;
  }
  40% {
    --glow-palette-01: #1de9b6;
    --glow-palette-02: #00e5ff;
    --glow-palette-03: #00b0ff;
    --glow-palette-04: #2979ff;
    --glow-palette-05: #304ffe;
    --glow-palette-06: #651fff;
    --glow-palette-07: #7c4dff;
    --glow-palette-08: #aa00ff;
    --glow-palette-09: #d500f9;
    --glow-palette-10: #ff4081;
    --glow-palette-11: #ff0033;
    --glow-palette-12: #ff3d00;
    --glow-palette-13: #ff9100;
    --glow-palette-14: #ffd600;
    --glow-palette-15: #aeea00;
    --glow-palette-16: #64dd17;
    --glow-palette-17: #00e676;
    --glow-palette-18: #00c853;
  }
  60% {
    --glow-palette-01: #304ffe;
    --glow-palette-02: #651fff;
    --glow-palette-03: #7c4dff;
    --glow-palette-04: #aa00ff;
    --glow-palette-05: #d500f9;
    --glow-palette-06: #ff4081;
    --glow-palette-07: #ff0033;
    --glow-palette-08: #ff3d00;
    --glow-palette-09: #ff9100;
    --glow-palette-10: #ffd600;
    --glow-palette-11: #aeea00;
    --glow-palette-12: #64dd17;
    --glow-palette-13: #00e676;
    --glow-palette-14: #00c853;
    --glow-palette-15: #1de9b6;
    --glow-palette-16: #00e5ff;
    --glow-palette-17: #00b0ff;
    --glow-palette-18: #2979ff;
  }
  80% {
    --glow-palette-01: #d500f9;
    --glow-palette-02: #ff4081;
    --glow-palette-03: #ff0033;
    --glow-palette-04: #ff3d00;
    --glow-palette-05: #ff9100;
    --glow-palette-06: #ffd600;
    --glow-palette-07: #aeea00;
    --glow-palette-08: #64dd17;
    --glow-palette-09: #00e676;
    --glow-palette-10: #00c853;
    --glow-palette-11: #1de9b6;
    --glow-palette-12: #00e5ff;
    --glow-palette-13: #00b0ff;
    --glow-palette-14: #2979ff;
    --glow-palette-15: #304ffe;
    --glow-palette-16: #651fff;
    --glow-palette-17: #7c4dff;
    --glow-palette-18: #aa00ff;
  }
  100% {
    --glow-palette-01: #ff0033;
    --glow-palette-02: #ff3d00;
    --glow-palette-03: #ff9100;
    --glow-palette-04: #ffd600;
    --glow-palette-05: #aeea00;
    --glow-palette-06: #64dd17;
    --glow-palette-07: #00e676;
    --glow-palette-08: #00c853;
    --glow-palette-09: #1de9b6;
    --glow-palette-10: #00e5ff;
    --glow-palette-11: #00b0ff;
    --glow-palette-12: #2979ff;
    --glow-palette-13: #304ffe;
    --glow-palette-14: #651fff;
    --glow-palette-15: #7c4dff;
    --glow-palette-16: #aa00ff;
    --glow-palette-17: #d500f9;
    --glow-palette-18: #ff4081;
  }
}

@property --stage-glow-a { syntax: '<color>'; inherits: false; initial-value: rgba(0, 212, 255, .34); }
@property --stage-glow-b { syntax: '<color>'; inherits: false; initial-value: rgba(255, 64, 129, .34); }
@property --stage-glow-c { syntax: '<color>'; inherits: false; initial-value: rgba(255, 214, 10, .22); }
@property --stage-glow-d { syntax: '<color>'; inherits: false; initial-value: rgba(0, 230, 118, .26); }
@property --stage-glow-e { syntax: '<color>'; inherits: false; initial-value: rgba(124, 77, 255, .38); }

.visual-stage {
  --stage-glow-a: rgba(0, 212, 255, .34);
  --stage-glow-b: rgba(255, 64, 129, .34);
  --stage-glow-c: rgba(255, 214, 10, .22);
  --stage-glow-d: rgba(0, 230, 118, .26);
  --stage-glow-e: rgba(124, 77, 255, .38);
  background:
    radial-gradient(circle at 14% 82%, var(--stage-glow-a), transparent 34%),
    radial-gradient(circle at 25% 22%, var(--stage-glow-b), transparent 31%),
    radial-gradient(circle at 50% 12%, var(--stage-glow-c), transparent 32%),
    radial-gradient(circle at 74% 24%, var(--stage-glow-d), transparent 36%),
    radial-gradient(circle at 82% 76%, var(--stage-glow-e), transparent 39%),
    radial-gradient(circle at 48% 52%, rgba(255, 255, 255, .08), transparent 32%),
    linear-gradient(135deg, #101522 0%, #090b14 48%, #05070d 100%) !important;
  animation: stagePaletteOnlyShift 54s ease-in-out infinite alternate !important;
}

.visual-stage:fullscreen {
  background:
    radial-gradient(circle at 10% 84%, var(--stage-glow-a), transparent 34%),
    radial-gradient(circle at 26% 18%, var(--stage-glow-b), transparent 33%),
    radial-gradient(circle at 52% 12%, var(--stage-glow-c), transparent 32%),
    radial-gradient(circle at 78% 26%, var(--stage-glow-d), transparent 36%),
    radial-gradient(circle at 86% 76%, var(--stage-glow-e), transparent 40%),
    radial-gradient(circle at 48% 48%, rgba(255, 255, 255, .09), transparent 31%),
    linear-gradient(135deg, #101522 0%, #080b14 46%, #05070d 100%) !important;
}

@keyframes stagePaletteOnlyShift {
  0% {
    --stage-glow-a: rgba(0, 212, 255, .34);
    --stage-glow-b: rgba(255, 64, 129, .34);
    --stage-glow-c: rgba(255, 214, 10, .22);
    --stage-glow-d: rgba(0, 230, 118, .26);
    --stage-glow-e: rgba(124, 77, 255, .38);
  }
  25% {
    --stage-glow-a: rgba(255, 214, 10, .30);
    --stage-glow-b: rgba(0, 229, 255, .33);
    --stage-glow-c: rgba(213, 0, 249, .24);
    --stage-glow-d: rgba(255, 61, 0, .27);
    --stage-glow-e: rgba(29, 233, 182, .37);
  }
  50% {
    --stage-glow-a: rgba(255, 64, 129, .34);
    --stage-glow-b: rgba(48, 79, 254, .34);
    --stage-glow-c: rgba(0, 230, 118, .24);
    --stage-glow-d: rgba(255, 214, 10, .28);
    --stage-glow-e: rgba(0, 176, 255, .38);
  }
  75% {
    --stage-glow-a: rgba(124, 77, 255, .35);
    --stage-glow-b: rgba(0, 230, 118, .32);
    --stage-glow-c: rgba(255, 64, 129, .24);
    --stage-glow-d: rgba(0, 229, 255, .29);
    --stage-glow-e: rgba(255, 109, 0, .36);
  }
  100% {
    --stage-glow-a: rgba(29, 233, 182, .34);
    --stage-glow-b: rgba(255, 214, 10, .31);
    --stage-glow-c: rgba(0, 176, 255, .24);
    --stage-glow-d: rgba(213, 0, 249, .28);
    --stage-glow-e: rgba(255, 64, 129, .38);
  }
}

.queue-panel .section-title.queue-panel-title {
  align-items: center !important;
}

.queue-panel-title-copy {
  display: flex !important;
  align-items: center !important;
  gap: .72rem !important;
  min-width: 0 !important;
  flex-wrap: nowrap !important;
}

.queue-panel-title-copy .eyebrow,
.queue-panel-title-copy h2 {
  margin: 0 !important;
}

.queue-panel-title-copy .eyebrow {
  line-height: 1 !important;
  white-space: nowrap !important;
}

.queue-panel-title-copy h2 {
  font-size: 1.08rem !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
}

@media (max-width: 430px) {
  .queue-panel .section-title.queue-panel-title {
    gap: .5rem !important;
  }

  .queue-panel-title-copy {
    gap: .46rem !important;
  }

  .queue-panel-title-copy .eyebrow {
    font-size: .64rem !important;
    letter-spacing: .08em !important;
  }

  .queue-panel-title-copy h2 {
    font-size: .92rem !important;
  }

  .queue-panel .section-title.queue-panel-title .mini-badge {
    font-size: .72rem !important;
    padding: .42rem .54rem !important;
  }
}

.mix-select-content .mix-field-label {
  display: block !important;
  color: var(--muted-2) !important;
  font-size: .86rem !important;
  font-weight: 700 !important;
  margin: 0 0 .15rem !important;
}

#wizardGenreChips.wizard-genre-chips {
  min-height: 4.4rem !important;
  max-height: 220px !important;
  overflow: auto !important;
  border-radius: 16px !important;
  padding: .9rem !important;
  border-color: color-mix(in oklab, var(--line) 66%, transparent) !important;
  background: color-mix(in oklab, var(--bg-soft) 52%, transparent) !important;
}

#wizardGenreChips .mix-genre-chip {
  cursor: pointer !important;
}

.mix-select-box:first-child > .mix-select-content {
  width: min(560px, calc(100vw - 2.25rem)) !important;
  min-width: min(360px, calc(100vw - 2.25rem)) !important;
  max-width: calc(100vw - 2.25rem) !important;
}

@media (max-width: 760px) {
  .mix-select-box:first-child > .mix-select-content {
    width: min(100%, calc(100vw - 1.5rem)) !important;
    min-width: 0 !important;
    max-width: calc(100vw - 1.5rem) !important;
  }

  #wizardGenreChips.wizard-genre-chips {
    max-height: 260px !important;
  }
}

.station-detail-button:not(:disabled) {
  color: var(--text) !important;
  opacity: 1 !important;
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--panel-strong) 88%, white 6%), color-mix(in oklab, var(--panel-strong) 82%, transparent)) !important;
  border-color: color-mix(in oklab, var(--text) 20%, var(--line)) !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.025) !important;
}

.station-detail-button:not(:disabled):hover,
.station-detail-button:not(:disabled):focus-visible {
  color: #fff !important;
  border-color: color-mix(in oklab, var(--brand) 65%, var(--line)) !important;
  background:
    linear-gradient(135deg, color-mix(in oklab, var(--brand) 22%, var(--panel-strong)), color-mix(in oklab, var(--brand-2) 18%, var(--panel-strong))) !important;
  transform: translateY(-1px) !important;
}

.station-card-actions .station-detail-button:not(:disabled) {
  cursor: pointer !important;
  pointer-events: auto !important;
}

.mix-genre-footer {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: .75rem !important;
  margin-top: .15rem !important;
}
.mix-genre-footer .field-note {
  min-width: 0 !important;
  margin: 0 !important;
}
.genre-reset-button {
  flex: 0 0 auto !important;
  min-height: 32px !important;
  padding: .42rem .72rem !important;
  border: 1px solid color-mix(in oklab, var(--brand) 34%, var(--line)) !important;
  border-radius: 999px !important;
  background: color-mix(in oklab, var(--panel-strong) 78%, transparent) !important;
  color: var(--text) !important;
  font-size: .78rem !important;
  font-weight: 800 !important;
  cursor: pointer !important;
  transition: transform .16s ease, border-color .16s ease, background .16s ease !important;
}
.genre-reset-button:hover,
.genre-reset-button:focus-visible {
  transform: translateY(-1px) !important;
  border-color: color-mix(in oklab, var(--brand) 64%, var(--line)) !important;
  background: color-mix(in oklab, var(--brand) 18%, var(--panel-strong)) !important;
  outline: none !important;
}
.mix-genre-chip.mix-genre-all {
  border-style: solid !important;
}
.mix-genre-chip.mix-genre-all.selected {
  background: linear-gradient(135deg, color-mix(in oklab, var(--brand) 72%, white 4%), color-mix(in oklab, var(--brand-2) 86%, white 0%)) !important;
}
@media (max-width: 560px) {
  .mix-genre-footer {
    align-items: flex-start !important;
    flex-direction: column !important;
  }
  .genre-reset-button {
    width: 100% !important;
  }
}

.mix-select-box > summary:hover,
.mix-select-box > summary:focus-visible {
  background: transparent !important;
  box-shadow: none !important;
}

.mix-select-box[open] > summary:hover,
.mix-select-box[open] > summary:focus-visible {
  background: transparent !important;
  box-shadow: none !important;
}

.mix-advanced-settings[hidden],
.mix-advanced-compact[hidden] {
  display: none !important;
}

.queue-panel {
  gap: .48rem !important;
}

.queue-panel .section-title.queue-panel-title {
  margin-bottom: 0 !important;
}

.queue-actions {
  margin: 0 !important;
  padding: 0 !important;
  gap: .48rem !important;
  min-height: 0 !important;
}

.queue-panel .queue-list:empty {
  display: none !important;
}

.queue-panel .empty-state {
  margin-top: .15rem !important;
  padding: .85rem 1rem !important;
}

.queue-actions .soft-button:disabled,
.queue-actions .soft-button:disabled:hover,
.queue-actions .soft-button:disabled:focus-visible {
  cursor: not-allowed !important;
  transform: none !important;
  opacity: .48 !important;
  color: var(--muted) !important;
  border-color: color-mix(in oklab, var(--line) 72%, transparent) !important;
  background: color-mix(in oklab, var(--panel-strong) 42%, transparent) !important;
  box-shadow: none !important;
  outline: none !important;
}

.queue-panel {
  gap: .22rem !important;
}

.queue-panel .section-title.queue-panel-title {
  margin-bottom: -.12rem !important;
}

.queue-panel .queue-actions {
  margin-top: -.08rem !important;
  margin-bottom: .12rem !important;
  padding: 0 !important;
  gap: .45rem !important;
}

.queue-panel .empty-state {
  margin-top: 0 !important;
}

@media (max-width: 760px) {
  .queue-panel {
    gap: .26rem !important;
  }
  .queue-panel .section-title.queue-panel-title {
    margin-bottom: 0 !important;
  }
}

.queue-panel .section-title.queue-panel-title {
  margin-bottom: -.22rem !important;
}
.queue-panel .queue-actions {
  margin-top: -.26rem !important;
  margin-bottom: .52rem !important;
  padding: 0 !important;
  gap: .45rem !important;
}
.mix-panel .queue-panel .section-title.compact {
  margin-bottom: .18rem !important;
}
.mix-panel .queue-panel .queue-actions {
  margin-top: 0 !important;
  margin-bottom: .52rem !important;
}
.queue-panel .empty-state {
  margin-top: 0 !important;
}
@media (max-width: 760px) {
  .queue-panel .section-title.queue-panel-title { margin-bottom: -.1rem !important; }
  .queue-panel .queue-actions,
  .mix-panel .queue-panel .queue-actions { margin-bottom: .42rem !important; }
}

.queue-item.mix-planned {
  border-color: color-mix(in oklab, var(--line) 92%, transparent) !important;
  background: color-mix(in oklab, var(--panel-solid) 64%, transparent) !important;
}

.queue-item.is-current {
  border-color: color-mix(in oklab, var(--good) 72%, var(--line)) !important;
  background:
    linear-gradient(90deg, color-mix(in oklab, var(--good) 14%, transparent), transparent 46%),
    color-mix(in oklab, var(--panel-strong) 72%, transparent) !important;
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--good) 28%, transparent) !important;
}

.queue-live-badge {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 30px !important;
  padding: .34rem .62rem !important;
  border: 1px solid color-mix(in oklab, var(--good) 62%, var(--line)) !important;
  border-radius: 999px !important;
  color: color-mix(in oklab, var(--good) 78%, white 18%) !important;
  background: color-mix(in oklab, var(--good) 16%, transparent) !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
}

.queue-item .soft-button.tiny[data-queue-action="play"] {
  white-space: nowrap !important;
  min-width: max-content !important;
}

.station-card.active,
.station-card[aria-current="true"] {
  border-color: color-mix(in oklab, var(--good) 72%, var(--line)) !important;
  background:
    linear-gradient(90deg, color-mix(in oklab, var(--good) 12%, transparent), transparent 46%),
    color-mix(in oklab, var(--panel-strong) 58%, transparent) !important;
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--good) 26%, transparent) !important;
}
.station-card.active::before,
.station-card[aria-current="true"]::before {
  background: color-mix(in oklab, var(--good) 82%, white 8%) !important;
}
.station-card.active:hover,
.station-card[aria-current="true"]:hover {
  border-color: color-mix(in oklab, var(--good) 84%, var(--line)) !important;
}
.station-card.active .station-card-badges .badge.ok:first-child,
.station-card[aria-current="true"] .station-card-badges .badge.ok:first-child {
  border-color: color-mix(in oklab, var(--good) 64%, var(--line)) !important;
  background: color-mix(in oklab, var(--good) 16%, transparent) !important;
  color: color-mix(in oklab, var(--good) 76%, white 20%) !important;
}

.custom-number-control {
  position: relative !important;
  display: block !important;
  width: 100% !important;
}
.custom-number-control input[type=number] {
  width: 100% !important;
  padding-right: 3.1rem !important;
  -moz-appearance: textfield;
}
.custom-number-control input[type=number]::-webkit-outer-spin-button,
.custom-number-control input[type=number]::-webkit-inner-spin-button {
  -webkit-appearance: none !important;
  margin: 0 !important;
}
.custom-number-buttons {
  position: absolute !important;
  right: .42rem !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  display: grid !important;
  grid-template-rows: 1fr 1fr !important;
  gap: 2px !important;
  z-index: 4 !important;
}
.custom-number-step {
  width: 1.55rem !important;
  height: 1.12rem !important;
  min-width: 1.55rem !important;
  min-height: 1.12rem !important;
  padding: 0 !important;
  border: 1px solid color-mix(in oklab, var(--line) 76%, transparent) !important;
  border-radius: .42rem !important;
  background: color-mix(in oklab, var(--panel-strong) 78%, transparent) !important;
  color: var(--muted) !important;
  font: inherit !important;
  font-size: .58rem !important;
  line-height: 1 !important;
  cursor: pointer !important;
}
.custom-number-step:hover,
.custom-number-step:focus-visible {
  border-color: color-mix(in oklab, var(--brand) 58%, var(--line)) !important;
  color: var(--text) !important;
  background: color-mix(in oklab, var(--brand) 16%, var(--panel-strong)) !important;
  outline: none !important;
}
.queue-plan-badge {
  white-space: nowrap !important;
  border-color: color-mix(in oklab, var(--line) 82%, transparent) !important;
  background: color-mix(in oklab, var(--panel-strong) 42%, transparent) !important;
  color: var(--muted) !important;
}

.queue-item.is-played {
  opacity: .82 !important;
}
.queue-item.is-played .queue-item-text strong {
  color: color-mix(in oklab, var(--text) 86%, var(--muted)) !important;
}
.queue-played-badge {
  border-color: color-mix(in oklab, var(--muted) 44%, var(--line)) !important;
  color: color-mix(in oklab, var(--muted) 86%, white 8%) !important;
  background: color-mix(in oklab, var(--panel-strong) 62%, transparent) !important;
}

.queue-item.mix-played {
  border-color: color-mix(in oklab, var(--line) 92%, transparent) !important;
  background: color-mix(in oklab, var(--panel-solid) 58%, transparent) !important;
}

.hero-player {
  position: relative !important;
}

.visual-stage > .stage-control-row {
  position: absolute !important;
  left: clamp(.65rem, 1.4vw, 1.15rem) !important;
  right: clamp(.65rem, 1.4vw, 1.15rem) !important;
  bottom: clamp(.65rem, 1.4vw, 1.15rem) !important;
  z-index: 24 !important;
  max-width: calc(100% - 1.3rem) !important;
  box-sizing: border-box !important;
  display: grid !important;
  grid-template-columns: minmax(340px, 1.55fr) minmax(230px, .72fr) minmax(250px, .86fr) auto !important;
  align-items: center !important;
  gap: .55rem !important;
  padding: .58rem .72rem !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  border-radius: 22px !important;
  background: rgba(8,10,16,.76) !important;
  backdrop-filter: blur(18px) !important;
  box-shadow: 0 18px 60px rgba(0,0,0,.38) !important;
  opacity: 1 !important;
  transform: translateY(0) !important;
  transition: opacity .22s ease, transform .22s ease !important;
}

.hero-player:not(:hover):not(:focus-within) .visual-stage > .stage-control-row {
  opacity: 0 !important;
  transform: translateY(12px) !important;
  pointer-events: none !important;
}

.visual-stage:fullscreen > .stage-control-row {
  display: none !important;
}

.visual-stage > .stage-control-row .stage-transport,
.visual-stage > .stage-control-row .stage-volume,
.visual-stage > .stage-control-row .stage-quality {
  min-width: 0 !important;
}

.visual-stage > .stage-control-row .stage-transport {
  display: flex !important;
  align-items: center !important;
  gap: .42rem !important;
  flex-wrap: wrap !important;
}

.visual-stage > .stage-control-row .stage-transport .primary-button,
.visual-stage > .stage-control-row .stage-transport .soft-button,
.visual-stage > .stage-control-row .fullscreen-stage-button,
.visual-stage > .stage-control-row #muteButton {
  min-height: 34px !important;
  padding: .44rem .62rem !important;
  font-size: .78rem !important;
  white-space: nowrap !important;
}

.visual-stage > .stage-control-row .player-shortcuts-button {
  width: 38px !important;
  min-width: 38px !important;
  padding-inline: 0 !important;
  justify-content: center !important;
}

.visual-stage > .stage-control-row .stage-volume {
  display: grid !important;
  grid-template-columns: auto minmax(70px, 1fr) auto !important;
  align-items: center !important;
  gap: .48rem !important;
  color: rgba(255,255,255,.82) !important;
  max-width: none !important;
}

.visual-stage > .stage-control-row .stage-volume label,
.visual-stage > .stage-control-row .stage-quality label {
  color: rgba(255,255,255,.82) !important;
  font-size: .78rem !important;
  white-space: nowrap !important;
}

.visual-stage > .stage-control-row .stage-volume input[type="range"] {
  width: 100% !important;
  min-width: 70px !important;
  max-width: none !important;
}

.visual-stage > .stage-control-row .stage-quality {
  display: grid !important;
  grid-template-columns: auto minmax(130px, 1fr) !important;
  align-items: center !important;
  gap: .48rem !important;
}

.visual-stage > .stage-control-row .stage-quality select {
  min-height: 34px !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  padding: .44rem .7rem !important;
  border-radius: 999px !important;
  color: #fff !important;
  background: rgba(255,255,255,.08) !important;
  border-color: rgba(255,255,255,.16) !important;
}

.visual-stage .status-pill {
  z-index: 26 !important;
  max-width: min(62%, 620px) !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  transition: bottom .22s ease, opacity .22s ease, transform .22s ease !important;
}

.hero-player:hover .visual-stage:not(:fullscreen) .status-pill,
.hero-player:focus-within .visual-stage:not(:fullscreen) .status-pill {
  bottom: 5.2rem !important;
}

.sleep-modal {
  display: grid !important;
  gap: .9rem !important;
  max-width: 560px !important;
}
.sleep-modal h2,
.sleep-modal p {
  margin: 0 !important;
}
.sleep-current {
  padding: .75rem .85rem !important;
  border: 1px solid color-mix(in oklab, var(--brand) 32%, var(--line)) !important;
  border-radius: 16px !important;
  background: color-mix(in oklab, var(--panel-strong) 58%, transparent) !important;
  color: var(--muted) !important;
}
.sleep-presets {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: .55rem !important;
}
.sleep-custom {
  display: grid !important;
  gap: .42rem !important;
  color: var(--muted) !important;
  font-weight: 700 !important;
}
.sleep-custom input {
  min-height: 44px !important;
  border-radius: 16px !important;
}
.sleep-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: .55rem !important;
}

@media (max-width: 1380px) {
  .visual-stage > .stage-control-row {
    grid-template-columns: minmax(280px, 1fr) minmax(200px, .65fr) minmax(220px, .75fr) auto !important;
  }
}

@media (max-width: 1180px) {
  .visual-stage > .stage-control-row {
    grid-template-columns: 1fr 1fr !important;
  }
  .visual-stage > .stage-control-row .stage-transport {
    grid-column: 1 / -1 !important;
  }
  .visual-stage > .stage-control-row .fullscreen-stage-button {
    width: 100% !important;
  }
}

@media (max-width: 760px) {
  .visual-stage > .stage-control-row {
    left: .55rem !important;
    right: .55rem !important;
    bottom: .55rem !important;
    grid-template-columns: 1fr !important;
    padding: .56rem !important;
  }
  .visual-stage > .stage-control-row .stage-volume,
  .visual-stage > .stage-control-row .stage-quality {
    grid-template-columns: 1fr !important;
  }
  .visual-stage .status-pill {
    max-width: calc(100% - 1.1rem) !important;
    font-size: .78rem !important;
  }
  .hero-player:hover .visual-stage:not(:fullscreen) .status-pill,
  .hero-player:focus-within .visual-stage:not(:fullscreen) .status-pill {
    bottom: 10.8rem !important;
  }
  .sleep-presets {
    grid-template-columns: 1fr !important;
  }
  .sleep-actions .primary-button,
  .sleep-actions .soft-button {
    width: 100% !important;
  }
}

.visual-stage:not(:fullscreen) .stage-overlay-title {
  left: clamp(.65rem, 1.4vw, 1.15rem) !important;
  top: .9rem !important;
}
.visual-stage:not(:fullscreen) .status-pill {
  left: clamp(.65rem, 1.4vw, 1.15rem) !important;
  right: auto !important;
}
.hero-player:hover .visual-stage:not(:fullscreen) .status-pill,
.hero-player:focus-within .visual-stage:not(:fullscreen) .status-pill {
  bottom: 5.5rem !important;
}
.visual-stage:fullscreen .stage-overlay-title {
  left: clamp(1.25rem, 3vw, 2.25rem) !important;
  top: 1.2rem !important;
}
.visual-stage:fullscreen .status-pill {
  left: clamp(1.25rem, 3vw, 2.25rem) !important;
  right: auto !important;
  bottom: 7.15rem !important;
}
.visual-stage:fullscreen.controls-hidden .status-pill {
  left: clamp(1.25rem, 3vw, 2.25rem) !important;
  bottom: 2rem !important;
}
@media (max-width: 900px) {
  .visual-stage:not(:fullscreen) .stage-overlay-title { left: .8rem !important; top: .82rem !important; }
  .visual-stage:not(:fullscreen) .status-pill { left: .8rem !important; }
  .hero-player:hover .visual-stage:not(:fullscreen) .status-pill,
  .hero-player:focus-within .visual-stage:not(:fullscreen) .status-pill { bottom: 11.05rem !important; }
  .visual-stage:fullscreen .stage-overlay-title { left: 1rem !important; top: 1rem !important; }
  .visual-stage:fullscreen .status-pill { left: 1rem !important; bottom: 9.8rem !important; }
  .visual-stage:fullscreen.controls-hidden .status-pill { left: 1rem !important; bottom: 1.45rem !important; }
}

.mix-wizard-head > div > p:not(.eyebrow),
.mix-compact-note {
  display: none !important;
}

.queue-panel-title-copy h2 {
  word-spacing: .05em !important;
}

.queue-item.is-next {
  border-color: color-mix(in oklab, var(--warn) 72%, var(--line)) !important;
  background:
    linear-gradient(90deg, color-mix(in oklab, var(--warn) 12%, transparent), transparent 44%),
    color-mix(in oklab, var(--panel-solid) 68%, transparent) !important;
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--warn) 22%, transparent) !important;
}

.queue-next-badge {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 30px !important;
  padding: .34rem .62rem !important;
  border: 1px solid color-mix(in oklab, var(--warn) 72%, var(--line)) !important;
  border-radius: 999px !important;
  color: color-mix(in oklab, var(--warn) 86%, white 10%) !important;
  background: color-mix(in oklab, var(--warn) 16%, transparent) !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
  white-space: nowrap !important;
}

.queue-item.is-current.is-next {
  border-color: color-mix(in oklab, var(--good) 72%, var(--line)) !important;
}

.visual-stage:fullscreen .fullscreen-bottom-overlay {
  padding: 0 clamp(1.25rem, 2.6vw, 1.9rem) clamp(1.15rem, 2.4vw, 1.6rem) !important;
  align-items: flex-end !important;
}
.visual-stage:fullscreen .fullscreen-controls {
  align-items: center !important;
  gap: .9rem !important;
  padding: .86rem 1rem !important;
}
.visual-stage:fullscreen .fullscreen-station-bar {
  align-self: center !important;
  gap: .5rem !important;
  padding-right: .35rem !important;
}
.visual-stage:fullscreen .fullscreen-meta-pills {
  row-gap: .42rem !important;
}
.visual-stage:fullscreen .status-pill {
  bottom: 10.2rem !important;
}
.visual-stage:fullscreen.controls-hidden .status-pill {
  bottom: 2rem !important;
}
@media (max-width: 1480px) {
  .visual-stage:fullscreen .status-pill { bottom: 10.9rem !important; }
}
@media (max-width: 1200px) {
  .visual-stage:fullscreen .fullscreen-controls { align-items: start !important; }
  .visual-stage:fullscreen .fullscreen-station-bar { align-self: start !important; }
  .visual-stage:fullscreen .status-pill { bottom: 12.4rem !important; }
}
@media (max-width: 900px) {
  .visual-stage:fullscreen .fullscreen-bottom-overlay { padding-inline: 1rem !important; padding-bottom: 1rem !important; }
  .visual-stage:fullscreen .status-pill { bottom: 13.2rem !important; }
  .visual-stage:fullscreen.controls-hidden .status-pill { bottom: 1.5rem !important; }
}

.visual-stage:fullscreen .fullscreen-station-bar {
  display: none !important;
}

.visual-stage:fullscreen .fullscreen-bottom-overlay {
  padding: 0 clamp(.65rem, 1.4vw, 1.15rem) clamp(.65rem, 1.4vw, 1.15rem) !important;
  align-items: flex-end !important;
}

.visual-stage:fullscreen .fullscreen-controls {
  grid-template-columns: minmax(330px, auto) minmax(260px, 1fr) minmax(360px, auto) !important;
  align-items: center !important;
  gap: .7rem !important;
  padding: .58rem .72rem !important;
  border-radius: 22px !important;
}

.visual-stage:fullscreen .status-pill {
  left: clamp(.65rem, 1.4vw, 1.15rem) !important;
  right: auto !important;
  bottom: 5.5rem !important;
  max-width: min(62%, 620px) !important;
}

.visual-stage:fullscreen.controls-hidden .status-pill {
  left: clamp(.65rem, 1.4vw, 1.15rem) !important;
  right: auto !important;
  bottom: 1.35rem !important;
}

.visual-stage:fullscreen .stage-overlay-title {
  left: clamp(.65rem, 1.4vw, 1.15rem) !important;
}

@media (max-width: 1200px) {
  .visual-stage:fullscreen .fullscreen-controls {
    grid-template-columns: 1fr 1fr !important;
    align-items: start !important;
  }
  .visual-stage:fullscreen .fullscreen-right-controls {
    justify-content: flex-start !important;
  }
  .visual-stage:fullscreen .status-pill {
    bottom: 8.4rem !important;
  }
}

@media (max-width: 900px) {
  .visual-stage:fullscreen .fullscreen-bottom-overlay {
    padding-inline: .8rem !important;
    padding-bottom: .8rem !important;
  }
  .visual-stage:fullscreen .fullscreen-controls {
    grid-template-columns: 1fr !important;
  }
  .visual-stage:fullscreen .status-pill {
    left: .8rem !important;
    bottom: 11.05rem !important;
    max-width: calc(100% - 1.6rem) !important;
  }
  .visual-stage:fullscreen.controls-hidden .status-pill {
    left: .8rem !important;
    bottom: 1.45rem !important;
  }
  .visual-stage:fullscreen .stage-overlay-title {
    left: .8rem !important;
  }
}

.visual-stage:fullscreen .fullscreen-meta-pills {
  display: none !important;
}

.visual-stage:fullscreen .fullscreen-station-bar {
  gap: 0 !important;
}

.visual-stage > .stage-control-row {
  grid-template-columns: minmax(340px, 1.55fr) minmax(250px, .9fr) minmax(230px, .72fr) auto !important;
}
.visual-stage > .stage-control-row .stage-quality {
  justify-self: center !important;
  width: 100% !important;
  max-width: 360px !important;
}
.visual-stage > .stage-control-row .stage-volume {
  justify-self: end !important;
  width: 100% !important;
  max-width: 320px !important;
}
.visual-stage:fullscreen .fullscreen-transport .fullscreen-shortcuts-button {
  width: 36px !important;
  min-width: 36px !important;
  padding-inline: 0 !important;
  justify-content: center !important;
  font-size: .95rem !important;
}
.visual-stage:fullscreen .fullscreen-transport #fullscreenSleepButton {
  white-space: nowrap !important;
}
@media (max-width: 1380px) {
  .visual-stage > .stage-control-row {
    grid-template-columns: minmax(280px, 1fr) minmax(230px, .8fr) minmax(210px, .7fr) auto !important;
  }
}
@media (max-width: 1180px) {
  .visual-stage > .stage-control-row {
    grid-template-columns: 1fr 1fr !important;
  }
  .visual-stage > .stage-control-row .stage-transport { grid-column: 1 / -1 !important; }
  .visual-stage > .stage-control-row .stage-quality { justify-self: stretch !important; max-width: none !important; }
  .visual-stage > .stage-control-row .stage-volume { justify-self: stretch !important; max-width: none !important; }
}
@media (max-width: 760px) {
  .visual-stage > .stage-control-row .stage-quality,
  .visual-stage > .stage-control-row .stage-volume { max-width: none !important; }
}

.queue-item-actions {
  flex-wrap: wrap;
  justify-content: flex-end;
}
.queue-favorite-button {
  width: 32px !important;
  min-width: 32px !important;
  height: 32px !important;
  padding: 0 !important;
  font-size: 1rem !important;
  line-height: 1 !important;
  border-radius: 999px !important;
}
.queue-favorite-button.active {
  color: #ffd166 !important;
}
select:not([multiple]) {
  -webkit-appearance: none !important;
  appearance: none !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M5.5 7.5 10 12l4.5-4.5' stroke='%23b7bfd4' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-size: 14px 14px !important;
  background-position: right .82rem center !important;
  padding-right: 2.55rem !important;
}
.mix-select-content select,
.pro-select-content select,
.stage-quality select,
.fullscreen-quality select,
.filter-grid select,
.player-filters select {
  border-radius: 14px !important;
}
.stage-quality select,
#qualityVariantSelect,
#fullscreenQualityVariantSelect,
.mix-select-content select,
.pro-select-content select,
.filter-grid select {
  background-position: right .82rem center !important;
  padding-right: 2.55rem !important;
}
.mix-select-box summary::after,
.pro-select-box summary::after {
  margin-right: .06rem !important;
}
@media (max-width: 920px) {
  .queue-item-actions {
    gap: .45rem !important;
  }
}

.mix-wizard-head > div {
  display: flex !important;
  align-items: flex-start !important;
  gap: .62rem !important;
  min-width: 0 !important;
  flex-wrap: nowrap !important;
}
.mix-wizard-head > div .eyebrow {
  margin: .12rem 0 0 !important;
  white-space: nowrap !important;
  flex: 0 0 auto !important;
}
.mix-wizard-head > div h3 {
  margin: .26rem 0 0 !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
  min-width: 0 !important;
}
@media (max-width: 760px) {
  .mix-wizard-head > div { gap: .5rem !important; }
  .mix-wizard-head > div .eyebrow { margin-top: .1rem !important; }
  .mix-wizard-head > div h3 { margin-top: .22rem !important; }
}

.mix-wizard-head > div h3 {
  font-size: 1.08rem !important;
  font-weight: 800 !important;
}
.queue-panel .section-title.queue-panel-title {
  align-items: flex-start !important;
}
.queue-panel-title-copy {
  display: flex !important;
  align-items: flex-start !important;
  gap: .62rem !important;
  min-width: 0 !important;
  flex-wrap: nowrap !important;
}
.queue-panel-title-copy .eyebrow {
  margin: .12rem 0 0 !important;
  white-space: nowrap !important;
  flex: 0 0 auto !important;
  color: var(--brand) !important;
}
.queue-panel-title-copy h2 {
  margin: .26rem 0 0 !important;
  font-size: 1.08rem !important;
  line-height: 1.1 !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
  color: var(--text) !important;
}
@media (max-width: 760px) {
  .mix-wizard-head > div h3, .queue-panel-title-copy h2 { font-size: 1rem !important; }
  .queue-panel-title-copy { gap: .5rem !important; }
  .queue-panel-title-copy .eyebrow { margin-top: .1rem !important; }
  .queue-panel-title-copy h2 { margin-top: .22rem !important; }
}

.sleep-custom .custom-number-control {
  width: 100% !important;
}
.sleep-custom .custom-number-control input[type=number] {
  min-height: 44px !important;
  border-radius: 16px !important;
}
.sleep-custom .custom-number-buttons {
  right: .48rem !important;
}

.mix-wizard-compact .mix-wizard-head,
.queue-panel .section-title.queue-panel-title {
  align-items: center !important;
}
.mix-wizard-head > div,
.queue-panel-title-copy {
  display: flex !important;
  align-items: center !important;
  gap: .72rem !important;
  min-width: 0 !important;
  flex-wrap: nowrap !important;
}
.mix-wizard-head > div .eyebrow,
.mix-wizard-head > div h3,
.queue-panel-title-copy .eyebrow,
.queue-panel-title-copy h2 {
  margin: 0 !important;
  white-space: nowrap !important;
}
.mix-wizard-head > div .eyebrow,
.queue-panel-title-copy .eyebrow {
  line-height: 1 !important;
  color: var(--brand) !important;
  flex: 0 0 auto !important;
}
.mix-wizard-head > div h3,
.queue-panel-title-copy h2 {
  font-size: 1.08rem !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
  color: var(--text) !important;
  min-width: 0 !important;
}
@media (max-width: 760px) {
  .mix-wizard-head > div,
  .queue-panel-title-copy { gap: .58rem !important; }
  .mix-wizard-head > div h3,
  .queue-panel-title-copy h2 { font-size: 1rem !important; }
}

.mix-wizard-head > div .eyebrow,
.queue-panel-title-copy .eyebrow {
  color: var(--muted) !important;
}

.search-shell {
  grid-template-columns: minmax(0, 1fr) auto minmax(170px, auto) !important;
  max-width: min(920px, 100%) !important;
}
.station-quick-select {
  min-height: 48px;
  max-width: 280px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .48rem;
  padding: .55rem .85rem;
  border: 1px solid color-mix(in oklab, var(--brand) 26%, var(--line));
  border-radius: 999px;
  color: var(--text);
  background: linear-gradient(180deg, color-mix(in oklab, var(--panel) 86%, white 4%), color-mix(in oklab, var(--panel-strong) 90%, transparent));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.025);
  font-weight: 800;
  font-size: .9rem;
  white-space: nowrap;
  overflow: hidden;
  cursor: pointer;
}
.station-quick-select:hover,
.station-quick-select:focus-visible {
  border-color: color-mix(in oklab, var(--brand) 55%, var(--line));
  background: linear-gradient(180deg, color-mix(in oklab, var(--brand) 12%, var(--panel)), color-mix(in oklab, var(--panel-strong) 92%, transparent));
  transform: translateY(-1px);
}
.station-quick-select-icon {
  width: 22px;
  height: 22px;
  min-width: 22px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  color: #fff;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  box-shadow: 0 8px 18px color-mix(in oklab, var(--brand) 28%, transparent);
  font-size: .82rem;
  line-height: 1;
}
.station-quick-select-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}
.station-headline,
.meta-grid,
.tag-row {
  display: none !important;
}
.action-row {
  padding-top: 1.05rem !important;
}
.station-chooser-modal {
  display: grid;
  gap: .9rem;
  max-width: 760px;
}
.station-chooser-modal h2,
.station-chooser-modal p {
  margin: 0;
}
.station-chooser-search-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .65rem;
  align-items: center;
}
.station-chooser-search-row input {
  min-height: 46px;
  border-radius: 16px;
}
.station-chooser-list {
  display: grid;
  gap: .55rem;
  max-height: min(52vh, 460px);
  overflow: auto;
  padding-right: .2rem;
}
.station-chooser-item {
  width: 100%;
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr) auto;
  align-items: center;
  gap: .75rem;
  padding: .68rem;
  border: 1px solid var(--line);
  border-radius: 18px;
  color: var(--text);
  background: color-mix(in oklab, var(--panel-strong) 42%, transparent);
  text-align: left;
}
.station-chooser-item:hover,
.station-chooser-item:focus-visible {
  border-color: color-mix(in oklab, var(--brand) 52%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in oklab, var(--brand) 12%, transparent), transparent 44%),
    color-mix(in oklab, var(--panel-strong) 54%, transparent);
  transform: translateY(-1px);
}
.station-chooser-item img {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  object-fit: cover;
  background: rgba(255,255,255,.06);
}
.station-chooser-item-copy {
  min-width: 0;
  display: grid;
  gap: .18rem;
}
.station-chooser-item-copy strong,
.station-chooser-item-copy small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.station-chooser-item-copy small {
  color: var(--muted);
  font-size: .82rem;
}
.station-chooser-play {
  display: inline-flex;
  min-height: 30px;
  align-items: center;
  padding: .34rem .55rem;
  border: 1px solid color-mix(in oklab, var(--brand) 42%, var(--line));
  border-radius: 999px;
  color: var(--text);
  background: color-mix(in oklab, var(--brand) 14%, transparent);
  font-size: .78rem;
  font-weight: 800;
}
.station-chooser-empty {
  padding: .9rem 1rem;
  border: 1px dashed var(--line);
  border-radius: 16px;
  color: var(--muted);
  background: color-mix(in oklab, var(--panel-strong) 28%, transparent);
}
@media (max-width: 1180px) {
  .search-shell {
    grid-template-columns: minmax(0, 1fr) auto !important;
  }
  .station-quick-select {
    grid-column: 1 / -1;
    max-width: none;
    min-height: 42px;
  }
}
@media (max-width: 620px) {
  .station-chooser-search-row {
    grid-template-columns: 1fr;
  }
  .station-chooser-item {
    grid-template-columns: 42px minmax(0, 1fr);
  }
  .station-chooser-play {
    grid-column: 1 / -1;
    justify-self: end;
  }
}

.station-chooser-modal {
  gap: .95rem !important;
}
.station-chooser-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 1rem !important;
}
.station-chooser-title-copy {
  display: flex !important;
  align-items: center !important;
  gap: .72rem !important;
  min-width: 0 !important;
  flex-wrap: nowrap !important;
}
.station-chooser-title-copy .eyebrow,
.station-chooser-title-copy h2 {
  margin: 0 !important;
  white-space: nowrap !important;
}
.station-chooser-title-copy .eyebrow {
  line-height: 1 !important;
  color: var(--brand) !important;
}
.station-chooser-title-copy h2 {
  font-size: 1.08rem !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
  color: var(--text) !important;
}
.station-chooser-filter-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) auto !important;
  gap: .65rem !important;
  align-items: end !important;
  padding: .75rem !important;
  border: 1px solid color-mix(in oklab, var(--brand) 28%, var(--line)) !important;
  border-radius: 18px !important;
  background:
    radial-gradient(circle at 0 0, color-mix(in oklab, var(--brand) 10%, transparent), transparent 32%),
    color-mix(in oklab, var(--panel-strong) 62%, transparent) !important;
}
.station-chooser-filter-grid label {
  display: grid !important;
  gap: .35rem !important;
  min-width: 0 !important;
  color: var(--muted-2) !important;
  font-size: .82rem !important;
  font-weight: 700 !important;
}
.station-chooser-filter-grid input,
.station-chooser-filter-grid select {
  min-height: 42px !important;
  border-radius: 14px !important;
  padding-block: .6rem !important;
}
.station-chooser-filter-grid .soft-button {
  min-height: 42px !important;
  white-space: nowrap !important;
}
@media (max-width: 900px) {
  .station-chooser-filter-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .station-chooser-filter-grid .soft-button {
    grid-column: 1 / -1 !important;
  }
}
@media (max-width: 620px) {
  .station-chooser-head,
  .station-chooser-title-copy {
    align-items: flex-start !important;
  }
  .station-chooser-title-copy {
    display: grid !important;
    gap: .35rem !important;
  }
  .station-chooser-filter-grid {
    grid-template-columns: 1fr !important;
  }
}

.search-shell {
  grid-template-columns: minmax(0, 1fr) auto auto !important;
  max-width: min(920px, 100%) !important;
}
.station-quick-select {
  width: 48px !important;
  min-width: 48px !important;
  max-width: 48px !important;
  height: 48px !important;
  min-height: 48px !important;
  padding: 0 !important;
  gap: 0 !important;
  border-color: color-mix(in oklab, var(--brand) 30%, var(--line)) !important;
}
.station-quick-select-label {
  display: none !important;
}
.station-quick-select-icon {
  width: 26px !important;
  height: 26px !important;
  min-width: 26px !important;
  font-size: .9rem !important;
}
.station-quick-select.has-station .station-quick-select-icon {
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--good) 20%, transparent), 0 8px 18px color-mix(in oklab, var(--brand) 28%, transparent) !important;
}
.station-chooser-modal select:not([multiple]) {
  background-position: right .82rem center !important;
  padding-right: 2.55rem !important;
}
@media (max-width: 1180px) {
  .station-quick-select {
    grid-column: auto !important;
    max-width: 48px !important;
  }
}

.station-chooser-head {
  padding-right: 3.2rem !important;
}
.station-chooser-title-copy {
  max-width: 100% !important;
}
.station-chooser-search-row {
  grid-template-columns: 1fr !important;
}
.station-chooser-filter-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr)) auto !important;
  align-items: end !important;
}
.station-chooser-filter-grid label {
  align-self: stretch !important;
}
.station-chooser-filter-grid select,
.station-chooser-filter-grid input {
  width: 100% !important;
  min-width: 0 !important;
  color: var(--text) !important;
}
.station-chooser-filter-grid .soft-button {
  align-self: end !important;
}
@media (max-width: 1180px) {
  .station-chooser-filter-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
  .station-chooser-filter-grid .soft-button {
    grid-column: auto !important;
  }
}
@media (max-width: 760px) {
  .station-chooser-filter-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .station-chooser-filter-grid .soft-button {
    grid-column: 1 / -1 !important;
  }
}
@media (max-width: 520px) {
  .station-chooser-filter-grid {
    grid-template-columns: 1fr !important;
  }
}
.station-chooser-modal {
  gap: .85rem !important;
}

.modal[data-modal-type="station-chooser"] {
  max-width: min(760px, calc(100vw - 2rem)) !important;
}
.modal[data-modal-type="station-chooser"] .modal-close {
  top: 1rem !important;
  right: 1rem !important;
  z-index: 8 !important;
}
.station-chooser-head {
  padding-right: 3.7rem !important;
  margin-bottom: .35rem !important;
}
.station-chooser-search-row {
  margin-top: .35rem !important;
}
.station-chooser-search-row input {
  min-height: 50px !important;
}
.station-chooser-filter-grid {
  margin-top: .2rem !important;
}
.station-chooser-list {
  margin-top: .1rem !important;
}

.modal[data-modal-type="station-chooser"] .modal-close {
  top: .9rem !important;
  right: .95rem !important;
}
.station-chooser-head {
  margin-bottom: 1.05rem !important;
  padding-right: 3.9rem !important;
}
.station-chooser-search-row {
  margin-top: .95rem !important;
}
.station-chooser-filter-grid select:disabled,
.station-chooser-filter-grid input:disabled {
  opacity: .48 !important;
  cursor: not-allowed !important;
  color: var(--muted) !important;
  border-color: color-mix(in oklab, var(--line) 66%, transparent) !important;
  background-color: color-mix(in oklab, var(--panel-strong) 42%, transparent) !important;
}
.station-chooser-empty {
  line-height: 1.45 !important;
}

.station-chooser-head {
  margin-bottom: .78rem !important;
}
.station-chooser-search-row {
  margin-top: .62rem !important;
}
.station-chooser-list {
  padding-bottom: .3rem !important;
}
.station-chooser-more-row {
  display: flex !important;
  justify-content: center !important;
  padding: .65rem .25rem .15rem !important;
}
.station-chooser-more-button {
  min-width: 220px !important;
  justify-content: center !important;
}
.station-chooser-filter-grid select:disabled {
  opacity: .42 !important;
}

.queue-panel .section-title.queue-panel-title {
  padding-left: .34rem !important;
}
@media (max-width: 760px) {
  .queue-panel .section-title.queue-panel-title {
    padding-left: .28rem !important;
  }
}

.visual-stage,
.visual-stage > .stage-control-row,
.stage-quality,
.fullscreen-quality {
  overflow: visible !important;
}
.variant-select-shell {
  position: relative !important;
  min-width: 0 !important;
  width: 100% !important;
}
.variant-native-select {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
  inset: auto !important;
}
.variant-select-button {
  width: 100% !important;
  min-height: 38px !important;
  display: block !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  border-radius: 999px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025)),
    rgba(20,25,38,.96) !important;
  color: var(--text) !important;
  padding: .58rem 2.2rem .58rem .82rem !important;
  font: inherit !important;
  font-size: .82rem !important;
  font-weight: 800 !important;
  line-height: 1.15 !important;
  text-align: left !important;
  cursor: pointer !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.02) !important;
}
.variant-select-button::after {
  content: "▾";
  position: absolute;
  right: .82rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--muted);
  font-size: .75rem;
  pointer-events: none;
}
.variant-select-shell.open .variant-select-button::after {
  transform: translateY(-50%) rotate(180deg);
}
.variant-select-button.is-disabled,
.variant-select-button:disabled {
  opacity: .58 !important;
  cursor: not-allowed !important;
}
.variant-select-menu {
  position: absolute !important;
  left: 0 !important;
  right: auto !important;
  top: calc(100% + .42rem) !important;
  z-index: 80 !important;
  width: min(100%, 420px) !important;
  min-width: min(320px, calc(100vw - 2rem)) !important;
  max-width: min(420px, calc(100vw - 2rem)) !important;
  max-height: min(260px, 42vh) !important;
  overflow: auto !important;
  padding: .38rem !important;
  border: 1px solid color-mix(in oklab, var(--brand) 48%, var(--line)) !important;
  border-radius: 18px !important;
  background:
    radial-gradient(circle at top left, color-mix(in oklab, var(--brand) 12%, transparent), transparent 38%),
    color-mix(in oklab, var(--panel-solid) 94%, black 6%) !important;
  box-shadow: 0 22px 70px rgba(0,0,0,.48) !important;
  backdrop-filter: blur(18px) !important;
}
.variant-option {
  width: 100% !important;
  min-height: 34px !important;
  border: 0 !important;
  border-radius: 12px !important;
  background: transparent !important;
  color: var(--text) !important;
  padding: .52rem .62rem !important;
  font: inherit !important;
  font-size: .82rem !important;
  line-height: 1.2 !important;
  text-align: left !important;
  cursor: pointer !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.variant-option:hover,
.variant-option:focus-visible,
.variant-option.selected {
  outline: none !important;
  background: color-mix(in oklab, var(--brand) 22%, var(--panel-strong)) !important;
}
.visual-stage:fullscreen .variant-select-menu,
.fullscreen-quality .variant-select-menu {
  top: auto !important;
  bottom: calc(100% + .42rem) !important;
  right: 0 !important;
  left: auto !important;
}

.variant-select-menu.is-floating-layer {
  position: fixed !important;
  right: auto !important;
  bottom: auto !important;
  display: block !important;
  visibility: visible;
  z-index: 2147483000 !important;
  pointer-events: auto !important;
}

@media (max-width: 760px) {
  .variant-select-menu {
    min-width: min(280px, calc(100vw - 1rem)) !important;
    max-width: min(360px, calc(100vw - 1rem)) !important;
  }
}

.app-select-shell,
.variant-select-shell {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
}
.app-native-select,
.variant-native-select {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
.app-select-button,
.variant-select-button {
  position: relative !important;
  width: 100% !important;
  min-width: 0 !important;
  min-height: 42px !important;
  border: 1px solid color-mix(in oklab, var(--line) 88%, transparent) !important;
  border-radius: 14px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025)),
    rgba(20,25,38,.96) !important;
  color: var(--text) !important;
  padding: .58rem 2.2rem .58rem .82rem !important;
  font: inherit !important;
  font-size: .82rem !important;
  font-weight: 800 !important;
  line-height: 1.15 !important;
  text-align: left !important;
  cursor: pointer !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.02) !important;
}
.app-select-button::after,
.variant-select-button::after {
  content: "▾" !important;
  position: absolute !important;
  right: .82rem !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  color: var(--muted) !important;
  font-size: .75rem !important;
  pointer-events: none !important;
  transition: transform .16s ease, color .16s ease !important;
}
.app-select-shell.open .app-select-button::after,
.variant-select-shell.open .variant-select-button::after {
  transform: translateY(-50%) rotate(180deg) !important;
}
.app-select-button.is-disabled,
.app-select-button:disabled,
.variant-select-button.is-disabled,
.variant-select-button:disabled {
  opacity: .58 !important;
  cursor: not-allowed !important;
}
.app-select-menu,
.variant-select-menu {
  position: absolute !important;
  left: 0 !important;
  right: auto !important;
  top: calc(100% + .42rem) !important;
  z-index: 90 !important;
  width: min(100%, 420px) !important;
  min-width: min(220px, calc(100vw - 2rem)) !important;
  max-width: min(420px, calc(100vw - 2rem)) !important;
  max-height: min(260px, 42vh) !important;
  overflow: auto !important;
  padding: .38rem !important;
  border: 1px solid color-mix(in oklab, var(--brand) 48%, var(--line)) !important;
  border-radius: 18px !important;
  background:
    radial-gradient(circle at top left, color-mix(in oklab, var(--brand) 12%, transparent), transparent 38%),
    color-mix(in oklab, var(--panel-solid) 94%, black 6%) !important;
  box-shadow: 0 22px 70px rgba(0,0,0,.48) !important;
  backdrop-filter: blur(18px) !important;
}
.app-select-option,
.variant-option {
  width: 100% !important;
  min-height: 34px !important;
  border: 0 !important;
  border-radius: 12px !important;
  background: transparent !important;
  color: var(--text) !important;
  padding: .52rem .62rem !important;
  font: inherit !important;
  font-size: .82rem !important;
  line-height: 1.2 !important;
  text-align: left !important;
  cursor: pointer !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.app-select-option:hover,
.app-select-option:focus-visible,
.app-select-option.selected,
.variant-option:hover,
.variant-option:focus-visible,
.variant-option.selected {
  outline: none !important;
  background: color-mix(in oklab, var(--brand) 22%, var(--panel-strong)) !important;
}
.mix-select-content .app-select-menu,
.station-chooser-filter-grid .app-select-menu,
.filter-grid .app-select-menu {
  width: min(260px, calc(100vw - 2rem)) !important;
  max-width: min(320px, calc(100vw - 2rem)) !important;
}
.visual-stage:fullscreen .variant-select-menu,
.fullscreen-quality .variant-select-menu {
  top: auto !important;
  bottom: calc(100% + .42rem) !important;
  right: 0 !important;
  left: auto !important;
}
@media (max-width: 760px) {
  .app-select-menu,
  .variant-select-menu {
    min-width: min(220px, calc(100vw - 1rem)) !important;
    max-width: min(360px, calc(100vw - 1rem)) !important;
  }
}

.modal[data-modal-type="station-chooser"] {
  width: min(760px, calc(100vw - 2rem)) !important;
  max-width: min(760px, calc(100vw - 2rem)) !important;
  min-height: min(620px, calc(100vh - 3rem)) !important;
  max-height: calc(100vh - 2.5rem) !important;
  overflow: visible !important;
}
.modal[data-modal-type="station-chooser"] #modalContent {
  overflow: visible !important;
}
.station-chooser-modal {
  min-height: min(540px, calc(100vh - 7rem)) !important;
  max-height: calc(100vh - 5.2rem) !important;
  display: grid !important;
  grid-template-rows: auto auto auto minmax(190px, 1fr) !important;
  overflow: visible !important;
}
.station-chooser-filter-grid {
  position: relative !important;
  z-index: 12 !important;
  overflow: visible !important;
}
.station-chooser-filter-grid label,
.station-chooser-filter-grid .app-select-shell {
  overflow: visible !important;
}
.station-chooser-filter-grid .app-select-shell.open {
  z-index: 40 !important;
}
.station-chooser-filter-grid .app-select-menu {
  max-height: min(238px, 34vh) !important;
  overflow-y: auto !important;
}
.station-chooser-list {
  position: relative !important;
  z-index: 1 !important;
  min-height: 190px !important;
  max-height: min(390px, 42vh) !important;
  overflow: auto !important;
}
.station-chooser-empty {
  min-height: 88px !important;
  display: flex !important;
  align-items: center !important;
}
@media (max-height: 760px) {
  .modal[data-modal-type="station-chooser"] {
    min-height: calc(100vh - 2rem) !important;
  }
  .station-chooser-modal {
    min-height: calc(100vh - 6.2rem) !important;
  }
  .station-chooser-list {
    max-height: min(320px, 36vh) !important;
  }
  .station-chooser-filter-grid .app-select-menu {
    max-height: min(210px, 32vh) !important;
  }
}
@media (max-width: 620px) {
  .modal[data-modal-type="station-chooser"] {
    min-height: calc(100vh - 2rem) !important;
    overflow: auto !important;
  }
  .station-chooser-modal {
    max-height: none !important;
  }
}

.queue-panel.queue-panel-standalone {
  margin-top: 1rem !important;
  margin-bottom: 1rem !important;
}
.queue-panel.queue-panel-standalone .section-title.queue-panel-title {
  align-items: center !important;
  padding-left: 0 !important;
  margin-bottom: .55rem !important;
}
.queue-panel.queue-panel-standalone .queue-panel-title-copy {
  gap: .72rem !important;
  align-items: center !important;
}
.queue-panel.queue-panel-standalone .queue-panel-title-copy .eyebrow {
  color: var(--brand) !important;
  line-height: 1 !important;
  margin: 0 !important;
}
.queue-panel.queue-panel-standalone .queue-panel-title-copy h2 {
  color: var(--text) !important;
  margin: 0 !important;
  line-height: 1.2 !important;
  font-size: 1.08rem !important;
  font-weight: 800 !important;
}
.queue-panel.queue-panel-standalone .queue-actions {
  margin-bottom: .55rem !important;
}
.mix-panel .helper-text {
  margin-top: .5rem !important;
}
@media (max-width: 760px) {
  .queue-panel.queue-panel-standalone .queue-panel-title-copy {
    gap: .58rem !important;
  }
  .queue-panel.queue-panel-standalone .queue-panel-title-copy h2 {
    font-size: 1rem !important;
  }
}

.hero-player {
  isolation: isolate !important;
}

.hero-player > .station-headline,
.hero-player > .meta-grid,
.hero-player > .tag-row,
.hero-player > .action-row,
.hero-player > .player-similar-panel {
  position: relative;
  z-index: 3;
  background: var(--panel-strong);
}

.hero-player > .station-headline {
  padding-top: 1rem;
}

.hero-player > .action-row {
  padding-top: .5rem;
  padding-bottom: 1rem;
}

.hero-player > .player-similar-panel {
  margin-top: 0;
}

.mix-panel .mix-controls {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: .6rem !important;
  margin-top: .75rem !important;
  margin-bottom: .35rem !important;
}
.mix-panel .mix-controls #mixStartButton {
  min-width: 185px !important;
}

.visual-stage:not(:fullscreen) {
  overflow: hidden !important;
  clip-path: inset(0 round var(--radius-xl) var(--radius-xl) 0 0);
}

.visual-stage:not(:fullscreen) .visual-glow {
  pointer-events: none !important;
}

.hero-player {
  background: var(--panel-strong) !important;
  overflow: hidden !important;
  isolation: isolate !important;
}

.hero-player > .station-headline,
.hero-player > .meta-grid,
.hero-player > .tag-row,
.hero-player > .action-row,
.hero-player > .audio-panel,
.hero-player > .player-similar-panel {
  position: relative !important;
  z-index: 4 !important;
  background: var(--panel-strong) !important;
}

.hero-player > .station-headline {
  padding-top: 1rem !important;
}

.hero-player > .action-row {
  padding-top: .72rem !important;
  padding-bottom: .9rem !important;
}

.hero-player > .player-similar-panel {
  margin: 0 !important;
  padding: .85rem 1.25rem 1.25rem !important;
  border: 0 !important;
  border-top: 1px solid var(--line) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: var(--panel-strong) !important;
}

.hero-player > .player-similar-panel .detail-empty {
  background: color-mix(in oklab, var(--panel) 52%, transparent) !important;
}

@media (max-width: 760px) {
  .hero-player > .player-similar-panel {
    padding-inline: .9rem !important;
  }
}

.mix-panel > .section-title.mix-panel-title {
  align-items: center !important;
}
.mix-panel > .section-title.mix-panel-title .mini-badge {
  margin-left: auto !important;
  flex: 0 0 auto !important;
  align-self: center !important;
}
.mix-status-row {
  display: grid !important;
  grid-template-columns: minmax(210px, 240px) repeat(3, minmax(0, 1fr));
  gap: .8rem !important;
  align-items: stretch !important;
  margin-top: 1rem !important;
}
.mix-status-row .mix-controls {
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  align-items: stretch !important;
}
.mix-status-row .mix-controls #mixStartButton {
  min-width: 0 !important;
  width: 100% !important;
  min-height: 100% !important;
}
.mix-status-card {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: .9rem;
  background: var(--panel-strong);
  min-height: 74px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.mix-status-card span {
  display: block;
  color: var(--muted);
  font-size: .82rem;
  margin-bottom: .25rem;
}
.mix-status-card strong {
  font-size: 1.05rem;
  line-height: 1.2;
  word-break: break-word;
}
.mix-panel .helper-text {
  margin-top: .75rem !important;
}
@media (max-width: 1180px) {
  .mix-status-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .mix-status-row .mix-controls {
    grid-column: 1 / -1;
  }
}
@media (max-width: 760px) {
  .mix-status-row {
    grid-template-columns: 1fr;
  }
  .mix-status-row .mix-controls {
    grid-column: auto;
  }
}

.mix-panel > .section-title.mix-panel-title {
  padding-right: 0 !important;
}
.mix-panel > .section-title.mix-panel-title .mini-badge {
  margin-left: auto !important;
  margin-right: 1rem !important;
  transform: none !important;
}

.mix-status-row {
  grid-template-columns: minmax(165px, 205px) minmax(0, 1.12fr) minmax(140px, .58fr) minmax(0, 1.18fr) !important;
  gap: .58rem !important;
  align-items: stretch !important;
  margin-top: .72rem !important;
}

.mix-status-row .mix-controls {
  min-height: 0 !important;
}

.mix-status-row .mix-controls #mixStartButton {
  min-height: 50px !important;
  height: 50px !important;
  padding: .55rem .82rem !important;
  font-size: .9rem !important;
  line-height: 1.1 !important;
}

.mix-status-card {
  min-height: 50px !important;
  padding: .55rem .74rem !important;
  border-radius: 16px !important;
}

.mix-status-card span {
  font-size: .76rem !important;
  margin-bottom: .12rem !important;
  line-height: 1.1 !important;
}

.mix-status-card strong {
  font-size: .92rem !important;
  line-height: 1.14 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

@media (max-width: 1180px) {
  .mix-panel > .section-title.mix-panel-title .mini-badge {
    margin-right: 0 !important;
  }
  .mix-status-row {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .mix-status-row .mix-controls {
    grid-column: auto !important;
  }
}

@media (max-width: 760px) {
  .mix-status-row {
    grid-template-columns: 1fr !important;
  }
  .mix-status-row .mix-controls #mixStartButton,
  .mix-status-card {
    min-height: 48px !important;
  }
}

.mix-panel > .section-title.mix-panel-title {
  padding-right: 1rem !important;
}

.mix-panel > .section-title.mix-panel-title .mini-badge#mixBadge {
  margin-left: auto !important;
  margin-right: 0 !important;
  flex: 0 0 auto !important;
  align-self: center !important;
}

@media (max-width: 430px) {
  .mix-panel > .section-title.mix-panel-title {
    padding-right: 1rem !important;
  }
}

.mix-panel > .section-title.mix-panel-title {
  padding-right: 0 !important;
}

.mix-panel > .section-title.mix-panel-title .mini-badge#mixBadge {
  margin-left: auto !important;
  margin-right: 0 !important;
  transform: none !important;
}

.visual-stage {
  user-select: none !important;
  -webkit-user-select: none !important;
  -ms-user-select: none !important;
  -webkit-tap-highlight-color: transparent;
}

.visual-stage img,
#stationArtwork {
  user-select: none !important;
  -webkit-user-select: none !important;
  -ms-user-select: none !important;
  -webkit-user-drag: none;
  pointer-events: none;
  outline: none !important;
}

.visual-stage::selection,
.visual-stage *::selection {
  background: transparent;
}

@media (max-width: 430px) {
  .mix-panel > .section-title.mix-panel-title {
    padding-right: 0 !important;
  }
}

.mix-panel > .section-title.mix-panel-title {
  padding-left: 0 !important;
  padding-right: 0 !important;
  padding-inline: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.mix-panel > .section-title.mix-panel-title .mix-panel-title-copy {
  margin-left: 0 !important;
  padding-left: 0 !important;
}

.variant-select-shell.open,
.variant-select-menu.is-floating-layer {
  z-index: 2147483000 !important;
}

.variant-select-menu.is-floating-layer {
  position: fixed !important;
  pointer-events: auto !important;
  overflow-y: auto !important;
  transform: none !important;
}

.visual-stage > .stage-control-row .stage-quality,
.visual-stage > .stage-control-row .variant-select-shell {
  position: relative !important;
  z-index: 2147483000 !important;
}

@media (max-width: 760px) {
  .mix-panel > .section-title.mix-panel-title {
    padding-inline: 0 !important;
  }
}

body > .variant-select-menu.is-floating-layer {
  position: fixed !important;
  z-index: 2147483000 !important;
  margin: 0 !important;
  pointer-events: auto !important;
  transform: none !important;
  clip-path: none !important;
}

.hero-player > .action-row {
  justify-content: flex-end !important;
}

.hero-player > .action-row > .soft-button,
.hero-player > .action-row > .primary-button {
  max-width: 100%;
}

.hero-player > .action-row > #heroFavoriteButton.active {
  color: #ffd166;
  border-color: color-mix(in oklab, #ffd166 48%, var(--line));
  background: color-mix(in oklab, #ffd166 10%, var(--panel-strong));
}

@media (max-width: 760px) {
  .hero-player > .action-row {
    justify-content: flex-start !important;
  }
}

.mix-select-box > summary .wizard-number {
  display: none !important;
}

.mix-select-box > summary {
  display: grid !important;
  grid-template-columns: minmax(0, max-content) minmax(0, 1fr) !important;
  align-items: center !important;
  column-gap: .72rem !important;
  min-height: 58px !important;
  padding: .72rem 2.95rem .72rem 1rem !important;
}

.mix-select-box > summary strong,
.mix-select-box > summary small {
  align-self: center !important;
  margin: 0 !important;
}

.mix-select-box > summary strong {
  line-height: 1.2 !important;
}

.mix-select-box > summary small {
  min-width: 0 !important;
  line-height: 1.2 !important;
}

body.filters-modal-open {
  overflow: hidden !important;
}

body.filters-modal-open::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 79;
  background: rgba(5, 10, 24, .58);
  backdrop-filter: blur(10px);
}

#filterPanel {
  position: fixed !important;
  left: 50% !important;
  top: 50% !important;
  right: auto !important;
  bottom: auto !important;
  width: min(1120px, calc(100vw - 1.5rem)) !important;
  max-width: min(1120px, calc(100vw - 1.5rem)) !important;
  max-height: min(82vh, 760px) !important;
  overflow: auto !important;
  overscroll-behavior: contain;
  z-index: 80 !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transform: translate(-50%, calc(-50% + 18px)) scale(.98) !important;
  transition: transform .22s ease, opacity .22s ease !important;
  border-radius: 28px !important;
  border: 1px solid color-mix(in oklab, var(--line) 88%, rgba(255,255,255,.04)) !important;
  box-shadow: 0 28px 90px rgba(0,0,0,.56) !important;
  background: linear-gradient(180deg, color-mix(in oklab, var(--panel) 96%, black 4%), color-mix(in oklab, var(--panel-strong) 96%, black 4%)) !important;
}

#filterPanel.open {
  opacity: 1 !important;
  pointer-events: auto !important;
  transform: translate(-50%, -50%) scale(1) !important;
}

#filterPanel .section-title.compact {
  position: sticky;
  top: -1rem;
  z-index: 2;
  margin: 0 -1rem .9rem !important;
  padding: 1rem 1rem .9rem !important;
  background: linear-gradient(180deg, color-mix(in oklab, var(--panel-solid) 94%, black 6%), color-mix(in oklab, var(--panel) 92%, transparent)) !important;
  backdrop-filter: blur(12px);
  border-bottom: 1px solid color-mix(in oklab, var(--line) 82%, transparent);
}

#filterPanel .filter-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: .8rem !important;
}

#filterPanel .check-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: .8rem !important;
  margin-top: 1rem !important;
}

#filterPanel .filter-grid label,
#filterPanel .check-grid label {
  background: color-mix(in oklab, var(--panel-strong) 78%, transparent);
  border: 1px solid color-mix(in oklab, var(--line) 86%, transparent);
  padding: .75rem .8rem;
}

@media (max-width: 980px) {
  #filterPanel .filter-grid,
  #filterPanel .check-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  .mix-select-box > summary {
    min-height: 54px !important;
    padding: .68rem 2.7rem .68rem .92rem !important;
  }

  #filterPanel {
    width: calc(100vw - 1rem) !important;
    max-width: calc(100vw - 1rem) !important;
    max-height: min(84dvh, 760px) !important;
    border-radius: 24px !important;
  }

  #filterPanel .filter-grid,
  #filterPanel .check-grid {
    grid-template-columns: 1fr !important;
  }
}

body.filters-modal-open,
body.filters-modal-open::before {
  all: unset;
}

#filterPanel.filter-dialog {
  position: relative !important;
  box-sizing: border-box;
  width: min(1120px, calc(100vw - 3rem)) !important;
  max-width: min(1120px, calc(100vw - 3rem)) !important;
  max-height: calc(100vh - 3rem) !important;
  overflow: auto !important;
  padding: 1rem 1rem 1.1rem !important;
  border-radius: 28px !important;
  border: 1px solid color-mix(in oklab, var(--line) 88%, rgba(255,255,255,.04)) !important;
  background: linear-gradient(180deg, color-mix(in oklab, var(--panel) 96%, black 4%), color-mix(in oklab, var(--panel-strong) 96%, black 4%)) !important;
  box-shadow: 0 28px 90px rgba(0,0,0,.56) !important;
}

#filterPanel.filter-dialog::backdrop {
  background: rgba(7, 12, 28, .72) !important;
  backdrop-filter: blur(8px);
}

#filterPanel.filter-dialog .section-title.compact {
  position: sticky;
  top: -1rem;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
  margin: 0 -1rem .9rem !important;
  padding: 1rem 1rem .9rem !important;
  background: linear-gradient(180deg, color-mix(in oklab, var(--panel-solid) 94%, black 6%), color-mix(in oklab, var(--panel) 92%, transparent)) !important;
  backdrop-filter: blur(12px);
  border-bottom: 1px solid color-mix(in oklab, var(--line) 82%, transparent);
}

#filterPanel.filter-dialog .modal-close {
  position: sticky;
  top: 0;
  right: 0;
  z-index: 4;
  margin-left: auto;
}

#filterPanel.filter-dialog .filter-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: .8rem !important;
}

#filterPanel.filter-dialog .check-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: .8rem !important;
  margin-top: 1rem !important;
}

#filterPanel.filter-dialog .filter-grid label,
#filterPanel.filter-dialog .check-grid label {
  background: color-mix(in oklab, var(--panel-strong) 78%, transparent);
  border: 1px solid color-mix(in oklab, var(--line) 86%, transparent);
  padding: .75rem .8rem;
  border-radius: 18px;
}

@media (max-width: 980px) {
  #filterPanel.filter-dialog .filter-grid,
  #filterPanel.filter-dialog .check-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  #filterPanel.filter-dialog {
    width: calc(100vw - 1rem) !important;
    max-width: calc(100vw - 1rem) !important;
    max-height: calc(100dvh - 1rem) !important;
    padding: .9rem .85rem 1rem !important;
    border-radius: 22px !important;
  }

  #filterPanel.filter-dialog .section-title.compact {
    top: -.9rem;
    margin: 0 -.85rem .85rem !important;
    padding: .9rem .85rem .8rem !important;
  }

  #filterPanel.filter-dialog .filter-grid,
  #filterPanel.filter-dialog .check-grid {
    grid-template-columns: 1fr !important;
  }
}

#filterPanel.filter-dialog,
#filterPanel.filter-dialog[open] {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: none !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  bottom: auto !important;
}

#filterPanel.filter-dialog:not([open]) {
  display: none !important;
}

#filterPanel.filter-dialog[open] {
  margin: auto !important;
}

#filterPanel.filter-dialog .filter-grid,
#filterPanel.filter-dialog .check-grid {
  opacity: 1 !important;
  visibility: visible !important;
}

#filterPanel.filter-dialog[open] {
  position: fixed !important;
  inset: 0 !important;
  margin: auto !important;
  width: min(1120px, calc(100vw - 3rem)) !important;
  max-width: min(1120px, calc(100vw - 3rem)) !important;
  height: fit-content !important;
  max-height: calc(100vh - 3rem) !important;
  transform: none !important;
}

@media (max-width: 760px) {
  #filterPanel.filter-dialog[open] {
    width: calc(100vw - 1rem) !important;
    max-width: calc(100vw - 1rem) !important;
    max-height: calc(100dvh - 1rem) !important;
  }
}

#filterPanel.filter-dialog .filter-grid,
#filterPanel.filter-dialog .check-grid {
  position: relative !important;
  overflow: visible !important;
}

#filterPanel.filter-dialog .filter-grid label {
  align-self: stretch !important;
  display: grid !important;
  gap: .55rem !important;
  color: var(--muted) !important;
  font-size: .9rem !important;
}

#filterPanel.filter-dialog .filter-grid input,
#filterPanel.filter-dialog .filter-grid select {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 46px !important;
  border: 1px solid color-mix(in oklab, var(--line) 88%, transparent) !important;
  border-radius: 16px !important;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)), rgba(20,25,38,.96) !important;
  color: var(--text) !important;
  padding: .72rem .9rem !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.02) !important;
}

#filterPanel.filter-dialog .filter-grid .app-select-shell {
  overflow: visible !important;
}

#filterPanel.filter-dialog .filter-grid .app-select-shell.open {
  z-index: 30 !important;
}

#filterPanel.filter-dialog .app-select-button {
  min-height: 46px !important;
  border-radius: 16px !important;
  padding: .72rem 2.25rem .72rem .9rem !important;
  font-size: .95rem !important;
  font-weight: 700 !important;
}

#filterPanel.filter-dialog .app-select-menu {
  z-index: 120 !important;
  width: min(320px, calc(100vw - 2rem)) !important;
  max-width: min(360px, calc(100vw - 2rem)) !important;
}

#filterPanel.filter-dialog .check-grid label {
  display: grid !important;
  grid-template-columns: 18px minmax(0, 1fr) !important;
  align-items: center !important;
  gap: .75rem !important;
  color: var(--text) !important;
  font-size: .95rem !important;
  line-height: 1.3 !important;
  min-height: 72px !important;
}

#filterPanel.filter-dialog .check-grid input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  margin: 0 !important;
  justify-self: start !important;
  align-self: center !important;
  accent-color: var(--brand) !important;
}

#filterPanel.filter-dialog .filter-popup-shell {
  display: grid !important;
  gap: .95rem !important;
}

#filterPanel.filter-dialog .filter-modal-head {
  padding-right: 3.2rem !important;
}

#filterPanel.filter-dialog .filter-modal-helper {
  margin: -.15rem 0 .1rem !important;
  color: var(--muted) !important;
  font-size: .92rem !important;
  line-height: 1.45 !important;
}

#filterPanel.filter-dialog .section-title.compact {
  all: unset;
}

#filterPanel.filter-dialog .station-chooser-title-copy .eyebrow {
  color: var(--brand) !important;
}

#filterPanel.filter-dialog .station-chooser-title-copy h2 {
  font-size: 1.08rem !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
  color: var(--text) !important;
}

#filterPanel.filter-dialog .modal-close {
  position: absolute !important;
  top: 1rem !important;
  right: 1rem !important;
  margin-left: 0 !important;
}

#filterPanel.filter-dialog .filter-grid {
  margin-top: .05rem !important;
}

@media (max-width: 760px) {
  #filterPanel.filter-dialog .filter-modal-helper {
    font-size: .88rem !important;
  }
}

.variant-select-menu {
  overflow-x: hidden !important;
  overflow-y: auto !important;
  scrollbar-gutter: stable !important;
  scrollbar-width: thin !important;
  scrollbar-color: color-mix(in oklab, var(--muted) 58%, transparent) transparent !important;
  clip-path: inset(0 round 18px) !important;
}

.variant-select-menu::-webkit-scrollbar {
  width: 10px;
}

.variant-select-menu::-webkit-scrollbar-track {
  background: transparent;
  margin-block: 10px;
  border-radius: 999px;
}

.variant-select-menu::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: color-mix(in oklab, var(--muted) 48%, transparent);
  border: 3px solid transparent;
  background-clip: content-box;
}

.variant-option.variant-option-rich {
  display: grid !important;
  grid-template-columns: minmax(140px, 1fr) auto auto !important;
  align-items: center !important;
  gap: .72rem !important;
  min-height: 40px !important;
  padding: .55rem .7rem !important;
}

.variant-option-name,
.variant-option-quality,
.variant-option-detail {
  display: block !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.variant-option-name {
  font-weight: 850 !important;
  color: var(--text) !important;
}

@media (max-width: 680px) {
  .variant-option.variant-option-rich {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: .18rem !important;
    align-items: start !important;
  }
}

.variant-option.variant-option-rich {
  display: flex !important;
  grid-template-columns: none !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: .55rem !important;
  min-width: 0 !important;
}

.variant-option-rich .variant-option-name {
  flex: 0 1 auto !important;
  max-width: min(300px, 48%) !important;
}

@media (max-width: 680px) {
  .variant-option.variant-option-rich {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: .18rem !important;
  }

  .variant-option-rich .variant-option-name,
  .variant-option-rich .variant-option-quality,
  .variant-option-rich .variant-option-detail {
    max-width: 100% !important;
  }
}

.variant-option.variant-option-rich {
  gap: .42rem !important;
}

.variant-option-rich .variant-option-name {
  flex: 0 1 auto !important;
  max-width: min(320px, 52vw) !important;
}

.variant-select-menu {
  scrollbar-gutter: auto !important;
  padding: .28rem !important;
}

.variant-option.variant-option-rich {
  width: 100% !important;
  max-width: 100% !important;
  gap: .36rem !important;
  padding: .5rem .56rem !important;
}

.variant-option-rich .variant-option-name {
  flex: 0 1 auto !important;
  max-width: min(300px, 58vw) !important;
}

.visual-stage:fullscreen .variant-select-menu,
.fullscreen-quality .variant-select-menu,
.variant-select-menu.is-floating-layer {
  overflow-x: hidden !important;
}

.variant-select-menu.is-floating-layer {
  width: max-content !important;
  min-width: 0 !important;
  max-width: calc(100vw - 24px) !important;
  padding: .22rem !important;
  scrollbar-gutter: auto !important;
  border-radius: 18px !important;
  clip-path: inset(0 round 18px) !important;
}

.variant-select-menu.is-floating-layer .variant-option.variant-option-rich {
  width: max-content !important;
  min-width: 100% !important;
  max-width: 100% !important;
  display: inline-flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: .28rem !important;
  padding: .5rem .48rem !important;
}

.variant-select-menu.is-floating-layer .variant-option-name {
  flex: 0 1 auto !important;
  max-width: min(260px, 54vw) !important;
}

.visual-stage:fullscreen .variant-select-menu.is-floating-layer,
.fullscreen-quality .variant-select-menu.is-floating-layer {
  z-index: 2147483000 !important;
}

@media (max-width: 680px) {
  .variant-select-menu.is-floating-layer .variant-option.variant-option-rich {
    display: inline-flex !important;
    gap: .24rem !important;
  }

  .variant-select-menu.is-floating-layer .variant-option-name {
    max-width: min(190px, 42vw) !important;
  }
}

.variant-select-menu.is-floating-layer {
  padding: .14rem !important;
}

.variant-select-menu.is-floating-layer .variant-option.variant-option-rich {
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  gap: .22rem !important;
  padding: .42rem .4rem !important;
}

.variant-select-menu.is-floating-layer .variant-option-name {
  max-width: min(240px, 50vw) !important;
}

@media (max-width: 680px) {
  .variant-select-menu.is-floating-layer .variant-option-name {
    max-width: min(180px, 38vw) !important;
  }
}

.variant-select-menu.is-floating-layer {
  padding: .12rem !important;
  box-sizing: border-box !important;
}

.variant-select-menu.is-floating-layer .variant-option.variant-option-rich {
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  gap: .2rem !important;
  padding: .4rem .36rem !important;
  box-sizing: border-box !important;
}

.variant-select-menu.is-floating-layer .variant-option-name {
  max-width: min(230px, 48vw) !important;
}

.variant-select-menu.is-floating-layer {
  padding: .08rem !important;
}

.variant-select-menu.is-floating-layer .variant-option.variant-option-rich {
  gap: .12rem !important;
  padding: .34rem .28rem !important;
}

.variant-select-menu.is-floating-layer .variant-option-name {
  max-width: min(205px, 44vw) !important;
}

.variant-select-menu.is-floating-layer {
  padding: .06rem !important;
  width: auto !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

.variant-select-menu.is-floating-layer .variant-option.variant-option-rich {
  display: inline-flex !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  gap: .16rem !important;
  padding: .34rem .32rem !important;
  box-sizing: border-box !important;
  white-space: nowrap !important;
}

.variant-select-menu.is-floating-layer .variant-option-name,
.variant-select-menu.is-floating-layer .variant-option-quality,
.variant-select-menu.is-floating-layer .variant-option-detail {
  overflow: visible !important;
  text-overflow: clip !important;
  white-space: nowrap !important;
}

.variant-select-menu.is-floating-layer .variant-option-name {
  max-width: none !important;
}

.variant-select-menu.is-floating-layer {
  padding: .16rem !important;
  box-sizing: border-box !important;
}

.variant-select-menu.is-floating-layer .variant-option.variant-option-rich {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  padding: .42rem .5rem !important;
  box-sizing: border-box !important;
  white-space: nowrap !important;
  overflow: visible !important;
  text-overflow: clip !important;
  font-weight: 800 !important;
  line-height: 1.25 !important;
}

.variant-select-menu.is-floating-layer {
  padding: .18rem !important;
  box-sizing: border-box !important;
}

.variant-select-menu.is-floating-layer .variant-option.variant-option-rich {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: .62rem !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  padding: .42rem .56rem !important;
  box-sizing: border-box !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  line-height: 1.25 !important;
}

.variant-select-menu.is-floating-layer .variant-option-name {
  flex: 0 1 auto !important;
  min-width: 0 !important;
  max-width: none !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  font-weight: 850 !important;
}

@media (max-width: 680px) {
  .variant-select-menu.is-floating-layer .variant-option.variant-option-rich {
    gap: .45rem !important;
    padding-inline: .48rem !important;
  }
}

.variant-select-menu.is-floating-layer {
  padding: .16rem !important;
  box-sizing: border-box !important;
}

.variant-select-menu.is-floating-layer .variant-option.variant-option-rich {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 1rem !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  padding: .42rem .56rem !important;
  box-sizing: border-box !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  line-height: 1.25 !important;
}

.variant-select-menu.is-floating-layer .variant-option-name {
  flex: 0 1 auto !important;
  min-width: 0 !important;
  max-width: none !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  font-weight: 850 !important;
}

.variant-select-menu.is-floating-layer .variant-option-meta {
  flex: 0 0 auto !important;
  min-width: max-content !important;
  max-width: none !important;
  overflow: visible !important;
  text-overflow: clip !important;
  white-space: nowrap !important;
  font-weight: 650 !important;
  color: color-mix(in oklab, var(--text) 84%, var(--muted)) !important;
}

@media (max-width: 680px) {
  .variant-select-menu.is-floating-layer .variant-option.variant-option-rich {
    gap: .72rem !important;
    padding-inline: .5rem !important;
  }
}

:root {
  --player-control-height-unified: 38px;
}

.stage-control-row .stage-transport .primary-button,
.stage-control-row .stage-transport .soft-button,
.stage-control-row .stage-quality .variant-select-button,
.stage-control-row .stage-volume #muteButton,
.stage-control-row > #fullscreenStageButton,
.visual-stage:fullscreen .fullscreen-transport .primary-button,
.visual-stage:fullscreen .fullscreen-transport .soft-button,
.visual-stage:fullscreen .fullscreen-quality .variant-select-button,
.visual-stage:fullscreen .fullscreen-right-controls .soft-button {
  min-height: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  box-sizing: border-box !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.stage-control-row .stage-transport .primary-button,
.stage-control-row .stage-transport .soft-button,
.stage-control-row .stage-volume #muteButton,
.stage-control-row > #fullscreenStageButton,
.visual-stage:fullscreen .fullscreen-transport .primary-button,
.visual-stage:fullscreen .fullscreen-transport .soft-button,
.visual-stage:fullscreen .fullscreen-right-controls .soft-button {
  padding-inline: .78rem !important;
}

.stage-control-row .stage-quality .variant-select-button,
.visual-stage:fullscreen .fullscreen-quality .variant-select-button {
  padding-inline: .82rem 2.2rem !important;
  justify-content: flex-start !important;
}

.stage-control-row .stage-transport .player-shortcuts-button,
.visual-stage:fullscreen .fullscreen-transport .player-shortcuts-button {
  min-width: var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  padding-inline: 0 !important;
}

.stage-control-row .stage-volume,
.stage-control-row .stage-quality,
.visual-stage:fullscreen .fullscreen-quality,
.visual-stage:fullscreen .fullscreen-right-controls {
  align-items: center !important;
}

.stage-control-row .stage-volume label,
.stage-control-row .stage-quality label,
.visual-stage:fullscreen .fullscreen-volume span,
.visual-stage:fullscreen .fullscreen-quality span {
  align-self: center !important;
}

.stage-control-row .stage-quality .variant-select-button,
.visual-stage:fullscreen .fullscreen-quality .variant-select-button {
  position: relative !important;
  overflow: hidden !important;
  min-width: 0 !important;
  text-overflow: clip !important;
  white-space: nowrap !important;
}

.stage-control-row .stage-quality .variant-select-button .variant-select-button-text,
.visual-stage:fullscreen .fullscreen-quality .variant-select-button .variant-select-button-text {
  display: block !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  padding-right: .15rem !important;
}

.stage-control-row .stage-quality .variant-select-button::after,
.visual-stage:fullscreen .fullscreen-quality .variant-select-button::after {
  flex: 0 0 auto !important;
  z-index: 2 !important;
}

.variant-select-menu.is-floating-layer .variant-option.variant-option-rich {
  overflow: visible !important;
}

.variant-select-menu.is-floating-layer .variant-option-name,
.variant-select-menu.is-floating-layer .variant-option-meta {
  overflow: visible !important;
  text-overflow: clip !important;
}

.mix-select-stack .mix-select-box > summary,
.mix-select-stack .mix-select-box summary {
  display: grid !important;
  grid-template-columns: minmax(0, auto) minmax(0, 1fr) auto !important;
  align-items: center !important;
  min-height: 44px !important;
  height: 44px !important;
  padding: .38rem .72rem .38rem .82rem !important;
  gap: .5rem !important;
  box-sizing: border-box !important;
}

.mix-select-stack .mix-select-box > summary .wizard-number,
.mix-select-stack .mix-select-box summary .wizard-number {
  display: none !important;
}

.mix-select-stack .mix-select-box > summary strong,
.mix-select-stack .mix-select-box summary strong {
  grid-column: 1 !important;
  align-self: center !important;
  justify-self: start !important;
  margin: 0 !important;
  min-width: 0 !important;
  line-height: 1 !important;
  font-size: .94rem !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.mix-select-stack .mix-select-box > summary small,
.mix-select-stack .mix-select-box summary small {
  grid-column: 2 !important;
  align-self: center !important;
  justify-self: end !important;
  margin: 0 !important;
  min-width: 0 !important;
  max-width: 100% !important;
  line-height: 1 !important;
  font-size: .76rem !important;
  text-align: right !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.mix-select-stack .mix-select-box summary::after {
  grid-column: 3 !important;
  align-self: center !important;
  justify-self: center !important;
  margin: 0 !important;
  line-height: 1 !important;
  font-size: .86rem !important;
}

.mix-select-stack .mix-select-box {
  border-radius: 18px !important;
}

@media (max-width: 760px) {
  .mix-select-stack .mix-select-box > summary,
  .mix-select-stack .mix-select-box summary {
    min-height: 42px !important;
    height: 42px !important;
    padding: .34rem .66rem .34rem .74rem !important;
  }
}

.mix-select-stack .mix-select-box:not([open]) {
  min-height: 42px !important;
  height: 42px !important;
  max-height: 42px !important;
  display: block !important;
  overflow: hidden !important;
}

.mix-select-stack .mix-select-box:not([open]) > summary,
.mix-select-stack .mix-select-box:not([open]) summary {
  min-height: 40px !important;
  height: 40px !important;
  max-height: 40px !important;
  padding: 0 .68rem 0 .78rem !important;
  display: grid !important;
  grid-template-columns: minmax(0, auto) minmax(0, 1fr) auto !important;
  align-items: center !important;
  align-content: center !important;
  column-gap: .46rem !important;
  box-sizing: border-box !important;
}

.mix-select-stack .mix-select-box:not([open]) > summary strong,
.mix-select-stack .mix-select-box:not([open]) summary strong,
.mix-select-stack .mix-select-box:not([open]) > summary small,
.mix-select-stack .mix-select-box:not([open]) summary small,
.mix-select-stack .mix-select-box:not([open]) summary::after {
  align-self: center !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  line-height: 1 !important;
}

.mix-select-stack .mix-select-box:not([open]) > summary strong,
.mix-select-stack .mix-select-box:not([open]) summary strong {
  font-size: .9rem !important;
}

.mix-select-stack .mix-select-box:not([open]) > summary small,
.mix-select-stack .mix-select-box:not([open]) summary small {
  font-size: .72rem !important;
  justify-self: end !important;
  text-align: right !important;
}

.mix-select-stack .mix-select-box:not([open]) summary::after {
  font-size: .82rem !important;
  justify-self: center !important;
}

.mix-select-stack .mix-select-box[open] {
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
}

.mix-select-stack .mix-select-box,
.mix-select-stack .mix-select-box[open],
.mix-select-stack .mix-select-box:not([open]) {
  height: 42px !important;
  min-height: 42px !important;
  max-height: 42px !important;
  overflow: visible !important;
  display: block !important;
  box-sizing: border-box !important;
}

.mix-select-stack .mix-select-box > summary,
.mix-select-stack .mix-select-box[open] > summary,
.mix-select-stack .mix-select-box:not([open]) > summary,
.mix-select-stack .mix-select-box summary,
.mix-select-stack .mix-select-box[open] summary,
.mix-select-stack .mix-select-box:not([open]) summary {
  height: 40px !important;
  min-height: 40px !important;
  max-height: 40px !important;
  padding: 0 .68rem 0 .78rem !important;
  display: grid !important;
  grid-template-columns: minmax(0, auto) minmax(0, 1fr) auto !important;
  align-items: center !important;
  align-content: center !important;
  column-gap: .46rem !important;
  box-sizing: border-box !important;
}

.mix-select-stack .mix-select-box[open] > summary {
  border-radius: 18px !important;
}

.mix-select-stack .mix-select-box > .mix-select-content {
  position: absolute !important;
  top: calc(100% + .56rem) !important;
  z-index: 320 !important;
}

.mix-select-stack .mix-select-box > summary strong,
.mix-select-stack .mix-select-box > summary small,
.mix-select-stack .mix-select-box summary::after {
  align-self: center !important;
  margin: 0 !important;
  line-height: 1 !important;
}

.mix-select-stack .mix-select-box > summary strong {
  font-size: .9rem !important;
}

.mix-select-stack .mix-select-box > summary small {
  font-size: .72rem !important;
  justify-self: end !important;
  text-align: right !important;
}

.mix-select-stack .mix-select-box summary::after {
  font-size: .82rem !important;
  justify-self: center !important;
}

.genre-overview-panel {
  display: grid !important;
  gap: .8rem !important;
  padding: .95rem 1.1rem 1rem !important;
  margin-bottom: 1rem !important;
}

.genre-overview-title {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  min-height: auto !important;
}

.genre-overview-title-copy {
  display: flex !important;
  align-items: baseline !important;
  gap: .6rem !important;
  flex-wrap: wrap !important;
}

.genre-overview-title-copy .eyebrow {
  margin: 0 !important;
}

.genre-overview-title-copy h2 {
  margin: 0 !important;
  font-size: 1.12rem !important;
  line-height: 1.2 !important;
  color: var(--text) !important;
}

.genre-overview-panel .genre-strip.genre-strip-panel {
  position: static !important;
  top: auto !important;
  z-index: auto !important;
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: .5rem !important;
  overflow: visible !important;
  overflow-x: visible !important;
  overflow-y: visible !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  backdrop-filter: none !important;
  border-bottom: 0 !important;
  scrollbar-width: none !important;
  width: 100% !important;
  max-width: 100% !important;
}

.genre-overview-panel .genre-strip.genre-strip-panel::-webkit-scrollbar {
  display: none !important;
  width: 0 !important;
  height: 0 !important;
}

.genre-overview-panel .genre-chip {
  flex: 0 0 auto !important;
  min-height: 38px !important;
  padding: .52rem .88rem !important;
  border-radius: 999px !important;
  white-space: nowrap !important;
}

@media (max-width: 760px) {
  .genre-overview-panel {
    padding: .85rem .85rem .92rem !important;
    gap: .7rem !important;
  }

  .genre-overview-title-copy h2 {
    font-size: 1.02rem !important;
  }

  .genre-overview-panel .genre-strip.genre-strip-panel {
    gap: .42rem !important;
  }

  .genre-overview-panel .genre-chip {
    min-height: 36px !important;
    padding: .48rem .8rem !important;
  }
}

.genre-overview-panel {
  width: calc(100% - 2rem) !important;
  max-width: none !important;
  margin: .9rem auto 1rem !important;
  box-sizing: border-box !important;
}

.genre-overview-panel .genre-strip.genre-strip-panel {
  max-width: 100% !important;
}

@media (max-width: 760px) {
  .genre-overview-panel {
    width: calc(100% - 1.2rem) !important;
    margin: .7rem auto .8rem !important;
  }
}

.genre-overview-panel {
  width: auto !important;
  max-width: none !important;
  margin: .9rem clamp(1rem, 3vw, 2rem) 1rem !important;
  box-sizing: border-box !important;
}

@media (max-width: 760px) {
  .genre-overview-panel {
    margin: .7rem .65rem .8rem !important;
    width: auto !important;
  }
}

.stage-hover-controls {
  position: absolute !important;
  inset: 0 !important;
  z-index: 6 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: clamp(.85rem, 2vw, 1.25rem) !important;
  pointer-events: none !important;
  opacity: 0 !important;
  transform: scale(.985) !important;
  transition: opacity .18s ease, transform .18s ease !important;
}

.visual-stage:hover .stage-hover-controls,
.visual-stage:focus-within .stage-hover-controls,
.visual-stage.stage-hover-controls-visible .stage-hover-controls {
  opacity: 1 !important;
  transform: scale(1) !important;
}

.visual-stage.controls-hidden .stage-hover-controls {
  opacity: 0 !important;
  pointer-events: none !important;
}

.stage-hover-button {
  pointer-events: auto !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid color-mix(in oklab, white 28%, transparent) !important;
  color: rgba(255,255,255,.94) !important;
  background:
    radial-gradient(circle at 35% 25%, rgba(255,255,255,.16), transparent 42%),
    color-mix(in oklab, var(--panel-solid) 44%, transparent) !important;
  backdrop-filter: blur(16px) saturate(1.15) !important;
  box-shadow: 0 18px 58px rgba(0,0,0,.34), inset 0 0 0 1px rgba(255,255,255,.05) !important;
  cursor: pointer !important;
  user-select: none !important;
  touch-action: manipulation !important;
  transition: transform .14s ease, background .14s ease, border-color .14s ease, opacity .14s ease !important;
}

.stage-hover-button:hover,
.stage-hover-button:focus-visible {
  transform: translateY(-1px) scale(1.04) !important;
  border-color: color-mix(in oklab, var(--brand) 62%, white 18%) !important;
  background:
    radial-gradient(circle at 35% 25%, rgba(255,255,255,.22), transparent 44%),
    color-mix(in oklab, var(--brand) 26%, var(--panel-solid) 44%) !important;
  outline: none !important;
}

.stage-hover-button:disabled {
  opacity: .34 !important;
  cursor: default !important;
  transform: none !important;
}

.stage-hover-main {
  width: clamp(70px, 8vw, 98px) !important;
  height: clamp(70px, 8vw, 98px) !important;
  border-radius: 999px !important;
  font-size: clamp(1.8rem, 3vw, 2.65rem) !important;
  font-weight: 900 !important;
  padding-left: .16em !important;
}

.stage-hover-main:not(:disabled) {
  background:
    radial-gradient(circle at 35% 25%, rgba(255,255,255,.22), transparent 42%),
    linear-gradient(135deg, color-mix(in oklab, var(--brand) 56%, transparent), color-mix(in oklab, var(--brand-2) 52%, transparent)),
    color-mix(in oklab, var(--panel-solid) 34%, transparent) !important;
}

.stage-hover-side {
  width: clamp(46px, 5.5vw, 62px) !important;
  height: clamp(46px, 5.5vw, 62px) !important;
  border-radius: 999px !important;
  font-size: clamp(1.65rem, 2.4vw, 2.1rem) !important;
  font-weight: 900 !important;
}

@media (max-width: 760px) {
  .stage-hover-controls {
    gap: .72rem !important;
  }

  .stage-hover-main {
    width: 66px !important;
    height: 66px !important;
    font-size: 1.75rem !important;
  }

  .stage-hover-side {
    width: 44px !important;
    height: 44px !important;
    font-size: 1.5rem !important;
  }
}

.stage-hover-controls {
  display: none !important;
}

.visual-stage.stage-hover-controls-available .stage-hover-controls {
  display: flex !important;
}

.stage-hover-button {
  line-height: 1 !important;
  padding: 0 !important;
}

.stage-hover-button svg {
  width: 58% !important;
  height: 58% !important;
  display: block !important;
  fill: currentColor !important;
  transform: translateY(0) !important;
  margin: auto !important;
}

.stage-hover-main {
  width: clamp(104px, 14vw, 165px) !important;
  height: clamp(104px, 14vw, 165px) !important;
  font-size: 0 !important;
}

.stage-hover-main svg {
  width: 54% !important;
  height: 54% !important;
}

.stage-hover-side {
  width: clamp(66px, 8.2vw, 98px) !important;
  height: clamp(66px, 8.2vw, 98px) !important;
  font-size: 0 !important;
}

.visual-stage:not(.stage-hover-controls-available):hover .stage-hover-controls,
.visual-stage:not(.stage-hover-controls-available).stage-hover-controls-visible .stage-hover-controls {
  opacity: 0 !important;
  pointer-events: none !important;
}

@media (max-width: 760px) {
  .stage-hover-main {
    width: 88px !important;
    height: 88px !important;
  }

  .stage-hover-side {
    width: 56px !important;
    height: 56px !important;
  }
}

.stage-hover-controls {
  gap: clamp(1.2rem, 2.8vw, 2.6rem) !important;
}

.stage-hover-main {
  width: clamp(260px, 32vw, 520px) !important;
  height: clamp(260px, 32vw, 520px) !important;
}

.stage-hover-side {
  width: clamp(170px, 18vw, 300px) !important;
  height: clamp(170px, 18vw, 300px) !important;
}

.stage-hover-main svg {
  width: 48% !important;
  height: 48% !important;
}

.stage-hover-side svg {
  width: 46% !important;
  height: 46% !important;
}

@media (max-width: 760px) {
  .stage-hover-controls {
    gap: .9rem !important;
  }

  .stage-hover-main {
    width: min(42vw, 210px) !important;
    height: min(42vw, 210px) !important;
  }

  .stage-hover-side {
    width: min(24vw, 118px) !important;
    height: min(24vw, 118px) !important;
  }
}

.stage-hover-controls {
  gap: clamp(1rem, 2.2vw, 2rem) !important;
}

.stage-hover-main {
  width: clamp(170px, 20vw, 300px) !important;
  height: clamp(170px, 20vw, 300px) !important;
}

.stage-hover-side {
  width: clamp(108px, 12vw, 185px) !important;
  height: clamp(108px, 12vw, 185px) !important;
}

.stage-hover-button {
  opacity: .68 !important;
  border-color: color-mix(in oklab, white 20%, transparent) !important;
  background:
    radial-gradient(circle at 35% 25%, rgba(255,255,255,.12), transparent 42%),
    color-mix(in oklab, var(--panel-solid) 26%, transparent) !important;
  box-shadow: 0 14px 44px rgba(0,0,0,.22), inset 0 0 0 1px rgba(255,255,255,.035) !important;
}

.stage-hover-main:not(:disabled) {
  background:
    radial-gradient(circle at 35% 25%, rgba(255,255,255,.16), transparent 42%),
    linear-gradient(135deg, color-mix(in oklab, var(--brand) 34%, transparent), color-mix(in oklab, var(--brand-2) 32%, transparent)),
    color-mix(in oklab, var(--panel-solid) 22%, transparent) !important;
}

.stage-hover-button:hover,
.stage-hover-button:focus-visible {
  opacity: .9 !important;
}

.stage-hover-main svg {
  width: 46% !important;
  height: 46% !important;
}

.stage-hover-side svg {
  width: 44% !important;
  height: 44% !important;
}

@media (max-width: 760px) {
  .stage-hover-main {
    width: min(34vw, 150px) !important;
    height: min(34vw, 150px) !important;
  }

  .stage-hover-side {
    width: min(21vw, 92px) !important;
    height: min(21vw, 92px) !important;
  }
}

.visual-stage:fullscreen .stage-hover-controls {
  transform: translateY(-3vh) scale(.985) !important;
}

.visual-stage:fullscreen:hover .stage-hover-controls,
.visual-stage:fullscreen:focus-within .stage-hover-controls,
.visual-stage:fullscreen.stage-hover-controls-visible .stage-hover-controls {
  transform: translateY(-3vh) scale(1) !important;
}

.visual-stage:fullscreen.controls-hidden .stage-hover-controls {
  opacity: 0 !important;
  pointer-events: none !important;
}

@media (max-width: 900px) {
  .visual-stage:fullscreen .stage-hover-controls {
    transform: translateY(-4vh) scale(.985) !important;
  }

  .visual-stage:fullscreen:hover .stage-hover-controls,
  .visual-stage:fullscreen:focus-within .stage-hover-controls,
  .visual-stage:fullscreen.stage-hover-controls-visible .stage-hover-controls {
    transform: translateY(-4vh) scale(1) !important;
  }
}

.queue-item.is-played,
.queue-item.mix-played {
  opacity: 1 !important;
  border-color: color-mix(in oklab, #ff8a00 76%, var(--line)) !important;
  background:
    linear-gradient(90deg, color-mix(in oklab, #ff8a00 13%, transparent), transparent 46%),
    color-mix(in oklab, var(--panel-solid) 66%, transparent) !important;
  box-shadow: inset 0 0 0 1px color-mix(in oklab, #ff8a00 24%, transparent) !important;
}

.queue-item.is-played .queue-item-text strong,
.queue-item.mix-played .queue-item-text strong {
  color: color-mix(in oklab, var(--text) 94%, #ffb35c 12%) !important;
}

.queue-played-badge {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 30px !important;
  padding: .34rem .62rem !important;
  border: 1px solid color-mix(in oklab, #ff8a00 76%, var(--line)) !important;
  border-radius: 999px !important;
  color: color-mix(in oklab, #ffb35c 86%, white 10%) !important;
  background: color-mix(in oklab, #ff8a00 17%, transparent) !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
  white-space: nowrap !important;
}

.queue-item.is-played .soft-button.tiny[data-queue-action="play"],
.queue-item.mix-played .soft-button.tiny[data-queue-action="play"] {
  border-color: color-mix(in oklab, #ff8a00 34%, var(--line)) !important;
}

.queue-item.is-played,
.queue-item.mix-played {
  border-color: color-mix(in oklab, #ff6a00 88%, var(--line)) !important;
  background:
    linear-gradient(90deg, color-mix(in oklab, #ff6a00 24%, transparent), transparent 48%),
    color-mix(in oklab, var(--panel-solid) 62%, transparent) !important;
  box-shadow:
    inset 0 0 0 1px color-mix(in oklab, #ff6a00 42%, transparent),
    0 0 22px color-mix(in oklab, #ff6a00 12%, transparent) !important;
}

.queue-item.is-played .queue-item-text strong,
.queue-item.mix-played .queue-item-text strong {
  color: color-mix(in oklab, #ffb15a 74%, var(--text)) !important;
}

.queue-played-badge {
  border-color: color-mix(in oklab, #ff6a00 92%, var(--line)) !important;
  color: color-mix(in oklab, #ffb15a 92%, white 8%) !important;
  background: color-mix(in oklab, #ff6a00 28%, transparent) !important;
  box-shadow: inset 0 0 0 1px color-mix(in oklab, #ff6a00 18%, transparent) !important;
}

.queue-item.is-played .soft-button.tiny[data-queue-action="play"],
.queue-item.mix-played .soft-button.tiny[data-queue-action="play"] {
  border-color: color-mix(in oklab, #ff6a00 52%, var(--line)) !important;
}

.stage-hover-controls {
  transition:
    opacity var(--fullscreen-control-transition, .22s) ease,
    transform var(--fullscreen-control-transition, .22s) ease !important;
}

.visual-stage:fullscreen .stage-hover-controls,
.visual-stage:fullscreen .fullscreen-bottom-overlay {
  transition-duration: var(--fullscreen-control-transition, .22s) !important;
}

.visual-stage:fullscreen .stage-hover-controls {
  opacity: 1 !important;
  pointer-events: auto !important;
  transform: translateY(-3vh) scale(1) !important;
  transition: opacity .24s ease, transform .24s ease !important;
}

.visual-stage:fullscreen.controls-hidden .stage-hover-controls {
  opacity: 0 !important;
  pointer-events: none !important;
  transform: translateY(calc(-3vh + 14px)) scale(.985) !important;
  transition: opacity .24s ease, transform .24s ease !important;
}

.visual-stage:fullscreen.controls-hidden:hover .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:focus-within .stage-hover-controls {
  opacity: 0 !important;
  pointer-events: none !important;
  transform: translateY(calc(-3vh + 14px)) scale(.985) !important;
}

.visual-stage:not(:fullscreen):hover .stage-hover-controls,
.visual-stage:not(:fullscreen):focus-within .stage-hover-controls,
.visual-stage:not(:fullscreen).stage-hover-controls-visible .stage-hover-controls {
  opacity: 1 !important;
  transform: scale(1) !important;
}

@media (max-width: 900px) {
  .visual-stage:fullscreen .stage-hover-controls {
    transform: translateY(-4vh) scale(1) !important;
  }

  .visual-stage:fullscreen.controls-hidden .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden:hover .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden:focus-within .stage-hover-controls {
    transform: translateY(calc(-4vh + 14px)) scale(.985) !important;
  }
}

.visual-stage:fullscreen .stage-hover-controls {
  transition: opacity .24s ease, transform .24s ease !important;
  transition-delay: 0s !important;
}

.visual-stage:fullscreen.controls-hidden .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:hover .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:focus-within .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible .stage-hover-controls {
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity .24s ease, transform .24s ease !important;
  transition-delay: 0s !important;
}

.visual-stage:fullscreen .fullscreen-bottom-overlay,
.visual-stage:fullscreen .fullscreen-top-hint {
  transition: opacity .24s ease, transform .24s ease !important;
  transition-delay: 0s !important;
}

.visual-stage:fullscreen .fullscreen-bottom-overlay,
.visual-stage:fullscreen .fullscreen-top-hint,
.visual-stage:fullscreen .stage-hover-controls {
  transition-property: opacity, transform !important;
  transition-duration: .24s, .24s !important;
  transition-timing-function: ease, ease !important;
  transition-delay: 0s, 0s !important;
}

.visual-stage:fullscreen:not(.controls-hidden) .fullscreen-bottom-overlay,
.visual-stage:fullscreen:not(.controls-hidden) .fullscreen-top-hint {
  opacity: 1 !important;
  pointer-events: auto !important;
}

.visual-stage:fullscreen:not(.controls-hidden) .stage-hover-controls {
  opacity: 1 !important;
  pointer-events: none !important;
  transform: translateY(-3vh) scale(1) !important;
}

.visual-stage:fullscreen:not(.controls-hidden) .stage-hover-controls .stage-hover-button {
  pointer-events: auto !important;
}

.visual-stage:fullscreen.controls-hidden .fullscreen-bottom-overlay,
.visual-stage:fullscreen.controls-hidden .fullscreen-top-hint {
  opacity: 0 !important;
  transform: translateY(14px) !important;
  pointer-events: none !important;
}

.visual-stage:fullscreen.controls-hidden .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:hover .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:focus-within .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible .stage-hover-controls {
  opacity: 0 !important;
  transform: translateY(calc(-3vh + 14px)) scale(.985) !important;
  pointer-events: none !important;
}

@media (max-width: 900px) {
  .visual-stage:fullscreen:not(.controls-hidden) .stage-hover-controls {
    transform: translateY(-4vh) scale(1) !important;
  }

  .visual-stage:fullscreen.controls-hidden .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden:hover .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden:focus-within .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible .stage-hover-controls {
    transform: translateY(calc(-4vh + 14px)) scale(.985) !important;
  }
}

.visual-stage:fullscreen .fullscreen-bottom-overlay,
.visual-stage:fullscreen .fullscreen-top-hint,
.visual-stage:fullscreen .stage-hover-controls {
  transition-property: opacity, transform !important;
  transition-duration: .24s, .24s !important;
  transition-timing-function: ease, ease !important;
  transition-delay: 0s, 0s !important;
}

.visual-stage:fullscreen.controls-hidden .fullscreen-bottom-overlay,
.visual-stage:fullscreen.controls-hidden .fullscreen-top-hint,
.visual-stage:fullscreen.controls-hidden .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:hover .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:focus-within .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible .stage-hover-controls {
  opacity: 0 !important;
  pointer-events: none !important;
  transition-duration: .24s, .24s !important;
  transition-delay: 0s, 0s !important;
}

.visual-stage:fullscreen.controls-hidden .stage-hover-controls {
  transform: translateY(calc(-3vh + 14px)) scale(.985) !important;
}

.visual-stage:fullscreen:not(.controls-hidden) .fullscreen-bottom-overlay,
.visual-stage:fullscreen:not(.controls-hidden) .fullscreen-top-hint,
.visual-stage:fullscreen:not(.controls-hidden) .stage-hover-controls {
  opacity: 1 !important;
  transition-duration: .24s, .24s !important;
  transition-delay: 0s, 0s !important;
}

.visual-stage:fullscreen:not(.controls-hidden) .stage-hover-controls {
  transform: translateY(-3vh) scale(1) !important;
}

@media (max-width: 900px) {
  .visual-stage:fullscreen.controls-hidden .stage-hover-controls {
    transform: translateY(calc(-4vh + 14px)) scale(.985) !important;
  }

  .visual-stage:fullscreen:not(.controls-hidden) .stage-hover-controls {
    transform: translateY(-4vh) scale(1) !important;
  }
}

.visual-stage:fullscreen .stage-hover-controls,
.visual-stage:fullscreen:hover .stage-hover-controls,
.visual-stage:fullscreen:focus-within .stage-hover-controls,
.visual-stage:fullscreen.stage-hover-controls-visible .stage-hover-controls {
  opacity: 1 !important;
  pointer-events: none !important;
  transform: translateY(-3vh) scale(1) !important;
  transition: opacity .24s ease, transform .24s ease !important;
  transition-delay: 0s !important;
}

.visual-stage:fullscreen .stage-hover-controls .stage-hover-button {
  pointer-events: auto !important;
}

.visual-stage:fullscreen.controls-hidden .fullscreen-bottom-overlay,
.visual-stage:fullscreen.controls-hidden .fullscreen-top-hint,
.visual-stage:fullscreen.controls-hidden .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:hover .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:focus-within .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible .stage-hover-controls {
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity .24s ease, transform .24s ease !important;
  transition-delay: 0s !important;
}

.visual-stage:fullscreen.controls-hidden .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:hover .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:focus-within .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible .stage-hover-controls {
  transform: translateY(calc(-3vh + 14px)) scale(.985) !important;
}

@media (max-width: 900px) {
  .visual-stage:fullscreen .stage-hover-controls,
  .visual-stage:fullscreen:hover .stage-hover-controls,
  .visual-stage:fullscreen:focus-within .stage-hover-controls,
  .visual-stage:fullscreen.stage-hover-controls-visible .stage-hover-controls {
    transform: translateY(-4vh) scale(1) !important;
  }

  .visual-stage:fullscreen.controls-hidden .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden:hover .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden:focus-within .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible .stage-hover-controls {
    transform: translateY(calc(-4vh + 14px)) scale(.985) !important;
  }
}

.visual-stage:fullscreen .fullscreen-bottom-overlay .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden .fullscreen-bottom-overlay .stage-hover-controls,
.visual-stage:fullscreen:hover .fullscreen-bottom-overlay .stage-hover-controls,
.visual-stage:fullscreen:focus-within .fullscreen-bottom-overlay .stage-hover-controls,
.visual-stage:fullscreen.stage-hover-controls-visible .fullscreen-bottom-overlay .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:hover .fullscreen-bottom-overlay .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:focus-within .fullscreen-bottom-overlay .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible .fullscreen-bottom-overlay .stage-hover-controls {
  position: fixed !important;
  inset: 0 !important;
  z-index: 2 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  opacity: 1 !important;
  pointer-events: none !important;
  transform: translateY(-3vh) scale(1) !important;
  transition: none !important;
}

.visual-stage:fullscreen .fullscreen-bottom-overlay .stage-hover-controls .stage-hover-button {
  pointer-events: auto !important;
}

.visual-stage:fullscreen .fullscreen-bottom-overlay,
.visual-stage:fullscreen .fullscreen-top-hint {
  transition: opacity .24s ease, transform .24s ease !important;
  transition-delay: 0s !important;
}

.visual-stage:fullscreen.controls-hidden .fullscreen-bottom-overlay,
.visual-stage:fullscreen.controls-hidden .fullscreen-top-hint {
  opacity: 0 !important;
  transform: translateY(14px) !important;
  pointer-events: none !important;
}

@media (max-width: 900px) {
  .visual-stage:fullscreen .fullscreen-bottom-overlay .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden .fullscreen-bottom-overlay .stage-hover-controls,
  .visual-stage:fullscreen:hover .fullscreen-bottom-overlay .stage-hover-controls,
  .visual-stage:fullscreen:focus-within .fullscreen-bottom-overlay .stage-hover-controls,
  .visual-stage:fullscreen.stage-hover-controls-visible .fullscreen-bottom-overlay .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden:hover .fullscreen-bottom-overlay .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden:focus-within .fullscreen-bottom-overlay .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible .fullscreen-bottom-overlay .stage-hover-controls {
    transform: translateY(-4vh) scale(1) !important;
  }
}

.visual-stage:fullscreen .fullscreen-bottom-overlay,
.visual-stage:fullscreen .fullscreen-top-hint,
.visual-stage:fullscreen .stage-hover-controls {
  transition: opacity .24s ease, transform .24s ease !important;
  transition-delay: 0s !important;
}

.visual-stage:fullscreen .fullscreen-bottom-overlay .stage-hover-controls {
  position: fixed !important;
  inset: 0 !important;
  z-index: 2 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.visual-stage:fullscreen .fullscreen-bottom-overlay .stage-hover-controls .stage-hover-button {
  pointer-events: auto !important;
}

.visual-stage:fullscreen.controls-hidden .fullscreen-bottom-overlay .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:hover .fullscreen-bottom-overlay .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:focus-within .fullscreen-bottom-overlay .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible .fullscreen-bottom-overlay .stage-hover-controls {
  transform: translateY(-3vh) scale(1) !important;
}

@media (max-width: 900px) {
  .visual-stage:fullscreen.controls-hidden .fullscreen-bottom-overlay .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden:hover .fullscreen-bottom-overlay .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden:focus-within .fullscreen-bottom-overlay .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible .fullscreen-bottom-overlay .stage-hover-controls {
    transform: translateY(-4vh) scale(1) !important;
  }
}

.visual-stage:fullscreen > .stage-hover-controls,
.visual-stage:fullscreen:hover > .stage-hover-controls,
.visual-stage:fullscreen:focus-within > .stage-hover-controls,
.visual-stage:fullscreen.stage-hover-controls-visible > .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden > .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:hover > .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:focus-within > .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible > .stage-hover-controls {
  position: absolute !important;
  inset: 0 !important;
  z-index: 13 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  pointer-events: none !important;
  transition: opacity .24s ease !important;
  transform: translateY(-3vh) scale(1) !important;
}

.visual-stage:fullscreen > .stage-hover-controls .stage-hover-button {
  pointer-events: auto !important;
}

.visual-stage:fullscreen.controls-hidden > .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:hover > .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden:focus-within > .stage-hover-controls,
.visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible > .stage-hover-controls {
  opacity: 0 !important;
  transform: translateY(-3vh) scale(1) !important;
  pointer-events: none !important;
}

.visual-stage:fullscreen .fullscreen-bottom-overlay .stage-hover-controls {
  opacity: inherit !important;
  transform: none !important;
  transition: none !important;
}

@media (max-width: 900px) {
  .visual-stage:fullscreen > .stage-hover-controls,
  .visual-stage:fullscreen:hover > .stage-hover-controls,
  .visual-stage:fullscreen:focus-within > .stage-hover-controls,
  .visual-stage:fullscreen.stage-hover-controls-visible > .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden > .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden:hover > .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden:focus-within > .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible > .stage-hover-controls {
    transform: translateY(-4vh) scale(1) !important;
  }

  .visual-stage:fullscreen.controls-hidden > .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden:hover > .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden:focus-within > .stage-hover-controls,
  .visual-stage:fullscreen.controls-hidden.stage-hover-controls-visible > .stage-hover-controls {
    transform: translateY(-4vh) scale(1) !important;
  }
}

.stage-hover-button,
.stage-hover-button:hover,
.stage-hover-button:focus-visible,
.stage-hover-main,
.stage-hover-main:not(:disabled) {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  transition-property: opacity, transform, background-color, border-color, box-shadow !important;
  transition-duration: .24s, .24s, .24s, .24s, .24s !important;
  transition-timing-function: ease, ease, ease, ease, ease !important;
  transition-delay: 0s, 0s, 0s, 0s, 0s !important;
  will-change: opacity, transform !important;
}

.stage-hover-button {
  background:
    radial-gradient(circle at 34% 24%, rgba(255,255,255,.18), transparent 43%),
    linear-gradient(135deg, rgba(255,255,255,.12), rgba(255,255,255,.035)),
    rgba(12, 14, 24, .34) !important;
  border-color: rgba(255,255,255,.24) !important;
  box-shadow:
    0 14px 42px rgba(0,0,0,.25),
    inset 0 0 0 1px rgba(255,255,255,.06) !important;
}

.stage-hover-main:not(:disabled) {
  background:
    radial-gradient(circle at 34% 24%, rgba(255,255,255,.20), transparent 43%),
    linear-gradient(135deg, color-mix(in oklab, var(--brand) 30%, transparent), color-mix(in oklab, var(--brand-2) 28%, transparent)),
    rgba(12, 14, 24, .30) !important;
}

.stage-hover-button:hover,
.stage-hover-button:focus-visible {
  background:
    radial-gradient(circle at 34% 24%, rgba(255,255,255,.24), transparent 43%),
    linear-gradient(135deg, color-mix(in oklab, var(--brand) 32%, transparent), color-mix(in oklab, var(--brand-2) 25%, transparent)),
    rgba(12, 14, 24, .38) !important;
  box-shadow:
    0 16px 46px rgba(0,0,0,.30),
    inset 0 0 0 1px rgba(255,255,255,.08) !important;
}

.visual-stage:fullscreen > .stage-hover-controls .stage-hover-button,
.visual-stage:fullscreen > .stage-hover-controls .stage-hover-button:hover,
.visual-stage:fullscreen > .stage-hover-controls .stage-hover-button:focus-visible {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.mix-status-row {
  --mix-status-field-height: 56px;
  align-items: center !important;
}

.mix-status-row .mix-controls,
.mix-status-row .mix-status-action {
  align-items: center !important;
  height: var(--mix-status-field-height) !important;
  min-height: var(--mix-status-field-height) !important;
  max-height: var(--mix-status-field-height) !important;
}

.mix-status-row .mix-controls #mixStartButton,
.mix-status-row .mix-status-action #mixStartButton {
  height: var(--mix-status-field-height) !important;
  min-height: var(--mix-status-field-height) !important;
  max-height: var(--mix-status-field-height) !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  line-height: 1 !important;
}

.mix-status-card {
  height: var(--mix-status-field-height) !important;
  min-height: var(--mix-status-field-height) !important;
  max-height: var(--mix-status-field-height) !important;
  padding: .48rem .76rem !important;
  display: grid !important;
  grid-template-rows: auto minmax(0, 1fr) !important;
  align-content: center !important;
  justify-content: stretch !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}

.mix-status-card span {
  min-width: 0 !important;
  max-width: 100% !important;
  margin: 0 0 .16rem 0 !important;
  font-size: .74rem !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.mix-status-card strong {
  min-width: 0 !important;
  max-width: 100% !important;
  display: block !important;
  font-size: .92rem !important;
  line-height: 1.08 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
}

@media (max-width: 760px) {
  .mix-status-row {
    --mix-status-field-height: 54px;
  }
}

.now-playing-line {
  margin: .34rem 0 0 !important;
  color: color-mix(in oklab, var(--muted) 88%, var(--text)) !important;
  font-size: .9rem !important;
  line-height: 1.25 !important;
  max-width: min(100%, 920px) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.meta-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
}

.meta-grid span:last-child {
  grid-column: span 1 !important;
}

.fullscreen-now-playing {
  display: block !important;
  max-width: min(52vw, 760px) !important;
  color: rgba(255,255,255,.78) !important;
  font-size: clamp(.82rem, 1vw, .98rem) !important;
  line-height: 1.15 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

@media (max-width: 1180px) {
  .meta-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .meta-grid span:last-child {
    grid-column: 1 / -1 !important;
  }
}

@media (max-width: 760px) {
  .now-playing-line {
    font-size: .84rem !important;
  }
  .meta-grid {
    grid-template-columns: 1fr !important;
  }
}

.now-playing-badge {
  position: absolute !important;
  right: 1rem !important;
  bottom: 1rem !important;
  z-index: 3 !important;
  max-width: min(48%, 520px) !important;
  min-height: 38px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  border: 1px solid var(--line) !important;
  border-radius: 999px !important;
  background: rgba(0,0,0,.45) !important;
  color: white !important;
  padding: .55rem .8rem !important;
  font-size: .86rem !important;
  font-weight: 750 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  box-sizing: border-box !important;
}

.visual-stage:fullscreen .now-playing-badge {
  right: 1.5rem !important;
  top: 1.35rem !important;
  bottom: auto !important;
  max-width: min(42vw, 620px) !important;
  background: rgba(0,0,0,.42) !important;
  border-color: rgba(255,255,255,.18) !important;
  color: rgba(255,255,255,.9) !important;
}

.visual-stage:fullscreen.controls-hidden .now-playing-badge {
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity .24s ease !important;
}

@media (max-width: 760px) {
  .now-playing-badge {
    right: .75rem !important;
    bottom: .75rem !important;
    max-width: min(56%, 360px) !important;
    min-height: 34px !important;
    padding: .45rem .62rem !important;
    font-size: .76rem !important;
  }

  .visual-stage:fullscreen .now-playing-badge {
    top: calc(env(safe-area-inset-top) + .75rem) !important;
    right: calc(env(safe-area-inset-right) + .75rem) !important;
    max-width: 46vw !important;
  }
}

.visual-stage .now-playing-badge {
  z-index: 26 !important;
  right: clamp(.65rem, 1.4vw, 1.15rem) !important;
  left: auto !important;
  bottom: 1rem !important;
  top: auto !important;
  max-width: min(62%, 620px) !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  transition: bottom .22s ease, opacity .22s ease, transform .22s ease !important;
}

.hero-player:hover .visual-stage:not(:fullscreen) .now-playing-badge,
.hero-player:focus-within .visual-stage:not(:fullscreen) .now-playing-badge {
  bottom: 5.5rem !important;
}

.visual-stage:fullscreen .now-playing-badge {
  right: clamp(.65rem, 1.4vw, 1.15rem) !important;
  left: auto !important;
  top: auto !important;
  bottom: 5.5rem !important;
  max-width: min(62%, 620px) !important;
  opacity: 1 !important;
  transition: bottom .22s ease, opacity .24s ease, transform .24s ease !important;
}

.visual-stage:fullscreen.controls-hidden .now-playing-badge {
  right: clamp(.65rem, 1.4vw, 1.15rem) !important;
  left: auto !important;
  top: auto !important;
  bottom: 1.35rem !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}

@media (max-width: 1200px) {
  .visual-stage:fullscreen .now-playing-badge {
    bottom: 8.4rem !important;
    max-width: min(58%, 520px) !important;
  }
  .visual-stage:fullscreen.controls-hidden .now-playing-badge {
    bottom: 1.35rem !important;
  }
}

@media (max-width: 900px) {
  .visual-stage:not(:fullscreen) .now-playing-badge {
    right: .8rem !important;
    max-width: calc(100% - 1.6rem) !important;
  }

  .hero-player:hover .visual-stage:not(:fullscreen) .now-playing-badge,
  .hero-player:focus-within .visual-stage:not(:fullscreen) .now-playing-badge {
    bottom: 11.05rem !important;
  }

  .visual-stage:fullscreen .now-playing-badge {
    right: .8rem !important;
    left: auto !important;
    top: auto !important;
    bottom: 11.05rem !important;
    max-width: calc(100% - 1.6rem) !important;
  }

  .visual-stage:fullscreen.controls-hidden .now-playing-badge {
    right: .8rem !important;
    bottom: 1.45rem !important;
  }
}

.now-playing-badge.is-hidden,
.now-playing-line.is-hidden,
.fullscreen-now-playing.is-hidden,
.now-playing-badge[hidden],
.now-playing-line[hidden],
.fullscreen-now-playing[hidden] {
  display: none !important;
}

.station-card.active,
.station-card[aria-current="true"] {
  margin: 0 !important;
  border-width: 1px !important;
  outline: 0 !important;
  box-sizing: border-box !important;
  transform: none !important;
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--good) 32%, transparent) !important;
  overflow: hidden !important;
}

.station-card.active:hover,
.station-card[aria-current="true"]:hover {
  transform: none !important;
}

.station-card.active::before,
.station-card[aria-current="true"]::before {
  display: none !important;
  content: none !important;
}

.tabs .tab {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: .46rem !important;
  min-width: 0 !important;
  white-space: nowrap !important;
}

.tabs .tab-label {
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.tabs .tab-count {
  flex: 0 0 auto !important;
  min-width: 1.9rem !important;
  height: 1.9rem !important;
  padding: 0 .48rem !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 999px !important;
  border: 1px solid color-mix(in oklab, var(--brand) 45%, transparent) !important;
  background: linear-gradient(135deg, var(--brand), var(--brand-2)) !important;
  color: #fff !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  box-shadow: 0 8px 20px rgba(255, 56, 92, .22) !important;
}

.tabs .tab:not(.active) .tab-count {
  opacity: .82 !important;
  box-shadow: none !important;
}

@media (max-width: 760px) {
  .tabs .tab {
    gap: .38rem !important;
    padding-inline: .62rem !important;
  }

  .tabs .tab-count {
    min-width: 1.7rem !important;
    height: 1.7rem !important;
    padding-inline: .42rem !important;
    font-size: .72rem !important;
  }
}

.tabs .tab {
  align-items: center !important;
  line-height: 1 !important;
}

.tabs .tab-count {
  min-width: 1.55rem !important;
  height: 1.55rem !important;
  padding: 0 .36rem !important;
  font-size: .68rem !important;
  line-height: 1 !important;
  align-self: center !important;
  transform: translateY(0) !important;
  box-shadow: 0 6px 16px rgba(255, 56, 92, .18) !important;
}

.tabs .tab-label {
  line-height: 1 !important;
  align-self: center !important;
}

@media (max-width: 760px) {
  .tabs .tab-count {
    min-width: 1.42rem !important;
    height: 1.42rem !important;
    padding-inline: .32rem !important;
    font-size: .64rem !important;
  }
}

#resultCount {
  display: block !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.tabs .tab-count {
  cursor: help !important;
}

.tabs .tab-count {
  cursor: default !important;
}

.tabs {
  overflow: visible !important;
}

.tabs .tab {
  overflow: visible !important;
  align-items: center !important;
  line-height: 1.25 !important;
  min-height: 42px !important;
}

.tabs .tab-label {
  line-height: 1.25 !important;
  overflow: visible !important;
  padding-bottom: .03em !important;
}

.tabs .tab-count {
  align-self: center !important;
  transform: none !important;
}

.list-toolbar {
  padding-left: .75rem !important;
  padding-right: .75rem !important;
  align-items: center !important;
}

.toolbar-buttons.toolbar-menu-wrap {
  position: relative !important;
  display: flex !important;
  justify-content: flex-end !important;
  align-items: center !important;
  margin-left: auto !important;
  min-width: max-content !important;
}

.list-manage-menu {
  position: relative !important;
  display: inline-flex !important;
  justify-content: flex-end !important;
  align-items: center !important;
}

.list-manage-menu > summary {
  list-style: none !important;
}

.list-manage-menu > summary::-webkit-details-marker {
  display: none !important;
}

.list-manage-trigger {
  cursor: pointer !important;
  min-width: 128px !important;
  justify-content: center !important;
}

.list-manage-trigger::after {
  content: "▾" !important;
  display: inline-block !important;
  margin-left: .45rem !important;
  font-size: .78em !important;
  opacity: .82 !important;
}

.list-manage-menu[open] .list-manage-trigger::after {
  transform: rotate(180deg) !important;
}

.list-manage-popover {
  position: absolute !important;
  right: 0 !important;
  top: calc(100% + .46rem) !important;
  z-index: 55 !important;
  width: min(260px, calc(100vw - 2rem)) !important;
  display: grid !important;
  gap: .42rem !important;
  padding: .58rem !important;
  border: 1px solid color-mix(in oklab, var(--brand) 28%, var(--line)) !important;
  border-radius: 18px !important;
  background:
    radial-gradient(circle at top right, color-mix(in oklab, var(--brand) 15%, transparent), transparent 48%),
    color-mix(in oklab, var(--panel-solid) 96%, transparent) !important;
  box-shadow: 0 22px 70px rgba(0,0,0,.42) !important;
}

.list-manage-popover .soft-button,
.list-manage-popover .import-label {
  width: 100% !important;
  justify-content: flex-start !important;
  min-height: 38px !important;
  padding: .52rem .72rem !important;
  text-align: left !important;
}

@media (max-width: 760px) {
  .list-toolbar {
    padding-left: .6rem !important;
    padding-right: .6rem !important;
  }

  .toolbar-buttons.toolbar-menu-wrap,
  .list-manage-menu,
  .list-manage-trigger {
    width: 100% !important;
  }

  .list-manage-popover {
    left: 0 !important;
    right: 0 !important;
    width: auto !important;
  }
}

.toolbar-buttons.toolbar-menu-wrap {
  min-width: 0 !important;
}

.list-manage-menu {
  width: max-content !important;
  min-width: 0 !important;
}

.list-manage-trigger {
  width: auto !important;
  min-width: 0 !important;
  max-width: max-content !important;
  padding-inline: .78rem !important;
  gap: .42rem !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: nowrap !important;
}

.list-manage-trigger::after {
  margin-left: .18rem !important;
  line-height: 1 !important;
}

.list-manage-popover {
  min-width: 246px !important;
}

@media (max-width: 760px) {
  .toolbar-buttons.toolbar-menu-wrap {
    justify-content: flex-end !important;
  }

  .list-manage-menu {
    width: max-content !important;
  }

  .list-manage-trigger {
    width: auto !important;
    min-width: 0 !important;
  }

  .list-manage-popover {
    min-width: min(246px, calc(100vw - 1.2rem)) !important;
  }
}

.now-playing-badge {
  gap: .42rem !important;
}

.now-playing-badge .now-playing-text {
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.now-playing-badge .now-playing-separator {
  flex: 0 0 auto !important;
  opacity: .68 !important;
}

.now-playing-badge .now-playing-link {
  flex: 0 0 auto !important;
  color: #fff !important;
  text-decoration: underline !important;
  text-decoration-color: rgba(255,255,255,.42) !important;
  text-underline-offset: .16em !important;
  font-weight: 900 !important;
  white-space: nowrap !important;
}

.now-playing-badge .now-playing-link:hover,
.now-playing-badge .now-playing-link:focus-visible {
  text-decoration-color: currentColor !important;
  outline: none !important;
}

@media (max-width: 760px) {
  .now-playing-badge .now-playing-link:nth-of-type(n+2),
  .now-playing-badge .now-playing-separator:nth-of-type(n+2) {
    display: none !important;
  }
}

.station-detail-modal .detail-modal-heading {
  display: flex;
  align-items: baseline;
  gap: .72rem;
  padding-right: 3.2rem;
  margin: 0 0 1rem;
  min-width: 0;
}

.station-detail-modal .detail-modal-heading .eyebrow {
  margin: 0;
  flex: 0 0 auto;
}

.station-detail-modal .detail-modal-heading-title {
  color: var(--text);
  font-weight: 900;
  font-size: clamp(1rem, 1.6vw, 1.18rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  min-width: 0;
}

.station-detail-modal .detail-head {
  margin-top: 0 !important;
}

@media (max-width: 760px) {
  .station-detail-modal .detail-modal-heading {
    gap: .5rem;
    padding-right: 2.8rem;
    margin-bottom: .85rem;
    flex-wrap: wrap;
  }
}

.station-detail-modal .detail-modal-heading {
  align-items: flex-start !important;
  gap: .78rem !important;
}

.station-detail-modal .detail-modal-heading .eyebrow {
  line-height: 1 !important;
  padding-top: .08rem !important;
}

.station-detail-modal .detail-modal-heading-title {
  display: inline-block !important;
  padding-top: .28rem !important;
  line-height: 1.05 !important;
}

@media (max-width: 760px) {
  .station-detail-modal .detail-modal-heading-title {
    padding-top: .24rem !important;
  }
}

.station-detail-modal .detail-modal-heading {
  align-items: flex-start !important;
  gap: .72rem !important;
}

.station-detail-modal .detail-modal-heading .eyebrow {
  padding-top: .06rem !important;
  line-height: 1 !important;
}

.station-detail-modal .detail-modal-heading-title {
  padding-top: .13rem !important;
  line-height: 1.08 !important;
}

@media (max-width: 760px) {
  .station-detail-modal .detail-modal-heading-title {
    padding-top: .11rem !important;
  }
}

.station-detail-modal .detail-modal-heading-title {
  padding-top: 0 !important;
  transform: translateY(-2px) !important;
}

.genre-overview-title-copy h2 {
  transform: translateY(3px) !important;
}

.visual-stage:not(:fullscreen):hover > .stage-control-row,
.visual-stage:not(:fullscreen):focus-within > .stage-control-row {
  opacity: 1 !important;
  transform: translateY(0) !important;
  pointer-events: auto !important;
}

.visual-stage:not(:fullscreen):not(:hover):not(:focus-within) > .stage-control-row {
  opacity: 0 !important;
  transform: translateY(12px) !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen):hover .status-pill,
.visual-stage:not(:fullscreen):focus-within .status-pill {
  bottom: 5.5rem !important;
}

.hero-player:hover .visual-stage:not(:fullscreen):not(:hover):not(:focus-within) .status-pill,
.hero-player:focus-within .visual-stage:not(:fullscreen):not(:hover):not(:focus-within) .status-pill {
  bottom: 1.35rem !important;
}

.visual-stage:not(:fullscreen):hover .now-playing-badge,
.visual-stage:not(:fullscreen):focus-within .now-playing-badge {
  bottom: 5.5rem !important;
}

.hero-player:hover .visual-stage:not(:fullscreen):not(:hover):not(:focus-within) .now-playing-badge,
.hero-player:focus-within .visual-stage:not(:fullscreen):not(:hover):not(:focus-within) .now-playing-badge {
  bottom: 1rem !important;
}

@media (max-width: 900px) {
  .visual-stage:not(:fullscreen):hover .status-pill,
  .visual-stage:not(:fullscreen):focus-within .status-pill {
    bottom: 11.05rem !important;
  }

  .hero-player:hover .visual-stage:not(:fullscreen):not(:hover):not(:focus-within) .status-pill,
  .hero-player:focus-within .visual-stage:not(:fullscreen):not(:hover):not(:focus-within) .status-pill {
    bottom: 1.45rem !important;
  }

  .visual-stage:not(:fullscreen):hover .now-playing-badge,
  .visual-stage:not(:fullscreen):focus-within .now-playing-badge {
    bottom: 11.05rem !important;
  }

  .hero-player:hover .visual-stage:not(:fullscreen):not(:hover):not(:focus-within) .now-playing-badge,
  .hero-player:focus-within .visual-stage:not(:fullscreen):not(:hover):not(:focus-within) .now-playing-badge {
    bottom: .75rem !important;
  }
}

/* Senderdetails-Popup: fest mittig im Viewport, Hintergrund bleibt scrollbar */
html:has(.modal.station-details-dialog[open]),
body:has(.modal.station-details-dialog[open]) {
  overflow: auto !important;
}

.modal.station-details-dialog[open] {
  position: fixed !important;
  inset: 50% auto auto 50% !important;
  transform: translate(-50%, -50%) !important;
  margin: 0 !important;
  width: min(1120px, calc(100vw - 2rem)) !important;
  max-width: min(1120px, calc(100vw - 2rem)) !important;
  max-height: min(860px, calc(100dvh - 2rem)) !important;
  overflow: auto !important;
  overscroll-behavior: contain !important;
  scrollbar-gutter: stable !important;
}

.modal.station-details-dialog[open]::backdrop {
  background: rgba(0, 0, 0, .56) !important;
  backdrop-filter: blur(8px) !important;
}

@supports not (height: 100dvh) {
  .modal.station-details-dialog[open] {
    max-height: min(860px, calc(100vh - 2rem)) !important;
  }
}

@media (max-width: 760px) {
  .modal.station-details-dialog[open] {
    width: calc(100vw - 1rem) !important;
    max-width: calc(100vw - 1rem) !important;
    max-height: calc(100dvh - 1rem) !important;
  }
}


/* v202: Player-Aktionen ohne geladenen Sender wirklich deaktivieren */
.stage-transport button:disabled,
.fullscreen-transport button:disabled,
.action-row button:disabled,
.stage-hover-controls button:disabled,
.mini-player button:disabled,
button.is-unavailable {
  cursor: not-allowed !important;
  pointer-events: auto !important;
}

.stage-transport button:disabled,
.fullscreen-transport button:disabled,
.action-row button:disabled,
.stage-hover-controls button:disabled {
  opacity: .55 !important;
  filter: saturate(.75) !important;
}

.stage-transport #sleepButton:disabled,
.fullscreen-transport #fullscreenSleepButton:disabled,
.player-shortcuts-button:disabled {
  cursor: pointer !important;
}


/* v203: Deaktivierte Player-/Aktionsbuttons dürfen nicht hover-liften oder roten Rand bekommen */
button:disabled,
button[aria-disabled="true"],
button.is-unavailable {
  cursor: not-allowed !important;
}

.icon-button:disabled:hover,
.soft-button:disabled:hover,
.primary-button:disabled:hover,
.favorite-main:disabled:hover,
.star-button:disabled:hover,
.action-row button:disabled:hover,
.stage-transport button:disabled:hover,
.fullscreen-transport button:disabled:hover,
.stage-hover-controls button:disabled:hover,
button[aria-disabled="true"]:hover,
button.is-unavailable:hover {
  transform: none !important;
  border-color: var(--line) !important;
  box-shadow: none !important;
}

.primary-button:disabled:hover,
.primary-button.is-unavailable:hover {
  border-color: transparent !important;
  box-shadow: none !important;
}

.action-row button:disabled,
.stage-transport button:disabled,
.fullscreen-transport button:disabled,
.stage-hover-controls button:disabled,
.action-row button.is-unavailable,
.stage-transport button.is-unavailable,
.fullscreen-transport button.is-unavailable,
.stage-hover-controls button.is-unavailable {
  pointer-events: auto !important;
  transition: none !important;
}

.action-row button:disabled:hover,
.stage-transport button:disabled:hover,
.fullscreen-transport button:disabled:hover,
.stage-hover-controls button:disabled:hover,
.action-row button.is-unavailable:hover,
.stage-transport button.is-unavailable:hover,
.fullscreen-transport button.is-unavailable:hover,
.stage-hover-controls button.is-unavailable:hover {
  background-color: inherit !important;
}

/* v203: Sleep-Timer-Popup an die übrigen Popup-Überschriften und kompaktere Breite anpassen */
.modal[data-modal-type="sleep-timer"] {
  width: min(640px, calc(100vw - 2rem)) !important;
  max-width: min(640px, calc(100vw - 2rem)) !important;
}

.sleep-modal {
  max-width: none !important;
  width: 100% !important;
  gap: .82rem !important;
}

.sleep-modal-heading {
  display: flex !important;
  align-items: flex-start !important;
  gap: .72rem !important;
  margin: 0 0 .65rem !important;
}

.sleep-modal-heading .eyebrow {
  margin: 0 !important;
  line-height: 1 !important;
  padding-top: .05rem !important;
  flex: 0 0 auto !important;
}

.sleep-modal-heading h2 {
  margin: 0 !important;
  color: var(--text) !important;
  font-size: clamp(1.02rem, 1.9vw, 1.28rem) !important;
  line-height: 1.06 !important;
  font-weight: 900 !important;
  letter-spacing: -0.02em !important;
  transform: translateY(-2px) !important;
}

.sleep-intro {
  margin: 0 0 .15rem !important;
  color: var(--muted) !important;
}

.sleep-current {
  text-align: left !important;
}

.sleep-presets {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

.sleep-actions {
  justify-content: flex-start !important;
}

@media (max-width: 760px) {
  .modal[data-modal-type="sleep-timer"] {
    width: calc(100vw - 1rem) !important;
    max-width: calc(100vw - 1rem) !important;
  }

  .sleep-modal-heading {
    gap: .52rem !important;
    flex-wrap: wrap !important;
  }

  .sleep-modal-heading h2 {
    transform: translateY(-1px) !important;
  }
}


/* v204: Titelbadge-Höhe an Live-Badge angleichen, ohne Player-Overlay/Cursor-Verhalten zu verändern */
.visual-stage .now-playing-badge {
  min-height: 42px !important;
  display: inline-flex !important;
  align-items: center !important;
  padding-top: .62rem !important;
  padding-bottom: .62rem !important;
  line-height: 1.05 !important;
  border-radius: 999px !important;
}

.visual-stage .now-playing-badge .now-playing-text,
.visual-stage .now-playing-badge .now-playing-separator,
.visual-stage .now-playing-badge .now-playing-link {
  line-height: 1.05 !important;
}


/* v205: Titelbadge nur sichtbar stylen, wenn wirklich ein Sender/Titelbereich aktiv ist */
.visual-stage .now-playing-badge[hidden],
.visual-stage .now-playing-badge.is-hidden {
  display: none !important;
  min-height: 0 !important;
  padding: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.visual-stage .now-playing-badge:not([hidden]):not(.is-hidden) {
  min-height: 42px !important;
  display: inline-flex !important;
  align-items: center !important;
  padding-top: .62rem !important;
  padding-bottom: .62rem !important;
  line-height: 1.05 !important;
  border-radius: 999px !important;
}


/* v206: Badge-/Meta-Flächen zeigen keinen Textcursor */
.badge,
.tag,
.mini-badge,
.status-pill,
.now-playing-badge,
.now-playing-badge .now-playing-text,
.now-playing-badge .now-playing-separator,
.detail-status-badge,
.queue-live-badge,
.queue-next-badge,
.queue-plan-badge,
.station-mode,
.meta-grid span,
.tag-row .tag,
.station-card-badges span,
.station-card-tags span,
.detail-empty,
.section-summary-chevron,
.section-title .eyebrow,
.section-title h2,
.detail-section-head h3,
.detail-section-head small {
  cursor: default !important;
  user-select: none !important;
}

.now-playing-badge .now-playing-link,
.now-playing-badge .now-playing-link *,
button:not(:disabled):not(.is-unavailable),
button:not(:disabled):not(.is-unavailable) * {
  cursor: pointer !important;
}

/* v206: Deaktivierte Playerbar-Buttons verändern bei Mouseover gar nichts mehr */
.stage-transport button:disabled,
.stage-transport button.is-unavailable,
.fullscreen-transport button:disabled,
.fullscreen-transport button.is-unavailable,
.stage-hover-controls button:disabled,
.stage-hover-controls button.is-unavailable,
.action-row button:disabled,
.action-row button.is-unavailable {
  cursor: not-allowed !important;
  pointer-events: auto !important;
  transition: none !important;
  transform: none !important;
  box-shadow: none !important;
  filter: none !important;
}

.stage-transport .soft-button:disabled,
.stage-transport .soft-button.is-unavailable,
.fullscreen-transport .soft-button:disabled,
.fullscreen-transport .soft-button.is-unavailable,
.action-row .soft-button:disabled,
.action-row .soft-button.is-unavailable {
  background: var(--panel-strong) !important;
  background-color: var(--panel-strong) !important;
  border-color: var(--line) !important;
  color: var(--text) !important;
}

.stage-transport .soft-button:disabled:hover,
.stage-transport .soft-button.is-unavailable:hover,
.fullscreen-transport .soft-button:disabled:hover,
.fullscreen-transport .soft-button.is-unavailable:hover,
.action-row .soft-button:disabled:hover,
.action-row .soft-button.is-unavailable:hover {
  background: var(--panel-strong) !important;
  background-color: var(--panel-strong) !important;
  border-color: var(--line) !important;
  color: var(--text) !important;
  transform: none !important;
  box-shadow: none !important;
  filter: none !important;
}

.stage-transport .primary-button:disabled,
.stage-transport .primary-button.is-unavailable,
.fullscreen-transport .primary-button:disabled,
.fullscreen-transport .primary-button.is-unavailable,
.stage-hover-controls .primary-button:disabled,
.stage-hover-controls .primary-button.is-unavailable {
  background: linear-gradient(135deg, var(--brand), var(--brand-2)) !important;
  background-color: transparent !important;
  border-color: transparent !important;
  color: #fff !important;
  box-shadow: 0 12px 30px rgba(255, 56, 92, .24) !important;
  transform: none !important;
  filter: none !important;
}

.stage-transport .primary-button:disabled:hover,
.stage-transport .primary-button.is-unavailable:hover,
.fullscreen-transport .primary-button:disabled:hover,
.fullscreen-transport .primary-button.is-unavailable:hover,
.stage-hover-controls .primary-button:disabled:hover,
.stage-hover-controls .primary-button.is-unavailable:hover {
  background: linear-gradient(135deg, var(--brand), var(--brand-2)) !important;
  background-color: transparent !important;
  border-color: transparent !important;
  color: #fff !important;
  box-shadow: 0 12px 30px rgba(255, 56, 92, .24) !important;
  transform: none !important;
  filter: none !important;
}

/* Sleep-Timer und Tastatur-Hilfe bleiben weiterhin normal bedienbar */
.stage-transport #sleepButton:not(:disabled):hover,
.fullscreen-transport #fullscreenSleepButton:not(:disabled):hover,
.stage-transport .player-shortcuts-button:not(:disabled):hover,
.fullscreen-transport .player-shortcuts-button:not(:disabled):hover {
  transform: translateY(-1px) !important;
}


/* v207: Tastatur-Popup mit Seitenüberschrift und kompakter Breite */
.modal[data-modal-type="shortcuts"] {
  width: min(600px, calc(100vw - 2rem)) !important;
  max-width: min(600px, calc(100vw - 2rem)) !important;
}

.shortcuts-modal {
  display: grid !important;
  gap: .92rem !important;
  width: 100% !important;
}

.shortcuts-modal-heading {
  display: flex !important;
  align-items: flex-start !important;
  gap: .72rem !important;
  margin: 0 0 .45rem !important;
}

.shortcuts-modal-heading .eyebrow {
  margin: 0 !important;
  line-height: 1 !important;
  padding-top: .05rem !important;
  flex: 0 0 auto !important;
}

.shortcuts-modal-heading h2 {
  margin: 0 !important;
  color: var(--text) !important;
  font-size: clamp(1.02rem, 1.9vw, 1.28rem) !important;
  line-height: 1.06 !important;
  font-weight: 900 !important;
  letter-spacing: -0.02em !important;
  transform: translateY(-2px) !important;
}

.shortcuts-modal p {
  margin: 0 !important;
  color: var(--muted) !important;
  line-height: 1.62 !important;
}

.shortcuts-modal kbd {
  cursor: default !important;
  user-select: none !important;
}

@media (max-width: 760px) {
  .modal[data-modal-type="shortcuts"] {
    width: calc(100vw - 1rem) !important;
    max-width: calc(100vw - 1rem) !important;
  }

  .shortcuts-modal-heading {
    gap: .52rem !important;
    flex-wrap: wrap !important;
  }

  .shortcuts-modal-heading h2 {
    transform: translateY(-1px) !important;
  }
}


/* v214: Vollbild-Mittelbuttons nur bei geladenem Sender sichtbar; Klicklogik bleibt stabil wie in v207 */
.visual-stage:fullscreen:not(.stage-hover-controls-available) .stage-hover-controls {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.visual-stage:fullscreen.stage-hover-controls-available .stage-hover-controls {
  visibility: visible !important;
}

.visual-stage:fullscreen.stage-hover-controls-available .stage-hover-controls .stage-hover-button:not(:disabled) {
  pointer-events: auto !important;
  cursor: pointer !important;
}

.visual-stage:fullscreen .stage-hover-controls .stage-hover-button svg {
  pointer-events: none !important;
}


/* v216: Kompakte Player-Buttons bei schmaler Playerbreite, ohne bestehende Klicklogik zu ändern */
.visual-stage {
  container-type: inline-size !important;
}

#previousButton,
#nextButton,
#randomButton,
#sleepButton,
#muteButton,
#fullscreenStageButton,
#fullscreenPreviousButton,
#fullscreenNextButton,
#fullscreenRandomButton,
#fullscreenSleepButton,
#fullscreenMuteButton,
#fullscreenExitButton {
  overflow: hidden !important;
}

@container (max-width: 980px) {
  .visual-stage:not(:fullscreen) > .stage-control-row {
    grid-template-columns: minmax(270px, 1.08fr) minmax(210px, .9fr) minmax(190px, .75fr) auto !important;
    gap: .45rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
    flex-wrap: nowrap !important;
  }

  .visual-stage:not(:fullscreen) #previousButton,
  .visual-stage:not(:fullscreen) #nextButton,
  .visual-stage:not(:fullscreen) #randomButton,
  .visual-stage:not(:fullscreen) #sleepButton,
  .visual-stage:not(:fullscreen) #muteButton,
  .visual-stage:not(:fullscreen) #fullscreenStageButton {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    flex: 0 0 var(--player-control-height-unified) !important;
    padding-inline: 0 !important;
    font-size: 0 !important;
    gap: 0 !important;
  }

  .visual-stage:not(:fullscreen) #previousButton::before,
  .visual-stage:not(:fullscreen) #nextButton::before,
  .visual-stage:not(:fullscreen) #randomButton::before,
  .visual-stage:not(:fullscreen) #sleepButton::before,
  .visual-stage:not(:fullscreen) #muteButton::before,
  .visual-stage:not(:fullscreen) #fullscreenStageButton::before {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    font-size: 1.05rem !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    pointer-events: none !important;
  }

  .visual-stage:not(:fullscreen) #previousButton::before { content: '‹' !important; font-size: 1.35rem !important; }
  .visual-stage:not(:fullscreen) #nextButton::before { content: '›' !important; font-size: 1.35rem !important; }
  .visual-stage:not(:fullscreen) #randomButton::before { content: '⇄' !important; }
  .visual-stage:not(:fullscreen) #sleepButton::before { content: '◷' !important; }
  .visual-stage:not(:fullscreen) #muteButton::before { content: '🔊' !important; font-size: .98rem !important; }
  .visual-stage:not(:fullscreen) #muteButton[aria-pressed="true"]::before { content: '🔇' !important; }
  .visual-stage:not(:fullscreen) #fullscreenStageButton::before { content: '⛶' !important; }
  .visual-stage:not(:fullscreen) #fullscreenStageButton[aria-pressed="true"]::before { content: '⤢' !important; }
}

@media (max-width: 1380px) {
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
    flex-wrap: nowrap !important;
  }

  .visual-stage:not(:fullscreen) #previousButton,
  .visual-stage:not(:fullscreen) #nextButton,
  .visual-stage:not(:fullscreen) #randomButton,
  .visual-stage:not(:fullscreen) #sleepButton,
  .visual-stage:not(:fullscreen) #muteButton,
  .visual-stage:not(:fullscreen) #fullscreenStageButton {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    flex: 0 0 var(--player-control-height-unified) !important;
    padding-inline: 0 !important;
    font-size: 0 !important;
    gap: 0 !important;
  }

  .visual-stage:not(:fullscreen) #previousButton::before,
  .visual-stage:not(:fullscreen) #nextButton::before,
  .visual-stage:not(:fullscreen) #randomButton::before,
  .visual-stage:not(:fullscreen) #sleepButton::before,
  .visual-stage:not(:fullscreen) #muteButton::before,
  .visual-stage:not(:fullscreen) #fullscreenStageButton::before {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    font-size: 1.05rem !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    pointer-events: none !important;
  }

  .visual-stage:not(:fullscreen) #previousButton::before { content: '‹' !important; font-size: 1.35rem !important; }
  .visual-stage:not(:fullscreen) #nextButton::before { content: '›' !important; font-size: 1.35rem !important; }
  .visual-stage:not(:fullscreen) #randomButton::before { content: '⇄' !important; }
  .visual-stage:not(:fullscreen) #sleepButton::before { content: '◷' !important; }
  .visual-stage:not(:fullscreen) #muteButton::before { content: '🔊' !important; font-size: .98rem !important; }
  .visual-stage:not(:fullscreen) #muteButton[aria-pressed="true"]::before { content: '🔇' !important; }
  .visual-stage:not(:fullscreen) #fullscreenStageButton::before { content: '⛶' !important; }
  .visual-stage:not(:fullscreen) #fullscreenStageButton[aria-pressed="true"]::before { content: '⤢' !important; }
}

@media (max-width: 1100px) {
  .visual-stage:fullscreen .fullscreen-transport #fullscreenPreviousButton,
  .visual-stage:fullscreen .fullscreen-transport #fullscreenNextButton,
  .visual-stage:fullscreen .fullscreen-transport #fullscreenRandomButton,
  .visual-stage:fullscreen .fullscreen-transport #fullscreenSleepButton,
  .visual-stage:fullscreen .fullscreen-right-controls #fullscreenMuteButton,
  .visual-stage:fullscreen .fullscreen-right-controls #fullscreenExitButton {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    flex: 0 0 var(--player-control-height-unified) !important;
    padding-inline: 0 !important;
    font-size: 0 !important;
    gap: 0 !important;
  }

  .visual-stage:fullscreen .fullscreen-transport #fullscreenPreviousButton::before,
  .visual-stage:fullscreen .fullscreen-transport #fullscreenNextButton::before,
  .visual-stage:fullscreen .fullscreen-transport #fullscreenRandomButton::before,
  .visual-stage:fullscreen .fullscreen-transport #fullscreenSleepButton::before,
  .visual-stage:fullscreen .fullscreen-right-controls #fullscreenMuteButton::before,
  .visual-stage:fullscreen .fullscreen-right-controls #fullscreenExitButton::before {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    font-size: 1.05rem !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    pointer-events: none !important;
  }

  .visual-stage:fullscreen #fullscreenPreviousButton::before { content: '‹' !important; font-size: 1.35rem !important; }
  .visual-stage:fullscreen #fullscreenNextButton::before { content: '›' !important; font-size: 1.35rem !important; }
  .visual-stage:fullscreen #fullscreenRandomButton::before { content: '⇄' !important; }
  .visual-stage:fullscreen #fullscreenSleepButton::before { content: '◷' !important; }
  .visual-stage:fullscreen #fullscreenMuteButton::before { content: '🔊' !important; font-size: .98rem !important; }
  .visual-stage:fullscreen #fullscreenMuteButton[aria-pressed="true"]::before { content: '🔇' !important; }
  .visual-stage:fullscreen #fullscreenExitButton::before { content: '⤢' !important; }
}


/* v217: Variante/Qualität im Player als zusammenhängende Gruppe mit kompaktem Symbol bei Platzmangel */
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality,
.visual-stage:fullscreen .fullscreen-quality {
  display: grid !important;
  grid-template-columns: max-content minmax(0, 1fr) !important;
  align-items: center !important;
  gap: 0 !important;
  min-width: 0 !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label,
.visual-stage:fullscreen .fullscreen-quality > span {
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-sizing: border-box !important;
  padding: 0 .72rem !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  border-right: 0 !important;
  border-radius: 999px 0 0 999px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025)),
    rgba(20,25,38,.96) !important;
  color: rgba(255,255,255,.86) !important;
  font-size: .78rem !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  cursor: pointer !important;
  user-select: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-shell,
.visual-stage:fullscreen .fullscreen-quality .variant-select-shell {
  min-width: 0 !important;
  width: 100% !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button,
.visual-stage:fullscreen .fullscreen-quality .variant-select-button {
  border-left: 0 !important;
  border-radius: 0 999px 999px 0 !important;
  min-width: 0 !important;
  width: 100% !important;
  padding-inline: .72rem 1.9rem !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality:has(select:disabled) > label,
.visual-stage:fullscreen .fullscreen-quality:has(select:disabled) > span {
  opacity: .58 !important;
  cursor: not-allowed !important;
}

@container (max-width: 980px) {
  .visual-stage:not(:fullscreen) > .stage-control-row {
    grid-template-columns: minmax(270px, 1fr) minmax(150px, .58fr) minmax(170px, .68fr) auto !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
    grid-template-columns: var(--player-control-height-unified) minmax(0, 1fr) !important;
    max-width: 210px !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    padding: 0 !important;
    font-size: 0 !important;
    overflow: hidden !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label::before {
    content: '▦' !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    font-size: 1rem !important;
    line-height: 1 !important;
    font-weight: 900 !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
    padding-left: .56rem !important;
    padding-right: 1.55rem !important;
    font-size: .78rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::after {
    right: .62rem !important;
  }
}

@media (max-width: 1100px) {
  .visual-stage:fullscreen .fullscreen-quality {
    grid-template-columns: var(--player-control-height-unified) minmax(0, 1fr) !important;
    min-width: 150px !important;
  }

  .visual-stage:fullscreen .fullscreen-quality > span {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    padding: 0 !important;
    font-size: 0 !important;
    overflow: hidden !important;
  }

  .visual-stage:fullscreen .fullscreen-quality > span::before {
    content: '▦' !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    font-size: 1rem !important;
    line-height: 1 !important;
    font-weight: 900 !important;
  }

  .visual-stage:fullscreen .fullscreen-quality .variant-select-button {
    padding-left: .56rem !important;
    padding-right: 1.55rem !important;
    font-size: .78rem !important;
  }

  .visual-stage:fullscreen .fullscreen-quality .variant-select-button::after {
    right: .62rem !important;
  }
}


/* v218: Variante/Qualität normal wieder getrennt; kompakt erst bei knapper Playerbreite als Symbolbutton */
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
  display: grid !important;
  grid-template-columns: auto minmax(130px, 1fr) !important;
  align-items: center !important;
  gap: .48rem !important;
  min-width: 0 !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label {
  height: auto !important;
  min-height: 0 !important;
  display: inline !important;
  width: auto !important;
  min-width: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: color-mix(in oklab, var(--text) 84%, var(--muted)) !important;
  font-size: .78rem !important;
  font-weight: 650 !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
  cursor: default !important;
  user-select: auto !important;
  opacity: 1 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label::before {
  content: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-shell {
  min-width: 0 !important;
  width: 100% !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
  border-left: 1px solid rgba(255,255,255,.16) !important;
  border-radius: 999px !important;
  min-width: 0 !important;
  width: 100% !important;
  padding-inline: .82rem 2.2rem !important;
  justify-content: flex-start !important;
  font-size: .82rem !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::before {
  content: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::after {
  display: block !important;
  right: .82rem !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button .variant-select-button-text {
  display: block !important;
}

.visual-stage:fullscreen .fullscreen-quality {
  display: grid !important;
  grid-template-columns: auto minmax(120px, 1fr) !important;
  align-items: center !important;
  gap: .55rem !important;
  min-width: 0 !important;
  overflow: visible !important;
}

.visual-stage:fullscreen .fullscreen-quality > span {
  height: auto !important;
  min-height: 0 !important;
  display: inline !important;
  width: auto !important;
  min-width: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: rgba(255,255,255,.84) !important;
  font-size: .84rem !important;
  font-weight: 650 !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
  cursor: default !important;
  user-select: auto !important;
  opacity: 1 !important;
}

.visual-stage:fullscreen .fullscreen-quality > span::before {
  content: none !important;
}

.visual-stage:fullscreen .fullscreen-quality .variant-select-shell {
  min-width: 0 !important;
  width: 100% !important;
}

.visual-stage:fullscreen .fullscreen-quality .variant-select-button {
  border-left: 1px solid rgba(255,255,255,.16) !important;
  border-radius: 999px !important;
  min-width: 0 !important;
  width: 100% !important;
  padding-inline: .82rem 2.2rem !important;
  justify-content: flex-start !important;
  font-size: .82rem !important;
}

.visual-stage:fullscreen .fullscreen-quality .variant-select-button::before {
  content: none !important;
}

.visual-stage:fullscreen .fullscreen-quality .variant-select-button::after {
  display: block !important;
  right: .82rem !important;
}

.visual-stage:fullscreen .fullscreen-quality .variant-select-button .variant-select-button-text {
  display: block !important;
}

@container (max-width: 980px) {
  .visual-stage:not(:fullscreen) > .stage-control-row {
    grid-template-columns: minmax(270px, 1fr) var(--player-control-height-unified) minmax(170px, .68fr) auto !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    grid-template-columns: var(--player-control-height-unified) !important;
    gap: 0 !important;
    justify-self: center !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    min-width: 0 !important;
    min-height: 0 !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0) !important;
    clip-path: inset(50%) !important;
    white-space: nowrap !important;
    font-size: 0 !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-shell,
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
    padding: 0 !important;
    border-radius: 999px !important;
    justify-content: center !important;
    font-size: 0 !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::before {
    content: '▦' !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    font-size: 1rem !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    pointer-events: none !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::after {
    display: none !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button .variant-select-button-text {
    display: none !important;
  }
}

@media (max-width: 1100px) {
  .visual-stage:fullscreen .fullscreen-quality {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    grid-template-columns: var(--player-control-height-unified) !important;
    gap: 0 !important;
  }

  .visual-stage:fullscreen .fullscreen-quality > span {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    min-width: 0 !important;
    min-height: 0 !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0) !important;
    clip-path: inset(50%) !important;
    white-space: nowrap !important;
    font-size: 0 !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  .visual-stage:fullscreen .fullscreen-quality .variant-select-shell,
  .visual-stage:fullscreen .fullscreen-quality .variant-select-button {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
  }

  .visual-stage:fullscreen .fullscreen-quality .variant-select-button {
    padding: 0 !important;
    border-radius: 999px !important;
    justify-content: center !important;
    font-size: 0 !important;
  }

  .visual-stage:fullscreen .fullscreen-quality .variant-select-button::before {
    content: '▦' !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    font-size: 1rem !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    pointer-events: none !important;
  }

  .visual-stage:fullscreen .fullscreen-quality .variant-select-button::after {
    display: none !important;
  }

  .visual-stage:fullscreen .fullscreen-quality .variant-select-button .variant-select-button-text {
    display: none !important;
  }
}

/* v219: Playerbar stabilisiert – keine gebrochenen Gruppen, kompakte Variante/Qualität nur bei wirklich knapper Breite */
.visual-stage:not(:fullscreen) > .stage-control-row {
  --wr-playerbar-gap: .42rem;
  --wr-playerbar-pad-y: .5rem;
  --wr-playerbar-pad-x: .62rem;
  position: absolute !important;
  left: clamp(.65rem, 1.4vw, 1.15rem) !important;
  right: clamp(.65rem, 1.4vw, 1.15rem) !important;
  bottom: clamp(.65rem, 1.4vw, 1.15rem) !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: var(--wr-playerbar-gap) !important;
  padding: var(--wr-playerbar-pad-y) var(--wr-playerbar-pad-x) !important;
  overflow: visible !important;
  border-radius: 22px !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row > * {
  min-width: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
  flex: 0 1 auto !important;
  min-width: 0 !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: .36rem !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport .primary-button,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport .soft-button,
.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  flex: 0 0 auto !important;
  min-height: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  padding-inline: .74rem !important;
  font-size: .78rem !important;
  gap: .25rem !important;
  overflow: hidden !important;
  white-space: nowrap !important;
}

.visual-stage:not(:fullscreen) #previousButton::before,
.visual-stage:not(:fullscreen) #nextButton::before,
.visual-stage:not(:fullscreen) #randomButton::before,
.visual-stage:not(:fullscreen) #sleepButton::before,
.visual-stage:not(:fullscreen) #muteButton::before,
.visual-stage:not(:fullscreen) #fullscreenStageButton::before {
  content: none !important;
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #playPauseButton {
  min-width: 70px !important;
  justify-content: center !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .player-shortcuts-button {
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  padding-inline: 0 !important;
  justify-content: center !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
  flex: 1 1 290px !important;
  width: auto !important;
  min-width: 215px !important;
  max-width: 360px !important;
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) !important;
  align-items: center !important;
  gap: .48rem !important;
  justify-self: auto !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label {
  position: static !important;
  width: auto !important;
  height: auto !important;
  min-width: 0 !important;
  min-height: 0 !important;
  clip: auto !important;
  clip-path: none !important;
  overflow: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  display: inline !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  font-size: .78rem !important;
  font-weight: 650 !important;
  line-height: 1.1 !important;
  color: color-mix(in oklab, var(--text) 84%, var(--muted)) !important;
  white-space: nowrap !important;
  cursor: default !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label::before {
  content: none !important;
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-shell,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
  border-left: 1px solid rgba(255,255,255,.16) !important;
  border-radius: 999px !important;
  padding-inline: .76rem 2rem !important;
  justify-content: flex-start !important;
  font-size: .78rem !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::before {
  content: none !important;
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::after {
  display: block !important;
  right: .76rem !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button .variant-select-button-text {
  display: block !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
  flex: 0 1 240px !important;
  width: auto !important;
  min-width: 170px !important;
  max-width: 275px !important;
  display: grid !important;
  grid-template-columns: max-content minmax(72px, 1fr) max-content !important;
  align-items: center !important;
  gap: .48rem !important;
  justify-self: auto !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume label {
  display: inline !important;
  color: color-mix(in oklab, var(--text) 84%, var(--muted)) !important;
  font-size: .78rem !important;
  font-weight: 650 !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
  width: 100% !important;
  min-width: 72px !important;
  max-width: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  flex: 0 0 auto !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton {
  min-width: 74px !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  min-width: 104px !important;
}

.visual-stage:not(:fullscreen):hover .status-pill,
.visual-stage:not(:fullscreen):focus-within .status-pill,
.visual-stage:not(:fullscreen):hover .now-playing-badge,
.visual-stage:not(:fullscreen):focus-within .now-playing-badge {
  bottom: 4.7rem !important;
}

@container (max-width: 1280px) {
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
    gap: .32rem !important;
  }

  .visual-stage:not(:fullscreen) #previousButton,
  .visual-stage:not(:fullscreen) #nextButton,
  .visual-stage:not(:fullscreen) #randomButton,
  .visual-stage:not(:fullscreen) #sleepButton,
  .visual-stage:not(:fullscreen) #muteButton,
  .visual-stage:not(:fullscreen) #fullscreenStageButton {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    flex: 0 0 var(--player-control-height-unified) !important;
    padding-inline: 0 !important;
    font-size: 0 !important;
    gap: 0 !important;
  }

  .visual-stage:not(:fullscreen) #previousButton::before,
  .visual-stage:not(:fullscreen) #nextButton::before,
  .visual-stage:not(:fullscreen) #randomButton::before,
  .visual-stage:not(:fullscreen) #sleepButton::before,
  .visual-stage:not(:fullscreen) #muteButton::before,
  .visual-stage:not(:fullscreen) #fullscreenStageButton::before {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    font-size: 1.05rem !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    pointer-events: none !important;
  }

  .visual-stage:not(:fullscreen) #previousButton::before { content: '‹' !important; font-size: 1.35rem !important; }
  .visual-stage:not(:fullscreen) #nextButton::before { content: '›' !important; font-size: 1.35rem !important; }
  .visual-stage:not(:fullscreen) #randomButton::before { content: '⇄' !important; }
  .visual-stage:not(:fullscreen) #sleepButton::before { content: '◷' !important; }
  .visual-stage:not(:fullscreen) #muteButton::before { content: '🔊' !important; font-size: .98rem !important; }
  .visual-stage:not(:fullscreen) #muteButton[aria-pressed="true"]::before { content: '🔇' !important; }
  .visual-stage:not(:fullscreen) #fullscreenStageButton::before { content: '⛶' !important; }
  .visual-stage:not(:fullscreen) #fullscreenStageButton[aria-pressed="true"]::before { content: '⤢' !important; }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
    flex: 1 1 240px !important;
    min-width: 190px !important;
    max-width: 300px !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
    flex: 0 1 210px !important;
    min-width: 150px !important;
    max-width: 240px !important;
  }
}

@container (max-width: 900px) {
  .visual-stage:not(:fullscreen) > .stage-control-row {
    --wr-playerbar-gap: .36rem;
    --wr-playerbar-pad-y: .46rem;
    --wr-playerbar-pad-x: .52rem;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
    flex: 0 0 var(--player-control-height-unified) !important;
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    display: block !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    min-width: 0 !important;
    min-height: 0 !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0) !important;
    clip-path: inset(50%) !important;
    white-space: nowrap !important;
    font-size: 0 !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-shell,
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
    padding: 0 !important;
    border-radius: 999px !important;
    justify-content: center !important;
    font-size: 0 !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::before {
    content: '▦' !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    font-size: 1rem !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    pointer-events: none !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::after,
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button .variant-select-button-text {
    display: none !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
    flex: 0 1 132px !important;
    min-width: 112px !important;
    max-width: 148px !important;
    grid-template-columns: minmax(66px, 1fr) max-content !important;
    gap: .42rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume label {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0) !important;
    clip-path: inset(50%) !important;
    white-space: nowrap !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
    min-width: 66px !important;
  }

  .visual-stage:not(:fullscreen):hover .status-pill,
  .visual-stage:not(:fullscreen):focus-within .status-pill,
  .visual-stage:not(:fullscreen):hover .now-playing-badge,
  .visual-stage:not(:fullscreen):focus-within .now-playing-badge {
    bottom: 4.5rem !important;
  }
}

@container (max-width: 660px) {
  .visual-stage:not(:fullscreen) > .stage-control-row {
    --wr-playerbar-gap: .28rem;
    --wr-playerbar-pad-y: .42rem;
    --wr-playerbar-pad-x: .42rem;
    border-radius: 18px !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
    gap: .24rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row #playPauseButton {
    min-width: 58px !important;
    padding-inline: .5rem !important;
    font-size: .72rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
    flex-basis: 112px !important;
    min-width: 98px !important;
    max-width: 122px !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
    min-width: 56px !important;
  }
}


/* v223: Rückbau der misslungenen v220-v222-Rechtsverschiebung; Vollbild bleibt kompakt rechts neben Mute */
.visual-stage:not(:fullscreen) > .stage-control-row {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: var(--wr-playerbar-gap, .42rem) !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
  flex: 0 0 auto !important;
  min-width: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
  flex: 1 1 260px !important;
  min-width: 180px !important;
  max-width: 330px !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
  flex: 0 0 220px !important;
  width: 220px !important;
  min-width: 190px !important;
  max-width: 220px !important;
  margin: 0 !important;
  display: grid !important;
  grid-template-columns: max-content minmax(72px, 1fr) max-content !important;
  align-items: center !important;
  gap: .44rem !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton {
  min-width: var(--player-control-height-unified) !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  margin: 0 !important;
  padding-inline: 0 !important;
  font-size: 0 !important;
  gap: 0 !important;
  overflow: hidden !important;
  white-space: nowrap !important;
}

.visual-stage:not(:fullscreen) #fullscreenStageButton::before {
  content: '⛶' !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  font-size: 1.02rem !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) #fullscreenStageButton[aria-pressed="true"]::before {
  content: '⤢' !important;
}

@container (max-width: 1180px) {
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
    flex: 1 1 210px !important;
    min-width: 150px !important;
    max-width: 280px !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
    flex: 0 0 154px !important;
    width: 154px !important;
    min-width: 132px !important;
    max-width: 154px !important;
    grid-template-columns: minmax(66px, 1fr) max-content !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume label {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0) !important;
    clip-path: inset(50%) !important;
    white-space: nowrap !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }
}

@container (max-width: 900px) {
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
    flex: 0 0 var(--player-control-height-unified) !important;
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
    flex: 0 0 126px !important;
    width: 126px !important;
    min-width: 112px !important;
    max-width: 126px !important;
  }
}


/* v224: Playerbar wieder sauber als feste Gruppen aufbauen; Lautstärke/Mute/Vollbild kompakt rechts halten */
.visual-stage:not(:fullscreen) > .stage-control-row {
  display: grid !important;
  grid-template-columns: max-content max-content minmax(0, 1fr) max-content !important;
  align-items: center !important;
  column-gap: .44rem !important;
  row-gap: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
  grid-column: 1 !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: .34rem !important;
  min-width: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
  grid-column: 2 !important;
  justify-self: start !important;
  min-width: 0 !important;
  margin: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
  grid-column: 3 !important;
  justify-self: end !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  display: grid !important;
  grid-template-columns: minmax(72px, 96px) max-content !important;
  align-items: center !important;
  gap: .42rem !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume label {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  min-width: 0 !important;
  min-height: 0 !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
  width: 96px !important;
  min-width: 72px !important;
  max-width: 96px !important;
  justify-self: end !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton {
  min-width: 74px !important;
  max-width: 92px !important;
  justify-self: end !important;
  margin: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  grid-column: 4 !important;
  justify-self: end !important;
  margin: 0 !important;
  flex: none !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  padding-inline: 0 !important;
  font-size: 0 !important;
  gap: 0 !important;
  overflow: hidden !important;
  white-space: nowrap !important;
}

.visual-stage:not(:fullscreen) #fullscreenStageButton::before {
  content: '⛶' !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  font-size: 1.02rem !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) #fullscreenStageButton[aria-pressed="true"]::before {
  content: '⤢' !important;
}

@container (min-width: 1181px) {
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
    display: grid !important;
    grid-template-columns: auto minmax(130px, 180px) !important;
    align-items: center !important;
    gap: .48rem !important;
    max-width: 330px !important;
  }
}

@container (max-width: 1180px) {
  .visual-stage:not(:fullscreen) > .stage-control-row {
    grid-template-columns: max-content max-content minmax(0, 1fr) max-content !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
    flex: none !important;
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    display: block !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    min-width: 0 !important;
    min-height: 0 !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0) !important;
    clip-path: inset(50%) !important;
    white-space: nowrap !important;
    font-size: 0 !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-shell,
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
    padding: 0 !important;
    border-radius: 999px !important;
    justify-content: center !important;
    font-size: 0 !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::before {
    content: '▦' !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    font-size: 1rem !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    pointer-events: none !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::after,
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button .variant-select-button-text {
    display: none !important;
  }
}

@container (max-width: 900px) {
  .visual-stage:not(:fullscreen) > .stage-control-row {
    column-gap: .34rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
    grid-template-columns: minmax(58px, 72px) max-content !important;
    gap: .32rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
    width: 72px !important;
    min-width: 58px !important;
    max-width: 72px !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row #muteButton {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    padding-inline: 0 !important;
    font-size: 0 !important;
  }

  .visual-stage:not(:fullscreen) #muteButton::before {
    content: '🔊' !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    font-size: .98rem !important;
    line-height: 1 !important;
    pointer-events: none !important;
  }

  .visual-stage:not(:fullscreen) #muteButton[aria-pressed="true"]::before {
    content: '🔇' !important;
  }
}


/* v225: Playerbar bei schmalem linken Player als 5 feste Gruppen begrenzen; Mute und Vollbild dürfen nicht aus dem Player laufen */
.visual-stage:not(:fullscreen) > .stage-control-row {
  display: grid !important;
  grid-template-columns: max-content max-content minmax(0, 1fr) max-content max-content !important;
  align-items: center !important;
  column-gap: .34rem !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
  grid-column: 1 !important;
  min-width: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
  grid-column: 2 !important;
  justify-self: start !important;
  min-width: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
  grid-column: 4 !important;
  justify-self: end !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  margin: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(52px, 68px) max-content !important;
  align-items: center !important;
  gap: .28rem !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
  width: 68px !important;
  min-width: 52px !important;
  max-width: 68px !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  padding-inline: 0 !important;
  font-size: 0 !important;
  flex: none !important;
  margin: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  grid-column: 5 !important;
  justify-self: end !important;
}

.visual-stage:not(:fullscreen) #muteButton::before,
.visual-stage:not(:fullscreen) #fullscreenStageButton::before {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  line-height: 1 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) #muteButton::before {
  content: '🔊' !important;
  font-size: .96rem !important;
}

.visual-stage:not(:fullscreen) #muteButton[aria-pressed="true"]::before {
  content: '🔇' !important;
}

.visual-stage:not(:fullscreen) #fullscreenStageButton::before {
  content: '⛶' !important;
  font-size: 1.02rem !important;
  font-weight: 900 !important;
}

.visual-stage:not(:fullscreen) #fullscreenStageButton[aria-pressed="true"]::before {
  content: '⤢' !important;
}

@container (max-width: 720px) {
  .visual-stage:not(:fullscreen) > .stage-control-row {
    column-gap: .28rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
    grid-template-columns: max-content !important;
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
    display: none !important;
  }
}


/* v226: tatsächliche Playerbreite per JS-Klasse behandeln – bei schmalem linken Player bleiben Mute und Vollbild komplett sichtbar */
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight {
  display: grid !important;
  grid-template-columns: max-content max-content minmax(0, 1fr) max-content max-content !important;
  align-items: center !important;
  column-gap: .30rem !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-transport {
  grid-column: 1 !important;
  min-width: 0 !important;
  gap: .28rem !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality {
  grid-column: 2 !important;
  flex: none !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  justify-self: start !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-volume {
  grid-column: 4 !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  display: grid !important;
  grid-template-columns: max-content !important;
  justify-self: end !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-volume label,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-volume input[type="range"] {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #fullscreenStageButton {
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  padding-inline: 0 !important;
  font-size: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #fullscreenStageButton {
  grid-column: 5 !important;
  justify-self: end !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #muteButton::before,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #fullscreenStageButton::before {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  line-height: 1 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #muteButton::before {
  content: '🔊' !important;
  font-size: .96rem !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #muteButton[aria-pressed="true"]::before {
  content: '🔇' !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #fullscreenStageButton::before {
  content: '⛶' !important;
  font-size: 1.02rem !important;
  font-weight: 900 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #fullscreenStageButton[aria-pressed="true"]::before {
  content: '⤢' !important;
}


/* v227: Schmale Playerbar nicht mehr nach rechts drücken – alle nötigen Steuerungen bleiben vollständig sichtbar */
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: .30rem !important;
  overflow: hidden !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-transport {
  order: 1 !important;
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: .28rem !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality {
  order: 2 !important;
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  margin: 0 !important;
  display: block !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-volume {
  order: 3 !important;
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #fullscreenStageButton {
  order: 4 !important;
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  margin: 0 !important;
  padding-inline: 0 !important;
  align-self: center !important;
  justify-self: auto !important;
  overflow: hidden !important;
  font-size: 0 !important;
  transform: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-volume label,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-volume input[type="range"] {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #fullscreenStageButton,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button {
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  padding: 0 !important;
  margin: 0 !important;
  font-size: 0 !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality > label,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button::after,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button .variant-select-button-text {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button::before,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #muteButton::before,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #fullscreenStageButton::before {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  line-height: 1 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button::before {
  content: '▦' !important;
  font-size: 1rem !important;
  font-weight: 900 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #muteButton::before {
  content: '🔊' !important;
  font-size: .96rem !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #muteButton[aria-pressed="true"]::before {
  content: '🔇' !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #fullscreenStageButton::before {
  content: '⛶' !important;
  font-size: 1.02rem !important;
  font-weight: 900 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #fullscreenStageButton[aria-pressed="true"]::before {
  content: '⤢' !important;
}


/* v228: Playerbar sauber innerhalb des Players halten; Lautstärke/Mute/Vollbild als rechter Block */
.visual-stage:not(:fullscreen) > .stage-control-row {
  left: clamp(.65rem, 1.4vw, 1.15rem) !important;
  right: clamp(.65rem, 1.4vw, 1.15rem) !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: .42rem !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
  flex: 0 1 auto !important;
  min-width: 0 !important;
  max-width: max-content !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: .32rem !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
  flex: 1 1 220px !important;
  min-width: 150px !important;
  max-width: 330px !important;
  margin: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
  margin-left: auto !important;
  margin-right: 0 !important;
  flex: 0 0 205px !important;
  width: 205px !important;
  min-width: 175px !important;
  max-width: 205px !important;
  display: grid !important;
  grid-template-columns: minmax(72px, 1fr) max-content !important;
  align-items: center !important;
  gap: .42rem !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume label {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  min-width: 0 !important;
  min-height: 0 !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
  display: block !important;
  width: 100% !important;
  min-width: 72px !important;
  max-width: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  padding: 0 !important;
  margin: 0 !important;
  font-size: 0 !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  white-space: nowrap !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  margin-left: .02rem !important;
  align-self: center !important;
}

.visual-stage:not(:fullscreen) #muteButton::before,
.visual-stage:not(:fullscreen) #fullscreenStageButton::before {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  line-height: 1 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) #muteButton::before {
  content: '🔊' !important;
  font-size: .96rem !important;
}

.visual-stage:not(:fullscreen) #muteButton[aria-pressed="true"]::before {
  content: '🔇' !important;
}

.visual-stage:not(:fullscreen) #fullscreenStageButton::before {
  content: '⛶' !important;
  font-size: 1.02rem !important;
  font-weight: 900 !important;
}

.visual-stage:not(:fullscreen) #fullscreenStageButton[aria-pressed="true"]::before {
  content: '⤢' !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: .34rem !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-transport,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-transport {
  order: 1 !important;
  flex: 0 1 auto !important;
  max-width: max-content !important;
  gap: .28rem !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality {
  order: 2 !important;
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  margin: 0 !important;
  display: block !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-volume,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-volume {
  order: 3 !important;
  margin-left: auto !important;
  flex: 0 1 150px !important;
  width: 150px !important;
  min-width: 116px !important;
  max-width: 150px !important;
  display: grid !important;
  grid-template-columns: minmax(58px, 1fr) max-content !important;
  align-items: center !important;
  gap: .36rem !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #fullscreenStageButton,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact #fullscreenStageButton {
  order: 4 !important;
  margin-left: .02rem !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality > label,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality > label,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button::after,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality .variant-select-button::after,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button .variant-select-button-text,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality .variant-select-button .variant-select-button-text {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality .variant-select-button {
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  padding: 0 !important;
  justify-content: center !important;
  font-size: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button::before,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality .variant-select-button::before {
  content: '▦' !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  font-size: 1rem !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  pointer-events: none !important;
}

@container (max-width: 620px) {
  .visual-stage:not(:fullscreen) > .stage-control-row {
    gap: .28rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
    flex-basis: var(--player-control-height-unified) !important;
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    display: flex !important;
    justify-content: center !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
    display: none !important;
  }
}


/* v229: Playerbar per fixer Innenbreite einpassen – rechte Controls dürfen nie aus dem Player laufen */
.visual-stage:not(:fullscreen) > .stage-control-row {
  left: clamp(.65rem, 1.35vw, 1rem) !important;
  right: clamp(.65rem, 1.35vw, 1rem) !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  display: grid !important;
  grid-template-columns: max-content minmax(0, 1fr) max-content max-content !important;
  grid-auto-flow: column !important;
  align-items: center !important;
  gap: .38rem !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
  grid-column: 1 !important;
  min-width: 0 !important;
  max-width: max-content !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: .28rem !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
  grid-column: 2 !important;
  min-width: 0 !important;
  max-width: none !important;
  width: auto !important;
  margin: 0 !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
  grid-column: 3 !important;
  margin: 0 !important;
  justify-self: end !important;
  flex: none !important;
  width: 196px !important;
  min-width: 0 !important;
  max-width: 196px !important;
  display: grid !important;
  grid-template-columns: minmax(68px, 1fr) max-content !important;
  align-items: center !important;
  gap: .36rem !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume label {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  min-width: 0 !important;
  min-height: 0 !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton {
  margin: 0 !important;
  justify-self: end !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  grid-column: 4 !important;
  margin: 0 !important;
  justify-self: end !important;
  align-self: center !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
  min-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  padding: 0 !important;
  font-size: 0 !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.visual-stage:not(:fullscreen) #muteButton::before,
.visual-stage:not(:fullscreen) #fullscreenStageButton::before {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  line-height: 1 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) #muteButton::before { content: '🔊' !important; font-size: .96rem !important; }
.visual-stage:not(:fullscreen) #muteButton[aria-pressed="true"]::before { content: '🔇' !important; }
.visual-stage:not(:fullscreen) #fullscreenStageButton::before { content: '⛶' !important; font-size: 1.02rem !important; font-weight: 900 !important; }
.visual-stage:not(:fullscreen) #fullscreenStageButton[aria-pressed="true"]::before { content: '⤢' !important; }

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact {
  grid-template-columns: max-content var(--player-control-height-unified) minmax(96px, 150px) var(--player-control-height-unified) !important;
  gap: .34rem !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight {
  grid-template-columns: max-content var(--player-control-height-unified) var(--player-control-height-unified) var(--player-control-height-unified) !important;
  gap: .30rem !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality {
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  display: block !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality > label,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality > label,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality .variant-select-button::after,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button::after,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality .variant-select-button .variant-select-button-text,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button .variant-select-button-text {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality .variant-select-button,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button {
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  padding: 0 !important;
  justify-content: center !important;
  font-size: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality .variant-select-button::before,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button::before {
  content: '▦' !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  font-size: 1rem !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-volume {
  width: 150px !important;
  max-width: 150px !important;
  grid-template-columns: minmax(54px, 1fr) max-content !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-volume {
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-volume input[type="range"] {
  display: none !important;
}

@container (max-width: 760px) {
  .visual-stage:not(:fullscreen) > .stage-control-row {
    grid-template-columns: max-content var(--player-control-height-unified) var(--player-control-height-unified) var(--player-control-height-unified) !important;
    gap: .30rem !important;
  }
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
  }
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
    width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    display: flex !important;
    justify-content: center !important;
    overflow: visible !important;
  }
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] { display: none !important; }
}


/* v230: finale Playerbar-Begrenzung nach echter Innenbreite.
   Wichtig: Die Leiste darf im zweispaltigen Layout niemals aus dem Player laufen.
   Bei enger Playerbreite bleiben rechts mindestens Mute + Vollbild sichtbar; der Slider wird dann ausgeblendet. */
.visual-stage:not(:fullscreen) > .stage-control-row {
  left: clamp(.7rem, 1.4vw, 1.05rem) !important;
  right: clamp(.7rem, 1.4vw, 1.05rem) !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: .42rem !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
  order: 1 !important;
  flex: 0 1 auto !important;
  min-width: 0 !important;
  max-width: max-content !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: .34rem !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
  order: 2 !important;
  flex: 0 1 250px !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: 330px !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
  order: 3 !important;
  margin-left: auto !important;
  margin-right: 0 !important;
  flex: 0 0 190px !important;
  width: 190px !important;
  min-width: 190px !important;
  max-width: 190px !important;
  display: grid !important;
  grid-template-columns: minmax(76px, 1fr) var(--player-control-height-unified) !important;
  align-items: center !important;
  gap: .40rem !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume label {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
  display: block !important;
  width: 100% !important;
  min-width: 76px !important;
  max-width: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton {
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  padding: 0 !important;
  font-size: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  order: 4 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  padding: 0 !important;
  font-size: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Mittlere Breite: Auswahl kompakt, Slider bleibt noch sichtbar. */
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact {
  gap: .34rem !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality {
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality > label,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality > label,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality .variant-select-button .variant-select-button-text,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button .variant-select-button-text,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality .variant-select-button::after,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button::after {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality .variant-select-button,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button {
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  padding: 0 !important;
  border-radius: 999px !important;
  justify-content: center !important;
  font-size: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality .variant-select-button::before,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button::before {
  content: '▦' !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  font-size: 1rem !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-volume {
  flex-basis: 150px !important;
  width: 150px !important;
  min-width: 150px !important;
  max-width: 150px !important;
  grid-template-columns: minmax(62px, 1fr) var(--player-control-height-unified) !important;
}

/* Enge Playerbreite wie im zweispaltigen Layout:
   Slider ausblenden, damit Mute und Vollbild vollständig rechts im Player bleiben. */
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-volume {
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-volume input[type="range"] {
  display: none !important;
}

/* Sicherheitsnetz: Wenn der Player extrem schmal wird, bleibt die Bedienleiste einzeilig und innerhalb der Bühne. */
@container (max-width: 720px) {
  .visual-stage:not(:fullscreen) > .stage-control-row {
    gap: .30rem !important;
    padding-inline: .50rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
    gap: .28rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality,
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume,
  .visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
    flex: 0 0 var(--player-control-height-unified) !important;
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
    display: none !important;
  }
}


/* v231: harte Abschlusskorrektur Playerbar – innerhalb der echten Playerfläche halten.
   Reihenfolge bleibt: Transport | Qualität | Lautstärke/Mute | Vollbild.
   Bei zweispaltig/schmalem Player werden Qualität und Lautstärke automatisch kompakt,
   damit Mute + Vollbild nie rechts herauslaufen. */
.visual-stage:not(:fullscreen) > .stage-control-row {
  left: clamp(.55rem, 1.15vw, .95rem) !important;
  right: clamp(.55rem, 1.15vw, .95rem) !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  box-sizing: border-box !important;
  display: grid !important;
  grid-template-columns: max-content minmax(0, 1fr) max-content max-content !important;
  grid-template-areas: "transport quality volume fullscreen" !important;
  align-items: center !important;
  gap: .34rem !important;
  padding-inline: .50rem !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
  grid-area: transport !important;
  min-width: 0 !important;
  width: max-content !important;
  max-width: 100% !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: .28rem !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
  grid-area: quality !important;
  min-width: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) !important;
  align-items: center !important;
  gap: .42rem !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
  grid-area: volume !important;
  min-width: 0 !important;
  width: 178px !important;
  min-width: 178px !important;
  max-width: 178px !important;
  margin: 0 !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(70px, 1fr) var(--player-control-height-unified) !important;
  align-items: center !important;
  gap: .34rem !important;
  justify-self: end !important;
  overflow: hidden !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  grid-area: fullscreen !important;
  justify-self: end !important;
  align-self: center !important;
  margin: 0 !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  padding: 0 !important;
  font-size: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: relative !important;
  z-index: 2 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume label {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton {
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  padding: 0 !important;
  font-size: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-shell,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
  min-width: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
}

/* Zweispaltiges Layout / schmaler linker Player: Qualität nur als Symbol, Slider ausblenden. */
@media (max-width: 1500px) {
  .visual-stage:not(:fullscreen) > .stage-control-row {
    grid-template-columns: max-content var(--player-control-height-unified) var(--player-control-height-unified) var(--player-control-height-unified) !important;
    gap: .30rem !important;
    padding-inline: .46rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    display: block !important;
    overflow: visible !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label,
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button .variant-select-button-text,
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::after {
    display: none !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    padding: 0 !important;
    justify-content: center !important;
    font-size: 0 !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::before {
    content: '▦' !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    font-size: 1rem !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    pointer-events: none !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: visible !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
    display: none !important;
  }
}

@container (max-width: 900px) {
  .visual-stage:not(:fullscreen) > .stage-control-row {
    grid-template-columns: max-content var(--player-control-height-unified) var(--player-control-height-unified) var(--player-control-height-unified) !important;
    gap: .30rem !important;
    padding-inline: .46rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    display: block !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: visible !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
    display: none !important;
  }
}


/* v233: finale Playerbar-Breite aus der echten Player-Innenfläche, ohne max-content-Auslauf */
.visual-stage:not(:fullscreen) > .stage-control-row {
  right: auto !important;
  width: auto;
  min-width: 0 !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: .34rem !important;
  padding: .48rem .56rem !important;
  overflow: hidden !important;
  max-width: calc(100% - 20px) !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row > * {
  box-sizing: border-box !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
  display: flex !important;
  flex: 0 1 auto !important;
  min-width: 0 !important;
  max-width: 100% !important;
  width: auto !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: .28rem !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport .primary-button,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport .soft-button,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button,
.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  flex-shrink: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) !important;
  align-items: center !important;
  gap: .42rem !important;
  flex: 1 1 250px !important;
  min-width: 0 !important;
  max-width: 340px !important;
  width: auto !important;
  margin: 0 !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label {
  min-width: 0 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-shell,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
  min-width: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
  display: grid !important;
  grid-template-columns: minmax(72px, 1fr) var(--player-control-height-unified) !important;
  align-items: center !important;
  gap: .34rem !important;
  flex: 0 0 178px !important;
  width: 178px !important;
  min-width: 178px !important;
  max-width: 178px !important;
  margin-left: auto !important;
  margin-right: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume label {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  padding: 0 !important;
  font-size: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  position: relative !important;
  inset: auto !important;
  transform: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  flex: 0 0 var(--player-control-height-unified) !important;
  margin: 0 !important;
  z-index: 5 !important;
}

.visual-stage:not(:fullscreen) #muteButton::before,
.visual-stage:not(:fullscreen) #fullscreenStageButton::before {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  line-height: 1 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) #muteButton::before { content: '🔊' !important; font-size: .98rem !important; }
.visual-stage:not(:fullscreen) #muteButton[aria-pressed="true"]::before { content: '🔇' !important; }
.visual-stage:not(:fullscreen) #fullscreenStageButton::before { content: '⛶' !important; font-size: 1.02rem !important; font-weight: 900 !important; }
.visual-stage:not(:fullscreen) #fullscreenStageButton[aria-pressed="true"]::before { content: '⤢' !important; }

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-slider-hidden {
  gap: .30rem !important;
  padding-inline: .48rem !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality {
  display: block !important;
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality > label,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality > label,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality .variant-select-button .variant-select-button-text,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button .variant-select-button-text,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality .variant-select-button::after,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button::after {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality .variant-select-button,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button {
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  padding: 0 !important;
  justify-content: center !important;
  font-size: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality .variant-select-button::before,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality .variant-select-button::before {
  content: '▦' !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  font-size: 1rem !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-slider-hidden .stage-volume,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-volume {
  display: flex !important;
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-slider-hidden .stage-volume input[type="range"],
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-volume input[type="range"] {
  display: none !important;
}

@media (max-width: 1500px) {
  .visual-stage:not(:fullscreen) > .stage-control-row {
    gap: .30rem !important;
    padding-inline: .48rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
    display: block !important;
    flex: 0 0 var(--player-control-height-unified) !important;
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label,
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button .variant-select-button-text,
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::after {
    display: none !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    padding: 0 !important;
    justify-content: center !important;
    font-size: 0 !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::before {
    content: '▦' !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    font-size: 1rem !important;
    line-height: 1 !important;
    font-weight: 900 !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
    display: flex !important;
    flex: 0 0 var(--player-control-height-unified) !important;
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
    display: none !important;
  }
}


/* v233: finale Begrenzung der Playerbar auf die sichtbare Player-Innenfläche.
   Rechte Steuerung wird in der kompakten Playeransicht absolut innerhalb der Bar gehalten. */
.visual-stage:not(:fullscreen) > .stage-control-row {
  right: clamp(.62rem, 1.45vw, 1rem) !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-slider-hidden {
  position: absolute !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: .28rem !important;
  padding: .46rem calc(.56rem + (var(--player-control-height-unified) * 2) + .42rem) .46rem .56rem !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-transport,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-transport,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-slider-hidden .stage-transport {
  flex: 0 1 auto !important;
  min-width: 0 !important;
  max-width: 100% !important;
  overflow: hidden !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: .28rem !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-quality,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-quality,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-slider-hidden .stage-quality {
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  margin: 0 !important;
  overflow: visible !important;
  display: block !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-volume,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-volume,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-slider-hidden .stage-volume {
  position: absolute !important;
  right: calc(.56rem + var(--player-control-height-unified) + .32rem) !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  max-height: var(--player-control-height-unified) !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  z-index: 20 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-volume label,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-volume label,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-slider-hidden .stage-volume label,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact .stage-volume input[type="range"],
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight .stage-volume input[type="range"],
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-slider-hidden .stage-volume input[type="range"] {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-slider-hidden #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact #fullscreenStageButton,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #fullscreenStageButton,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-slider-hidden #fullscreenStageButton {
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  max-height: var(--player-control-height-unified) !important;
  padding: 0 !important;
  margin: 0 !important;
  font-size: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact #fullscreenStageButton,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight #fullscreenStageButton,
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-slider-hidden #fullscreenStageButton {
  position: absolute !important;
  right: .56rem !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  flex: 0 0 var(--player-control-height-unified) !important;
  z-index: 21 !important;
}


/* v234: finale Playerbar-Verteilung ohne absolute Rechtsverschiebung.
   Rechte Bedienelemente bleiben als normale Flex-Elemente innerhalb der Bar. */
.visual-stage:not(:fullscreen) > .stage-control-row {
  left: clamp(.62rem, 1.45vw, 1rem) !important;
  right: clamp(.62rem, 1.45vw, 1rem) !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: .34rem !important;
  padding: .46rem .52rem !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
  order: 1 !important;
  flex: 0 1 auto !important;
  min-width: 0 !important;
  max-width: calc(100% - 9.5rem) !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: .30rem !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
  order: 2 !important;
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  margin: 0 !important;
  display: block !important;
  position: static !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
  order: 3 !important;
  position: static !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  bottom: auto !important;
  transform: none !important;
  margin: 0 0 0 auto !important;
  padding: 0 !important;
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0 !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  z-index: 2 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  order: 4 !important;
  position: static !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  bottom: auto !important;
  transform: none !important;
  margin: 0 !important;
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  z-index: 2 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume label,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"],
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button .variant-select-button-text,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::after {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  max-height: var(--player-control-height-unified) !important;
  padding: 0 !important;
  margin: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 0 !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::before {
  content: '▦' !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  font-size: 1rem !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  pointer-events: none !important;
}

@container (min-width: 980px) {
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
    flex: 0 1 275px !important;
    width: auto !important;
    min-width: 210px !important;
    max-width: 330px !important;
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    align-items: center !important;
    gap: .46rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label,
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button .variant-select-button-text,
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::after {
    display: block !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button {
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    padding-inline: .76rem 2rem !important;
    justify-content: flex-start !important;
    font-size: .78rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::before {
    content: none !important;
    display: none !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
    flex: 0 0 235px !important;
    width: 235px !important;
    min-width: 210px !important;
    max-width: 250px !important;
    display: grid !important;
    grid-template-columns: auto minmax(72px, 1fr) max-content !important;
    gap: .46rem !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume label,
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
    display: block !important;
  }
}


/* v235: Lautstärke-Slider in der schmalen Playerbar wieder sichtbar,
   ohne Mute/Vollbild nach außen zu drücken. */
.visual-stage:not(:fullscreen) > .stage-control-row {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: .34rem !important;
  overflow: hidden !important;
  padding-inline: .52rem !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
  flex: 0 1 auto !important;
  max-width: calc(100% - 15rem) !important;
  min-width: 0 !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  margin: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
  order: 3 !important;
  flex: 0 0 132px !important;
  width: 132px !important;
  min-width: 132px !important;
  max-width: 132px !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  margin: 0 0 0 auto !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(70px, 1fr) var(--player-control-height-unified) !important;
  align-items: center !important;
  gap: .34rem !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume label {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
  display: block !important;
  width: 100% !important;
  min-width: 70px !important;
  max-width: none !important;
  margin: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton {
  grid-column: 2 !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  order: 4 !important;
  flex: 0 0 var(--player-control-height-unified) !important;
  width: var(--player-control-height-unified) !important;
  min-width: var(--player-control-height-unified) !important;
  max-width: var(--player-control-height-unified) !important;
  height: var(--player-control-height-unified) !important;
  min-height: var(--player-control-height-unified) !important;
  margin: 0 !important;
}

@container (max-width: 620px) {
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
    max-width: calc(100% - 10.5rem) !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
    flex-basis: var(--player-control-height-unified) !important;
    width: var(--player-control-height-unified) !important;
    min-width: var(--player-control-height-unified) !important;
    max-width: var(--player-control-height-unified) !important;
    display: flex !important;
    justify-content: center !important;
  }

  .visual-stage:not(:fullscreen) > .stage-control-row .stage-volume input[type="range"] {
    display: none !important;
  }
}


/* v237: endgültige Playerbar-Verteilung mit berechneter Pixelbreite.
   Keine Schätzung über Browserbreite: JS setzt --wr-volume-width aus der echten Player-Innenbreite. */
.visual-stage:not(:fullscreen) > .stage-control-row {
  left: clamp(10px, 1.8%, 16px) !important;
  right: clamp(10px, 1.8%, 16px) !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 8px 9px !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
  order: 1 !important;
  flex: 0 1 var(--wr-transport-width, 300px) !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: var(--wr-transport-width, 300px) !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 6px !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport .primary-button,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport .soft-button,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button,
.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  height: var(--player-control-height-unified, 38px) !important;
  min-height: var(--player-control-height-unified, 38px) !important;
  max-height: var(--player-control-height-unified, 38px) !important;
  box-sizing: border-box !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #playPauseButton {
  flex: 0 0 72px !important;
  width: 72px !important;
  min-width: 72px !important;
  max-width: 72px !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #previousButton,
.visual-stage:not(:fullscreen) > .stage-control-row #nextButton,
.visual-stage:not(:fullscreen) > .stage-control-row #randomButton,
.visual-stage:not(:fullscreen) > .stage-control-row #sleepButton,
.visual-stage:not(:fullscreen) > .stage-control-row .player-shortcuts-button,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-shell,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button,
.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  flex: 0 0 var(--player-control-height-unified, 38px) !important;
  width: var(--player-control-height-unified, 38px) !important;
  min-width: var(--player-control-height-unified, 38px) !important;
  max-width: var(--player-control-height-unified, 38px) !important;
  padding: 0 !important;
  margin: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
  order: 2 !important;
  min-width: var(--player-control-height-unified, 38px) !important;
  max-width: var(--player-control-height-unified, 38px) !important;
  display: block !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button .variant-select-button-text,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::after {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::before {
  content: '▦' !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  font-size: 1rem !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
  order: 3 !important;
  margin-left: auto !important;
  margin-right: 0 !important;
  flex: 0 0 var(--wr-volume-width, 136px) !important;
  width: var(--wr-volume-width, 136px) !important;
  min-width: var(--wr-volume-width, 136px) !important;
  max-width: var(--wr-volume-width, 136px) !important;
  height: var(--player-control-height-unified, 38px) !important;
  min-height: var(--player-control-height-unified, 38px) !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(78px, 1fr) var(--player-control-height-unified, 38px) !important;
  align-items: center !important;
  gap: 6px !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume label {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row:not(.is-playerbar-slider-hidden) .stage-volume input[type="range"],
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-compact:not(.is-playerbar-slider-hidden) .stage-volume input[type="range"],
.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-tight:not(.is-playerbar-slider-hidden) .stage-volume input[type="range"] {
  display: block !important;
  grid-column: 1 !important;
  width: 100% !important;
  min-width: 78px !important;
  max-width: none !important;
  margin: 0 !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton {
  grid-column: 2 !important;
  position: static !important;
  transform: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  order: 4 !important;
  position: static !important;
  transform: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  flex: 0 0 var(--player-control-height-unified, 38px) !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-slider-hidden .stage-volume {
  flex-basis: var(--player-control-height-unified, 38px) !important;
  width: var(--player-control-height-unified, 38px) !important;
  min-width: var(--player-control-height-unified, 38px) !important;
  max-width: var(--player-control-height-unified, 38px) !important;
  display: flex !important;
  justify-content: center !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row.is-playerbar-slider-hidden .stage-volume input[type="range"] {
  display: none !important;
}


/* v237: finaler Playerbar-Aufbau: Mute bleibt immer sichtbar; horizontaler Slider wird in einen Volume-Button mit vertikalem Slider-Popup umgewandelt. */
.visual-stage:not(:fullscreen) > .stage-control-row {
  left: clamp(10px, 1.8%, 16px) !important;
  right: clamp(10px, 1.8%, 16px) !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 8px 9px !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
  order: 1 !important;
  flex: 0 1 auto !important;
  min-width: 0 !important;
  max-width: calc(100% - 188px) !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 6px !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #playPauseButton {
  flex: 0 0 72px !important;
  width: 72px !important;
  min-width: 72px !important;
  max-width: 72px !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #previousButton,
.visual-stage:not(:fullscreen) > .stage-control-row #nextButton,
.visual-stage:not(:fullscreen) > .stage-control-row #randomButton,
.visual-stage:not(:fullscreen) > .stage-control-row #sleepButton,
.visual-stage:not(:fullscreen) > .stage-control-row .player-shortcuts-button,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-shell,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button,
.visual-stage:not(:fullscreen) > .stage-control-row .volume-popup-button,
.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  flex: 0 0 var(--player-control-height-unified, 38px) !important;
  width: var(--player-control-height-unified, 38px) !important;
  min-width: var(--player-control-height-unified, 38px) !important;
  max-width: var(--player-control-height-unified, 38px) !important;
  height: var(--player-control-height-unified, 38px) !important;
  min-height: var(--player-control-height-unified, 38px) !important;
  max-height: var(--player-control-height-unified, 38px) !important;
  padding: 0 !important;
  margin: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
  order: 2 !important;
  display: block !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button .variant-select-button-text,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::after {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::before {
  content: '▦' !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  font-size: 1rem !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
  order: 3 !important;
  margin-left: auto !important;
  margin-right: 0 !important;
  flex: 0 0 82px !important;
  width: 82px !important;
  min-width: 82px !important;
  max-width: 82px !important;
  height: var(--player-control-height-unified, 38px) !important;
  min-height: var(--player-control-height-unified, 38px) !important;
  padding: 0 !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 6px !important;
  position: relative !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume label,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > input[type="range"] {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume .volume-popup-button {
  order: 1 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume #muteButton {
  order: 2 !important;
  position: static !important;
  transform: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  order: 4 !important;
  position: static !important;
  transform: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume-popover {
  position: absolute !important;
  left: 0 !important;
  bottom: calc(100% + 9px) !important;
  width: 46px !important;
  height: 156px !important;
  padding: 12px 6px !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  border-radius: 999px !important;
  background: rgba(16, 22, 34, .94) !important;
  backdrop-filter: blur(18px) !important;
  box-shadow: 0 16px 44px rgba(0,0,0,.48) !important;
  z-index: 2147483200 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume-popover[hidden] {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume-popover input[type="range"] {
  display: block !important;
  width: 28px !important;
  height: 128px !important;
  min-width: 28px !important;
  min-height: 128px !important;
  max-width: 28px !important;
  max-height: 128px !important;
  margin: 0 !important;
  padding: 0 !important;
  writing-mode: vertical-lr !important;
  direction: rtl !important;
  accent-color: var(--accent, #ff3f7d) !important;
}

.visual-stage:not(:fullscreen) #muteButton::before {
  content: '🔊' !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  font-size: .98rem !important;
  line-height: 1 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) #muteButton[aria-pressed="true"]::before { content: '🔇' !important; }
.visual-stage:not(:fullscreen) #fullscreenStageButton::before { content: '⛶' !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; width: 100% !important; font-size: 1.02rem !important; font-weight: 900 !important; pointer-events: none !important; }
.visual-stage:not(:fullscreen) #fullscreenStageButton[aria-pressed="true"]::before { content: '⤢' !important; }

@container (max-width: 560px) {
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
    max-width: calc(100% - 158px) !important;
  }
  .visual-stage:not(:fullscreen) > .stage-control-row #playPauseButton {
    flex-basis: 64px !important;
    width: 64px !important;
    min-width: 64px !important;
    max-width: 64px !important;
  }
}

/* v240: finale Playerbar-Geometrie – direkte Kinder, feste rechte Icon-Gruppe, kein Überlaufen */
.visual-stage:not(:fullscreen) > .stage-control-row {
  left: clamp(10px, 1.8%, 16px) !important;
  right: clamp(10px, 1.8%, 16px) !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 8px 9px !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
  order: 1 !important;
  flex: 0 1 auto !important;
  min-width: 0 !important;
  max-width: calc(100% - 186px) !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 6px !important;
  overflow: hidden !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #playPauseButton {
  flex: 0 0 72px !important;
  width: 72px !important;
  min-width: 72px !important;
  max-width: 72px !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #previousButton,
.visual-stage:not(:fullscreen) > .stage-control-row #nextButton,
.visual-stage:not(:fullscreen) > .stage-control-row #randomButton,
.visual-stage:not(:fullscreen) > .stage-control-row #sleepButton,
.visual-stage:not(:fullscreen) > .stage-control-row .player-shortcuts-button,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-shell,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button,
.visual-stage:not(:fullscreen) > .stage-control-row .volume-popup-button,
.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  flex: 0 0 var(--player-control-height-unified, 38px) !important;
  width: var(--player-control-height-unified, 38px) !important;
  min-width: var(--player-control-height-unified, 38px) !important;
  max-width: var(--player-control-height-unified, 38px) !important;
  height: var(--player-control-height-unified, 38px) !important;
  min-height: var(--player-control-height-unified, 38px) !important;
  max-height: var(--player-control-height-unified, 38px) !important;
  padding: 0 !important;
  margin: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality {
  order: 2 !important;
  flex: 0 0 var(--player-control-height-unified, 38px) !important;
  display: block !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button .variant-select-button-text,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::after {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::before {
  content: '▦' !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  font-size: 1rem !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume {
  order: 3 !important;
  margin-left: auto !important;
  margin-right: 0 !important;
  flex: 0 0 82px !important;
  width: 82px !important;
  min-width: 82px !important;
  max-width: 82px !important;
  height: var(--player-control-height-unified, 38px) !important;
  min-height: var(--player-control-height-unified, 38px) !important;
  padding: 0 !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 6px !important;
  position: relative !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume label,
.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > input#volumeControl[type="range"] {
  display: none !important;
  width: 0 !important;
  min-width: 0 !important;
  max-width: 0 !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .volume-popup-button {
  order: 1 !important;
  position: static !important;
  transform: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #muteButton {
  order: 2 !important;
  position: static !important;
  transform: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton {
  order: 4 !important;
  flex: 0 0 var(--player-control-height-unified, 38px) !important;
  position: static !important;
  transform: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume-popover {
  position: absolute !important;
  left: 0 !important;
  bottom: calc(100% + 10px) !important;
  width: 46px !important;
  height: 156px !important;
  padding: 12px 6px !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  border-radius: 999px !important;
  background: rgba(16, 22, 34, .94) !important;
  backdrop-filter: blur(18px) !important;
  box-shadow: 0 16px 44px rgba(0,0,0,.48) !important;
  z-index: 2147483200 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume-popover[hidden] {
  display: none !important;
}

.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume-popover input[type="range"] {
  display: block !important;
  width: 28px !important;
  height: 128px !important;
  min-width: 28px !important;
  min-height: 128px !important;
  margin: 0 !important;
  padding: 0 !important;
  writing-mode: vertical-lr !important;
  direction: rtl !important;
  accent-color: var(--accent, #ff3f7d) !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

.visual-stage:not(:fullscreen) #muteButton::before {
  content: '🔊' !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  font-size: .98rem !important;
  line-height: 1 !important;
  pointer-events: none !important;
}
.visual-stage:not(:fullscreen) #muteButton[aria-pressed="true"]::before { content: '🔇' !important; }
.visual-stage:not(:fullscreen) #fullscreenStageButton::before {
  content: '⛶' !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  font-size: 1.02rem !important;
  font-weight: 900 !important;
  pointer-events: none !important;
}
.visual-stage:not(:fullscreen) #fullscreenStageButton[aria-pressed="true"]::before { content: '⤢' !important; }

@container (max-width: 560px) {
  .visual-stage:not(:fullscreen) > .stage-control-row .stage-transport {
    max-width: calc(100% - 166px) !important;
  }
  .visual-stage:not(:fullscreen) > .stage-control-row #playPauseButton {
    flex-basis: 64px !important;
    width: 64px !important;
    min-width: 64px !important;
    max-width: 64px !important;
  }
}


/* v283: Footer-Links und rechtliche Popups im bestehenden WeltRadio-Seitendesign */
.site-footer {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: .9rem !important;
  margin: 1.2rem clamp(1rem, 3vw, 2rem) 1.6rem !important;
  padding: .85rem !important;
  border: 1px solid color-mix(in oklab, var(--brand) 28%, var(--line)) !important;
  border-radius: clamp(22px, 3vw, 30px) !important;
  background: linear-gradient(135deg, color-mix(in oklab, var(--panel-strong) 92%, transparent), color-mix(in oklab, var(--panel) 98%, transparent)) !important;
  box-shadow: 0 18px 46px rgba(0, 0, 0, .18) !important;
}
.footer-link-row {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: .5rem !important;
  min-width: 0 !important;
}
.site-footer .link-button {
  min-height: 36px !important;
  padding: .48rem .78rem !important;
  border: 1px solid var(--line) !important;
  border-radius: 999px !important;
  background: color-mix(in oklab, var(--panel-strong) 76%, transparent) !important;
  color: var(--text) !important;
  text-decoration: none !important;
  font-weight: 700 !important;
  font-size: .9rem !important;
  box-shadow: 0 10px 22px rgba(0,0,0,.12) !important;
}
.site-footer .link-button:hover,
.site-footer .link-button:focus-visible {
  transform: translateY(-1px) !important;
  border-color: color-mix(in oklab, var(--brand) 52%, var(--line)) !important;
  background: color-mix(in oklab, var(--brand) 11%, var(--panel-strong)) !important;
}
.footer-api-status {
  color: var(--muted) !important;
  font-size: .86rem !important;
  line-height: 1.35 !important;
  text-align: right !important;
  max-width: min(44vw, 520px) !important;
}
.modal[data-modal-type="help"],
.modal[data-modal-type="shortcuts"],
.modal[data-modal-type="troubleshooting"],
.modal[data-modal-type="privacy"],
.modal[data-modal-type="imprint"],
.modal[data-modal-type="contact"],
.modal[data-modal-type="suggest"] {
  width: min(880px, calc(100vw - 2rem)) !important;
  max-width: min(880px, calc(100vw - 2rem)) !important;
  max-height: min(86vh, 860px) !important;
  padding: 0 !important;
  border-radius: clamp(24px, 4vw, 32px) !important;
  border: 1px solid color-mix(in oklab, var(--brand) 34%, var(--line)) !important;
  background: linear-gradient(180deg, color-mix(in oklab, var(--panel-strong) 96%, transparent), color-mix(in oklab, var(--panel) 99%, transparent)) !important;
  box-shadow: 0 36px 96px rgba(0,0,0,.44) !important;
  overflow: hidden !important;
}
.modal[data-modal-type="help"]::backdrop,
.modal[data-modal-type="shortcuts"]::backdrop,
.modal[data-modal-type="troubleshooting"]::backdrop,
.modal[data-modal-type="privacy"]::backdrop,
.modal[data-modal-type="imprint"]::backdrop,
.modal[data-modal-type="contact"]::backdrop,
.modal[data-modal-type="suggest"]::backdrop {
  background: rgba(3,8,20,.72) !important;
  backdrop-filter: blur(7px) !important;
}
.modal[data-modal-type="help"] #modalContent,
.modal[data-modal-type="shortcuts"] #modalContent,
.modal[data-modal-type="troubleshooting"] #modalContent,
.modal[data-modal-type="privacy"] #modalContent,
.modal[data-modal-type="imprint"] #modalContent,
.modal[data-modal-type="contact"] #modalContent,
.modal[data-modal-type="suggest"] #modalContent {
  max-height: min(86vh, 860px) !important;
  overflow: auto !important;
  padding: 1.2rem 1.25rem 1.35rem !important;
  scrollbar-width: thin !important;
}
.modal[data-modal-type="help"] .modal-close,
.modal[data-modal-type="shortcuts"] .modal-close,
.modal[data-modal-type="troubleshooting"] .modal-close,
.modal[data-modal-type="privacy"] .modal-close,
.modal[data-modal-type="imprint"] .modal-close,
.modal[data-modal-type="contact"] .modal-close,
.modal[data-modal-type="suggest"] .modal-close {
  right: 1rem !important;
  top: 1rem !important;
  z-index: 2 !important;
}
.footer-modal-content {
  display: grid !important;
  gap: .95rem !important;
  padding-right: 3rem !important;
}
.footer-modal-heading {
  display: flex !important;
  align-items: flex-start !important;
  gap: .78rem !important;
  margin: 0 0 .35rem !important;
}
.footer-modal-heading .eyebrow {
  margin: .08rem 0 0 !important;
  flex: 0 0 auto !important;
}
.footer-modal-heading h2 {
  margin: 0 !important;
  color: var(--text) !important;
  font-size: clamp(1.18rem, 2.6vw, 1.7rem) !important;
  line-height: 1.06 !important;
  font-weight: 900 !important;
  letter-spacing: -0.025em !important;
  transform: translateY(-2px) !important;
}
.footer-modal-content h3 {
  margin: .45rem 0 -.35rem !important;
  color: var(--text) !important;
  font-size: 1rem !important;
  line-height: 1.25 !important;
}
.footer-modal-content p,
.footer-modal-content li {
  margin: 0 !important;
  color: var(--muted) !important;
  line-height: 1.62 !important;
}
.footer-modal-content a {
  color: var(--text) !important;
  text-decoration-color: color-mix(in oklab, var(--brand) 70%, transparent) !important;
  text-underline-offset: 3px !important;
}
.footer-modal-grid.two {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: .75rem !important;
}
.footer-modal-grid article,
.footer-modal-list,
.footer-modal-alert {
  border: 1px solid var(--line) !important;
  border-radius: var(--radius-lg) !important;
  background: color-mix(in oklab, var(--panel-strong) 62%, transparent) !important;
  padding: .9rem !important;
}
.footer-modal-grid article strong {
  display: block !important;
  margin-bottom: .35rem !important;
  color: var(--text) !important;
}
.footer-modal-list {
  display: grid !important;
  gap: .55rem !important;
}
.footer-modal-alert {
  display: grid !important;
  gap: .28rem !important;
  border-color: color-mix(in oklab, var(--brand) 55%, var(--line)) !important;
  background: color-mix(in oklab, var(--brand) 10%, var(--panel-strong)) !important;
}
.footer-modal-alert strong {
  color: var(--text) !important;
}
.footer-modal-note {
  border-left: 3px solid color-mix(in oklab, var(--brand) 68%, var(--line)) !important;
  padding-left: .8rem !important;
}
.footer-modal-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: .6rem !important;
}
.footer-modal-mail {
  display: inline-flex !important;
  width: fit-content !important;
  align-items: center !important;
  min-height: 38px !important;
  padding: .52rem .8rem !important;
  border: 1px solid var(--line) !important;
  border-radius: 999px !important;
  background: color-mix(in oklab, var(--panel-strong) 70%, transparent) !important;
  text-decoration: none !important;
  font-weight: 800 !important;
}
@media (max-width: 760px) {
  .site-footer {
    align-items: stretch !important;
    margin: .9rem .5rem 1rem !important;
    padding: .7rem !important;
  }
  .footer-link-row {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    width: 100% !important;
  }
  .site-footer .link-button {
    justify-content: center !important;
    width: 100% !important;
  }
  .footer-api-status {
    width: 100% !important;
    max-width: none !important;
    text-align: left !important;
  }
  .modal[data-modal-type="help"],
  .modal[data-modal-type="shortcuts"],
  .modal[data-modal-type="troubleshooting"],
  .modal[data-modal-type="privacy"],
  .modal[data-modal-type="imprint"],
  .modal[data-modal-type="contact"],
  .modal[data-modal-type="suggest"] {
    width: calc(100vw - .5rem) !important;
    max-width: calc(100vw - .5rem) !important;
    max-height: calc(100vh - .5rem) !important;
  }
  .modal[data-modal-type="help"] #modalContent,
  .modal[data-modal-type="shortcuts"] #modalContent,
  .modal[data-modal-type="troubleshooting"] #modalContent,
  .modal[data-modal-type="privacy"] #modalContent,
  .modal[data-modal-type="imprint"] #modalContent,
  .modal[data-modal-type="contact"] #modalContent,
  .modal[data-modal-type="suggest"] #modalContent {
    max-height: calc(100vh - .5rem) !important;
    padding: .95rem .9rem 1.05rem !important;
  }
  .footer-modal-content {
    padding-right: 2.55rem !important;
  }
  .footer-modal-heading {
    display: grid !important;
    gap: .38rem !important;
  }
  .footer-modal-heading h2 {
    transform: none !important;
  }
  .footer-modal-grid.two {
    grid-template-columns: 1fr !important;
  }
}
@media (max-width: 430px) {
  .footer-link-row {
    grid-template-columns: 1fr !important;
  }
}


/* ===== css/130-playerbar-final-v270.css ===== */
/* v270: final playerbar reset.
   Only this file controls the normal-mode playerbar layout.
   No hover/resizing calculations. No duplicate slider/button state. */
#visualStage.visual-stage:not(:fullscreen) {
  container-type: inline-size !important;
}

#visualStage.visual-stage:not(:fullscreen) > .stage-control-row {
  --wr-control-size: 38px !important;
  --wr-control-gap: 8px !important;
  --wr-play-width: 72px !important;
  --wr-volume-width: 150px !important;
  position: absolute !important;
  left: 18px !important;
  right: 18px !important;
  bottom: 14px !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  height: 58px !important;
  min-height: 58px !important;
  max-height: 58px !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: var(--wr-control-gap) !important;
  padding: 9px 12px !important;
  overflow: hidden !important;
  border-radius: 22px !important;
  background: rgba(7, 9, 15, .82) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  box-shadow: 0 16px 48px rgba(0,0,0,.34) !important;
  backdrop-filter: blur(18px) !important;
}

#visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-transport,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-quality,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-right-controls,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .volume-popup-button {
  position: relative !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  bottom: auto !important;
  inset: auto !important;
  transform: none !important;
  margin: 0 !important;
}

#visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-transport {
  order: 1 !important;
  flex: 0 0 auto !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: var(--wr-control-gap) !important;
  height: var(--wr-control-size) !important;
  min-width: 0 !important;
  overflow: visible !important;
  z-index: 20 !important;
}

#visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-quality {
  order: 2 !important;
  flex: 0 0 var(--wr-control-size) !important;
  width: var(--wr-control-size) !important;
  min-width: var(--wr-control-size) !important;
  max-width: var(--wr-control-size) !important;
  height: var(--wr-control-size) !important;
  min-height: var(--wr-control-size) !important;
  max-height: var(--wr-control-size) !important;
  overflow: visible !important;
  z-index: 21 !important;
}

#visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-right-controls {
  order: 3 !important;
  margin-left: auto !important;
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: 100% !important;
  height: var(--wr-control-size) !important;
  min-height: var(--wr-control-size) !important;
  max-height: var(--wr-control-size) !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 10px !important;
  padding: 0 !important;
  overflow: hidden !important;
  z-index: 40 !important;
}

#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #playPauseButton {
  flex: 0 0 var(--wr-play-width) !important;
  width: var(--wr-play-width) !important;
  min-width: var(--wr-play-width) !important;
  max-width: var(--wr-play-width) !important;
  height: var(--wr-control-size) !important;
  min-height: var(--wr-control-size) !important;
  max-height: var(--wr-control-size) !important;
  font-size: .78rem !important;
}

#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #previousButton,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #nextButton,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #randomButton,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #sleepButton,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .player-shortcuts-button,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-shell,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .volume-popup-button {
  flex: 0 0 var(--wr-control-size) !important;
  width: var(--wr-control-size) !important;
  min-width: var(--wr-control-size) !important;
  max-width: var(--wr-control-size) !important;
  height: var(--wr-control-size) !important;
  min-height: var(--wr-control-size) !important;
  max-height: var(--wr-control-size) !important;
  box-sizing: border-box !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  align-self: center !important;
}

#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality > label,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > label,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button .variant-select-button-text,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::after {
  display: none !important;
}

#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #previousButton,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #nextButton,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #randomButton,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #sleepButton,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #muteButton,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .volume-popup-button {
  font-size: 0 !important;
  gap: 0 !important;
}

#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #previousButton::before,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #nextButton::before,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #randomButton::before,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #sleepButton::before,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::before,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #muteButton::before,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton::before,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .volume-popup-button::before {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: 100% !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  pointer-events: none !important;
}
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #previousButton::before { content: '‹' !important; font-size: 1.35rem !important; position: relative !important; top: -1px !important; }
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #nextButton::before { content: '›' !important; font-size: 1.35rem !important; position: relative !important; top: -1px !important; }
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #randomButton::before { content: '⇄' !important; font-size: 1rem !important; }
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #sleepButton::before { content: '◷' !important; font-size: 1rem !important; }
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-quality .variant-select-button::before { content: '▦' !important; font-size: .98rem !important; }
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .volume-popup-button::before { content: '🎚' !important; font-size: .98rem !important; }
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #muteButton::before { content: '🔊' !important; font-size: .96rem !important; }
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #muteButton[aria-pressed="true"]::before { content: '🔇' !important; }
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row #fullscreenStageButton::before { content: '⛶' !important; font-size: 1.02rem !important; }

/* Normal mode: one single volume element = horizontal slider. No extra volume button. */
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-right-controls > .stage-volume {
  flex: 0 0 var(--wr-volume-width) !important;
  width: var(--wr-volume-width) !important;
  min-width: var(--wr-volume-width) !important;
  max-width: var(--wr-volume-width) !important;
  height: var(--wr-control-size) !important;
  min-height: var(--wr-control-size) !important;
  max-height: var(--wr-control-size) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 12px !important;
  box-sizing: border-box !important;
  border-radius: 999px !important;
  background: rgba(20, 26, 40, .9) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04) !important;
  overflow: hidden !important;
  align-self: center !important;
}

#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > .volume-popup-button,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > .stage-volume-popover {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > input#volumeControl {
  display: block !important;
  flex: 1 1 auto !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  height: 18px !important;
  margin: 0 !important;
  padding: 0 !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  background: transparent !important;
  cursor: pointer !important;
  accent-color: #ff456f !important;
  --range-progress: 85%;
  --range-fill: #ff456f;
  --range-rest: rgba(255,255,255,.24);
}
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > input#volumeControl::-webkit-slider-runnable-track {
  width: 100% !important;
  height: 10px !important;
  border-radius: 999px !important;
  background: linear-gradient(to right, var(--range-fill) 0%, var(--range-fill) var(--range-progress), var(--range-rest) var(--range-progress), var(--range-rest) 100%) !important;
}
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > input#volumeControl::-webkit-slider-thumb {
  -webkit-appearance: none !important;
  appearance: none !important;
  width: 18px !important;
  height: 18px !important;
  margin-top: -4px !important;
  border-radius: 50% !important;
  background: var(--range-fill) !important;
  border: 2px solid #fff !important;
  box-shadow: 0 4px 14px rgba(255,69,111,.35) !important;
}
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > input#volumeControl::-moz-range-track {
  height: 10px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: var(--range-rest) !important;
}
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > input#volumeControl::-moz-range-progress {
  height: 10px !important;
  border-radius: 999px !important;
  background: var(--range-fill) !important;
}
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > input#volumeControl::-moz-range-thumb {
  width: 18px !important;
  height: 18px !important;
  border-radius: 50% !important;
  background: var(--range-fill) !important;
  border: 2px solid #fff !important;
  box-shadow: 0 4px 14px rgba(255,69,111,.35) !important;
}
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume.is-muted > input#volumeControl {
  --range-fill: #98a2b8 !important;
  --range-rest: rgba(255,255,255,.14) !important;
  opacity: .82 !important;
}

@container (max-width: 820px) {
  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row { --wr-volume-width: 126px !important; }
}
@container (max-width: 740px) {
  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row { --wr-volume-width: 102px !important; }
  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-right-controls { gap: 8px !important; }
}
@container (max-width: 660px) {
  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row { --wr-control-gap: 7px !important; --wr-volume-width: 82px !important; }
  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-right-controls { gap: 7px !important; }
  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-right-controls > .stage-volume { padding-left: 8px !important; padding-right: 8px !important; }
}
@container (max-width: 590px) {
  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-right-controls > .stage-volume {
    flex: 0 0 var(--wr-control-size) !important;
    width: var(--wr-control-size) !important;
    min-width: var(--wr-control-size) !important;
    max-width: var(--wr-control-size) !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
  }
  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > input#volumeControl {
    display: none !important;
    width: 0 !important;
    min-width: 0 !important;
    max-width: 0 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }
  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > .volume-popup-button {
    display: inline-flex !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }
  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume .stage-volume-popover {
    position: absolute !important;
    left: 50% !important;
    bottom: calc(100% + 10px) !important;
    transform: translateX(-50%) !important;
    width: 54px !important;
    height: 168px !important;
    padding: 12px 0 !important;
    border-radius: 22px !important;
    background: rgba(15, 20, 32, .96) !important;
    border: 1px solid rgba(255,255,255,.14) !important;
    box-shadow: 0 16px 44px rgba(0,0,0,.42) !important;
    backdrop-filter: blur(18px) !important;
    z-index: 2147483200 !important;
  }
  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume .stage-volume-popover:not([hidden]) {
    display: flex !important;
    visibility: visible !important;
    pointer-events: auto !important;
    align-items: center !important;
    justify-content: center !important;
  }
}


/* ===== css/133-playerbar-volume-popover-v273.css ===== */
/* v273: exactly one compact volume button and one vertical volume slider popover */
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-right-controls {
  overflow: visible !important;
}

#visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-right-controls > .stage-volume {
  position: relative !important;
}

#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > .volume-popup-button,
#visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > .stage-volume-popover {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

@container (max-width: 590px) {
  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row,
  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-right-controls,
  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-right-controls > .stage-volume {
    overflow: visible !important;
  }

  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-right-controls {
    gap: 8px !important;
  }

  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row > .stage-right-controls > .stage-volume {
    flex: 0 0 var(--wr-control-size) !important;
    width: var(--wr-control-size) !important;
    min-width: var(--wr-control-size) !important;
    max-width: var(--wr-control-size) !important;
    height: var(--wr-control-size) !important;
    min-height: var(--wr-control-size) !important;
    max-height: var(--wr-control-size) !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    z-index: 60 !important;
  }

  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > input#volumeControl {
    display: none !important;
    width: 0 !important;
    min-width: 0 !important;
    max-width: 0 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > .volume-popup-button {
    display: inline-flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > .stage-volume-popover {
    position: absolute !important;
    left: 50% !important;
    bottom: calc(100% + 10px) !important;
    transform: translateX(-50%) !important;
    width: 54px !important;
    height: 168px !important;
    padding: 12px 0 !important;
    border-radius: 22px !important;
    background: rgba(15, 20, 32, .96) !important;
    border: 1px solid rgba(255,255,255,.14) !important;
    box-shadow: 0 16px 44px rgba(0,0,0,.42) !important;
    backdrop-filter: blur(18px) !important;
    z-index: 2147483200 !important;
  }

  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > .stage-volume-popover:not([hidden]) {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    align-items: center !important;
    justify-content: center !important;
  }

  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > .stage-volume-popover input[type="range"] {
    -webkit-appearance: none !important;
    appearance: none !important;
    writing-mode: vertical-lr !important;
    direction: rtl !important;
    width: 30px !important;
    min-width: 30px !important;
    max-width: 30px !important;
    height: 132px !important;
    min-height: 132px !important;
    max-height: 132px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    cursor: pointer !important;
    accent-color: #ff456f !important;
    --range-progress: 85%;
    --range-fill: #ff456f;
    --range-rest: rgba(255,255,255,.22);
  }

  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > .stage-volume-popover input[type="range"]::-webkit-slider-runnable-track {
    width: 10px !important;
    height: 132px !important;
    border-radius: 999px !important;
    background: linear-gradient(to top, var(--range-fill) 0%, var(--range-fill) var(--range-progress), var(--range-rest) var(--range-progress), var(--range-rest) 100%) !important;
  }

  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume > .stage-volume-popover input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none !important;
    appearance: none !important;
    width: 18px !important;
    height: 18px !important;
    margin-left: -4px !important;
    border-radius: 50% !important;
    background: var(--range-fill) !important;
    border: 2px solid #fff !important;
    box-shadow: 0 4px 14px rgba(255,69,111,.35) !important;
  }

  #visualStage.visual-stage:not(:fullscreen) > .stage-control-row .stage-volume.is-muted > .stage-volume-popover input[type="range"] {
    --range-fill: #98a2b8 !important;
    --range-rest: rgba(255,255,255,.14) !important;
    opacity: .82 !important;
  }
}


/* ===== css/134-mini-overlay-badges-v275.css ===== */
/* v275: mini/normal player badge positions when playerbar appears.
   Keep Live and title badges just above the bar instead of jumping far upward. */
.visual-stage:not(:fullscreen):hover .status-pill,
.visual-stage:not(:fullscreen):focus-within .status-pill,
.hero-player:hover .visual-stage:not(:fullscreen) .status-pill,
.hero-player:focus-within .visual-stage:not(:fullscreen) .status-pill {
  bottom: 5.5rem !important;
}

.visual-stage:not(:fullscreen):hover .now-playing-badge,
.visual-stage:not(:fullscreen):focus-within .now-playing-badge,
.hero-player:hover .visual-stage:not(:fullscreen) .now-playing-badge,
.hero-player:focus-within .visual-stage:not(:fullscreen) .now-playing-badge {
  bottom: 5.5rem !important;
}

@media (max-width: 900px) {
  .visual-stage:not(:fullscreen):hover .status-pill,
  .visual-stage:not(:fullscreen):focus-within .status-pill,
  .hero-player:hover .visual-stage:not(:fullscreen) .status-pill,
  .hero-player:focus-within .visual-stage:not(:fullscreen) .status-pill {
    bottom: 5.25rem !important;
  }

  .visual-stage:not(:fullscreen):hover .now-playing-badge,
  .visual-stage:not(:fullscreen):focus-within .now-playing-badge,
  .hero-player:hover .visual-stage:not(:fullscreen) .now-playing-badge,
  .hero-player:focus-within .visual-stage:not(:fullscreen) .now-playing-badge {
    bottom: 5.25rem !important;
  }
}

@media (max-width: 640px) {
  .visual-stage:not(:fullscreen):hover .status-pill,
  .visual-stage:not(:fullscreen):focus-within .status-pill,
  .hero-player:hover .visual-stage:not(:fullscreen) .status-pill,
  .hero-player:focus-within .visual-stage:not(:fullscreen) .status-pill,
  .visual-stage:not(:fullscreen):hover .now-playing-badge,
  .visual-stage:not(:fullscreen):focus-within .now-playing-badge,
  .hero-player:hover .visual-stage:not(:fullscreen) .now-playing-badge,
  .hero-player:focus-within .visual-stage:not(:fullscreen) .now-playing-badge {
    bottom: 5.05rem !important;
  }
}


/* ===== css/135-station-list-badges-v287.css ===== */
/* v287: Einheitliche, kontrastreiche Senderlisten-Badges für Gelb und Grün.
   Gilt nur für die normale Senderliste/Senderkarten und lässt Sender-Mix-Markierungen unverändert. */
:root {
  --station-warn-badge-bg: color-mix(in oklab, #f0b83f 17%, var(--panel-strong));
  --station-warn-badge-border: color-mix(in oklab, #e2a22a 76%, var(--line));
  --station-warn-badge-text: #ffd986;
  --station-ok-badge-bg: color-mix(in oklab, #24d889 17%, var(--panel-strong));
  --station-ok-badge-border: color-mix(in oklab, #2fc47f 76%, var(--line));
  --station-ok-badge-text: #8df0bd;
}

html[data-theme="light"] {
  --station-warn-badge-bg: #fff1c2;
  --station-warn-badge-border: #d99312;
  --station-warn-badge-text: #6f4300;
  --station-ok-badge-bg: #e4faef;
  --station-ok-badge-border: #2cbf78;
  --station-ok-badge-text: #0f7547;
}

.station-card-badges .badge.warn,
.station-card-badges .badge.ok {
  font-weight: 650 !important;
  letter-spacing: .005em;
  box-shadow: inset 0 0 0 1px color-mix(in oklab, currentColor 8%, transparent) !important;
}

.station-card-badges .badge.warn {
  color: var(--station-warn-badge-text) !important;
  border-color: var(--station-warn-badge-border) !important;
  background: var(--station-warn-badge-bg) !important;
}

.station-card-badges .badge.ok {
  color: var(--station-ok-badge-text) !important;
  border-color: var(--station-ok-badge-border) !important;
  background: var(--station-ok-badge-bg) !important;
}


/* ===== css/136-queue-badges-v290.css ===== */
/* v288: Kontrastreiche Sender-Mix-Listen-Badges.
   Gilt nur für Warteschlange/Sender-Mix-Liste. Schriftgröße und Schriftdicke entsprechen den normalen Senderlisten-Badges. */
:root {
  --queue-live-badge-bg: color-mix(in oklab, #24d889 18%, var(--panel-strong));
  --queue-live-badge-border: color-mix(in oklab, #2fc47f 78%, var(--line));
  --queue-live-badge-text: #8df0bd;

  --queue-next-badge-bg: color-mix(in oklab, #f0b83f 18%, var(--panel-strong));
  --queue-next-badge-border: color-mix(in oklab, #e2a22a 78%, var(--line));
  --queue-next-badge-text: #ffd986;

  --queue-played-badge-bg: color-mix(in oklab, #ff7a1a 18%, var(--panel-strong));
  --queue-played-badge-border: color-mix(in oklab, #ff7a1a 78%, var(--line));
  --queue-played-badge-text: #ffbf77;
}

html[data-theme="light"] {
  --queue-live-badge-bg: #e4faef;
  --queue-live-badge-border: #2cbf78;
  --queue-live-badge-text: #0f7547;

  --queue-next-badge-bg: #fff1c2;
  --queue-next-badge-border: #d99312;
  --queue-next-badge-text: #6f4300;

  --queue-played-badge-bg: #fff0df;
  --queue-played-badge-border: #e77719;
  --queue-played-badge-text: #7b3500;
}

.queue-item-actions .queue-live-badge,
.queue-item-actions .queue-next-badge,
.queue-item-actions .queue-played-badge {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 0 !important;
  padding: .32rem .54rem !important;
  border-radius: 999px !important;
  font-size: .72rem !important;
  font-weight: 650 !important;
  line-height: 1.15 !important;
  letter-spacing: .005em !important;
  white-space: nowrap !important;
  box-shadow: inset 0 0 0 1px color-mix(in oklab, currentColor 8%, transparent) !important;
}

.queue-item-actions .queue-live-badge {
  color: var(--queue-live-badge-text) !important;
  border-color: var(--queue-live-badge-border) !important;
  background: var(--queue-live-badge-bg) !important;
}

.queue-item-actions .queue-next-badge {
  color: var(--queue-next-badge-text) !important;
  border-color: var(--queue-next-badge-border) !important;
  background: var(--queue-next-badge-bg) !important;
}

.queue-item-actions .queue-played-badge {
  color: var(--queue-played-badge-text) !important;
  border-color: var(--queue-played-badge-border) !important;
  background: var(--queue-played-badge-bg) !important;
}

/* v291: Cookie-/Speicher-Hinweis im bestehenden WeltRadio-Design */
.cookie-notice {
  position: fixed !important;
  left: clamp(.75rem, 3vw, 1.35rem) !important;
  right: clamp(.75rem, 3vw, 1.35rem) !important;
  bottom: calc(1rem + env(safe-area-inset-bottom, 0px)) !important;
  z-index: 1180 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 1rem !important;
  max-width: 1040px !important;
  margin: 0 auto !important;
  padding: .95rem 1rem !important;
  border: 1px solid color-mix(in oklab, var(--brand) 34%, var(--line)) !important;
  border-radius: clamp(22px, 3vw, 30px) !important;
  background: linear-gradient(135deg, color-mix(in oklab, var(--panel-strong) 96%, transparent), color-mix(in oklab, var(--panel) 99%, transparent)) !important;
  box-shadow: 0 24px 72px rgba(0, 0, 0, .34) !important;
  opacity: 0 !important;
  transform: translateY(16px) !important;
  transition: opacity .18s ease, transform .18s ease !important;
}
.cookie-notice.show {
  opacity: 1 !important;
  transform: translateY(0) !important;
}
.cookie-notice[hidden] {
  display: none !important;
}
.cookie-notice-copy {
  display: grid !important;
  gap: .28rem !important;
  min-width: 0 !important;
}
.cookie-notice-copy .eyebrow {
  margin: 0 !important;
}
.cookie-notice-copy h2 {
  margin: 0 !important;
  color: var(--text) !important;
  font-size: clamp(1rem, 2vw, 1.18rem) !important;
  line-height: 1.15 !important;
  font-weight: 900 !important;
  letter-spacing: -0.02em !important;
}
.cookie-notice-copy p:not(.eyebrow) {
  margin: 0 !important;
  max-width: 760px !important;
  color: var(--muted) !important;
  font-size: .91rem !important;
  line-height: 1.48 !important;
}
.cookie-notice-actions {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  flex-wrap: wrap !important;
  gap: .55rem !important;
  flex: 0 0 auto !important;
}
.cookie-notice-actions .soft-button,
.cookie-notice-actions .primary-button {
  min-height: 38px !important;
  white-space: nowrap !important;
}
@media (max-width: 760px) {
  .cookie-notice {
    left: .55rem !important;
    right: .55rem !important;
    bottom: calc(4.85rem + env(safe-area-inset-bottom, 0px)) !important;
    display: grid !important;
    gap: .85rem !important;
    padding: .85rem !important;
  }
  .cookie-notice-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
  }
  .cookie-notice-actions .soft-button,
  .cookie-notice-actions .primary-button {
    width: 100% !important;
    justify-content: center !important;
  }
}

/* v295: Senderdetails gezielt korrigieren. Allgemeine Dialoge/Settings bleiben unverändert positioniert. */
.modal.station-details-dialog[open] {
  position: fixed !important;
  inset: 50% auto auto 50% !important;
  transform: translate(-50%, -50%) !important;
  margin: 0 !important;
  width: min(1120px, calc(100vw - 2rem)) !important;
  max-width: min(1120px, calc(100vw - 2rem)) !important;
  max-height: min(860px, calc(100dvh - 2rem)) !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  overscroll-behavior: contain !important;
}

.modal.station-details-dialog[open] #modalContent {
  display: block !important;
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow: hidden !important;
}

.modal.station-details-dialog[open] .modal-close {
  position: absolute !important;
  top: .95rem !important;
  right: .95rem !important;
  z-index: 20 !important;
}

.modal.station-details-dialog[open] .station-detail-modal {
  display: flex !important;
  flex-direction: column !important;
  gap: .95rem !important;
  min-height: 0 !important;
  max-height: calc(100dvh - 4.6rem) !important;
  overflow: hidden !important;
}

.modal.station-details-dialog[open] .detail-modal-heading,
.modal.station-details-dialog[open] .detail-head {
  flex: 0 0 auto !important;
}

.modal.station-details-dialog[open] .detail-modal-heading {
  padding-right: 3.4rem !important;
  margin-bottom: 0 !important;
}

.modal.station-details-dialog[open] .station-detail-modal-body {
  display: grid !important;
  gap: 1rem !important;
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow: auto !important;
  overscroll-behavior: contain !important;
  scrollbar-width: thin !important;
  scrollbar-gutter: stable !important;
  padding-right: .55rem !important;
  padding-bottom: .15rem !important;
}

@supports not (height: 100dvh) {
  .modal.station-details-dialog[open] .station-detail-modal {
    max-height: calc(100vh - 4.6rem) !important;
  }
}

@media (max-width: 760px) {
  .modal.station-details-dialog[open] {
    width: calc(100vw - 1rem) !important;
    max-width: calc(100vw - 1rem) !important;
    max-height: calc(100dvh - 1rem) !important;
  }

  .modal.station-details-dialog[open] .station-detail-modal {
    max-height: calc(100dvh - 3rem) !important;
  }

  .modal.station-details-dialog[open] .detail-modal-heading {
    padding-right: 2.9rem !important;
  }
}

/* v295: Daten-/Einstellungen-Dialog wieder an die gewohnte zentrale Modalposition setzen. */
#settingsPanel.settings-dialog[open] {
  position: fixed !important;
  inset: 50% auto auto 50% !important;
  transform: translate(-50%, -50%) !important;
  margin: 0 !important;
  width: min(980px, calc(100vw - 2rem)) !important;
  max-width: min(980px, calc(100vw - 2rem)) !important;
  max-height: min(720px, calc(100dvh - 2rem)) !important;
  overflow: hidden !important;
  display: block !important;
}
#settingsPanel.settings-dialog[open] .settings-dialog-shell {
  max-height: min(720px, calc(100dvh - 2rem)) !important;
  overflow: auto !important;
  scrollbar-width: thin !important;
}
@supports not (height: 100dvh) {
  #settingsPanel.settings-dialog[open],
  #settingsPanel.settings-dialog[open] .settings-dialog-shell {
    max-height: min(720px, calc(100vh - 2rem)) !important;
  }
}
@media (max-width: 760px) {
  #settingsPanel.settings-dialog[open] {
    width: calc(100vw - .5rem) !important;
    max-width: calc(100vw - .5rem) !important;
    max-height: calc(100dvh - .5rem) !important;
  }
  #settingsPanel.settings-dialog[open] .settings-dialog-shell {
    max-height: calc(100dvh - .5rem) !important;
  }
}


/* v296: Senderdetails-Dialog mit festem Kopf und sichtbarem inneren Scrollbereich ab Detailinhalt. */
.modal.station-details-dialog[open] {
  position: fixed !important;
  inset: 50% auto auto 50% !important;
  transform: translate(-50%, -50%) !important;
  margin: 0 !important;
  box-sizing: border-box !important;
  width: min(1120px, calc(100vw - 2rem)) !important;
  max-width: min(1120px, calc(100vw - 2rem)) !important;
  height: min(860px, calc(100dvh - 2rem)) !important;
  max-height: min(860px, calc(100dvh - 2rem)) !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  overscroll-behavior: contain !important;
}

.modal.station-details-dialog[open] #modalContent {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
  height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;
}

.modal.station-details-dialog[open] .station-detail-modal {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  gap: .95rem !important;
  overflow: hidden !important;
}

.modal.station-details-dialog[open] .detail-modal-heading,
.modal.station-details-dialog[open] .detail-head {
  flex: 0 0 auto !important;
}

.modal.station-details-dialog[open] .detail-modal-heading {
  padding-right: 3.4rem !important;
  margin-bottom: 0 !important;
}

.modal.station-details-dialog[open] .station-detail-modal-body {
  display: grid !important;
  gap: 1rem !important;
  flex: 1 1 auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  overscroll-behavior: contain !important;
  scrollbar-width: thin !important;
  scrollbar-color: color-mix(in oklab, var(--muted) 58%, transparent) transparent !important;
  scrollbar-gutter: stable !important;
  padding-right: .7rem !important;
  padding-bottom: .25rem !important;
}

.modal.station-details-dialog[open] .station-detail-modal-body::-webkit-scrollbar {
  width: 10px !important;
}

.modal.station-details-dialog[open] .station-detail-modal-body::-webkit-scrollbar-track {
  background: transparent !important;
  border-radius: 999px !important;
}

.modal.station-details-dialog[open] .station-detail-modal-body::-webkit-scrollbar-thumb {
  background: color-mix(in oklab, var(--muted) 58%, transparent) !important;
  border: 2px solid transparent !important;
  border-radius: 999px !important;
  background-clip: padding-box !important;
}

.modal.station-details-dialog[open] .station-detail-modal-body::-webkit-scrollbar-thumb:hover {
  background: color-mix(in oklab, var(--brand) 46%, var(--muted)) !important;
  border: 2px solid transparent !important;
  background-clip: padding-box !important;
}

@supports not (height: 100dvh) {
  .modal.station-details-dialog[open] {
    height: min(860px, calc(100vh - 2rem)) !important;
    max-height: min(860px, calc(100vh - 2rem)) !important;
  }
}

@media (max-width: 760px) {
  .modal.station-details-dialog[open] {
    width: calc(100vw - 1rem) !important;
    max-width: calc(100vw - 1rem) !important;
    height: calc(100dvh - 1rem) !important;
    max-height: calc(100dvh - 1rem) !important;
  }

  .modal.station-details-dialog[open] .detail-modal-heading {
    padding-right: 2.9rem !important;
  }

  .modal.station-details-dialog[open] .station-detail-modal-body {
    padding-right: .45rem !important;
  }
}

/* v297: Footer-/Info-Dialoge mit festem Kopf und internem Scrollbereich unterhalb der Überschrift. */
.modal[data-modal-type="help"][open],
.modal[data-modal-type="shortcuts"][open],
.modal[data-modal-type="troubleshooting"][open],
.modal[data-modal-type="privacy"][open],
.modal[data-modal-type="imprint"][open],
.modal[data-modal-type="contact"][open],
.modal[data-modal-type="suggest"][open] {
  position: fixed !important;
  inset: 50% auto auto 50% !important;
  transform: translate(-50%, -50%) !important;
  margin: 0 !important;
  width: min(880px, calc(100vw - 2rem)) !important;
  max-width: min(880px, calc(100vw - 2rem)) !important;
  max-height: min(86dvh, 860px) !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 0 !important;
  overscroll-behavior: contain !important;
}

.modal[data-modal-type="help"][open] #modalContent,
.modal[data-modal-type="shortcuts"][open] #modalContent,
.modal[data-modal-type="troubleshooting"][open] #modalContent,
.modal[data-modal-type="privacy"][open] #modalContent,
.modal[data-modal-type="imprint"][open] #modalContent,
.modal[data-modal-type="contact"][open] #modalContent,
.modal[data-modal-type="suggest"][open] #modalContent {
  display: flex !important;
  flex-direction: column !important;
  min-height: 0 !important;
  max-height: min(86dvh, 860px) !important;
  overflow: hidden !important;
  padding: 1.2rem 1.25rem 1.35rem !important;
}

.modal[data-modal-type="help"][open] .footer-modal-content,
.modal[data-modal-type="shortcuts"][open] .footer-modal-content,
.modal[data-modal-type="troubleshooting"][open] .footer-modal-content,
.modal[data-modal-type="privacy"][open] .footer-modal-content,
.modal[data-modal-type="imprint"][open] .footer-modal-content,
.modal[data-modal-type="contact"][open] .footer-modal-content,
.modal[data-modal-type="suggest"][open] .footer-modal-content {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
  min-height: 0 !important;
  max-height: 100% !important;
  gap: .95rem !important;
  padding-right: 0 !important;
  overflow: hidden !important;
}

.modal[data-modal-type="help"][open] .footer-modal-heading,
.modal[data-modal-type="shortcuts"][open] .footer-modal-heading,
.modal[data-modal-type="troubleshooting"][open] .footer-modal-heading,
.modal[data-modal-type="privacy"][open] .footer-modal-heading,
.modal[data-modal-type="imprint"][open] .footer-modal-heading,
.modal[data-modal-type="contact"][open] .footer-modal-heading,
.modal[data-modal-type="suggest"][open] .footer-modal-heading {
  flex: 0 0 auto !important;
  padding-right: 3.4rem !important;
  margin: 0 !important;
}

.footer-modal-scroll-body {
  display: grid !important;
  gap: .95rem !important;
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  overscroll-behavior: contain !important;
  scrollbar-width: thin !important;
  scrollbar-color: color-mix(in oklab, var(--muted) 58%, transparent) transparent !important;
  scrollbar-gutter: stable !important;
  padding-right: .65rem !important;
  padding-bottom: .1rem !important;
}

.footer-modal-scroll-body::-webkit-scrollbar {
  width: 10px !important;
}

.footer-modal-scroll-body::-webkit-scrollbar-track {
  background: transparent !important;
  border-radius: 999px !important;
}

.footer-modal-scroll-body::-webkit-scrollbar-thumb {
  background: color-mix(in oklab, var(--muted) 58%, transparent) !important;
  border: 2px solid transparent !important;
  border-radius: 999px !important;
  background-clip: padding-box !important;
}

.footer-modal-scroll-body::-webkit-scrollbar-thumb:hover {
  background: color-mix(in oklab, var(--brand) 46%, var(--muted)) !important;
  border: 2px solid transparent !important;
  background-clip: padding-box !important;
}

@supports not (height: 100dvh) {
  .modal[data-modal-type="help"][open],
  .modal[data-modal-type="shortcuts"][open],
  .modal[data-modal-type="troubleshooting"][open],
  .modal[data-modal-type="privacy"][open],
  .modal[data-modal-type="imprint"][open],
  .modal[data-modal-type="contact"][open],
  .modal[data-modal-type="suggest"][open],
  .modal[data-modal-type="help"][open] #modalContent,
  .modal[data-modal-type="shortcuts"][open] #modalContent,
  .modal[data-modal-type="troubleshooting"][open] #modalContent,
  .modal[data-modal-type="privacy"][open] #modalContent,
  .modal[data-modal-type="imprint"][open] #modalContent,
  .modal[data-modal-type="contact"][open] #modalContent,
  .modal[data-modal-type="suggest"][open] #modalContent {
    max-height: min(86vh, 860px) !important;
  }
}

@media (max-width: 760px) {
  .modal[data-modal-type="help"][open],
  .modal[data-modal-type="shortcuts"][open],
  .modal[data-modal-type="troubleshooting"][open],
  .modal[data-modal-type="privacy"][open],
  .modal[data-modal-type="imprint"][open],
  .modal[data-modal-type="contact"][open],
  .modal[data-modal-type="suggest"][open] {
    width: calc(100vw - .5rem) !important;
    max-width: calc(100vw - .5rem) !important;
    max-height: calc(100dvh - .5rem) !important;
  }

  .modal[data-modal-type="help"][open] #modalContent,
  .modal[data-modal-type="shortcuts"][open] #modalContent,
  .modal[data-modal-type="troubleshooting"][open] #modalContent,
  .modal[data-modal-type="privacy"][open] #modalContent,
  .modal[data-modal-type="imprint"][open] #modalContent,
  .modal[data-modal-type="contact"][open] #modalContent,
  .modal[data-modal-type="suggest"][open] #modalContent {
    max-height: calc(100dvh - .5rem) !important;
    padding: .95rem .9rem 1.05rem !important;
  }

  .modal[data-modal-type="help"][open] .footer-modal-heading,
  .modal[data-modal-type="shortcuts"][open] .footer-modal-heading,
  .modal[data-modal-type="troubleshooting"][open] .footer-modal-heading,
  .modal[data-modal-type="privacy"][open] .footer-modal-heading,
  .modal[data-modal-type="imprint"][open] .footer-modal-heading,
  .modal[data-modal-type="contact"][open] .footer-modal-heading,
  .modal[data-modal-type="suggest"][open] .footer-modal-heading {
    padding-right: 2.9rem !important;
  }

  .footer-modal-scroll-body {
    padding-right: .45rem !important;
  }
}


/* ===== css/139-light-select-controls-v299.css ===== */
/* v299: Helle, lesbare Select- und Dropdown-Farben im Light-Mode.
   Gilt gezielt für native Selects und die vorhandenen Custom-Selects, ohne den Dark-Mode anzufassen. */
html[data-theme="light"] input,
html[data-theme="light"] select,
html[data-theme="light"] textarea {
  background: #ffffff !important;
  color: #1f2430 !important;
  border-color: rgba(24, 31, 46, .18) !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.72) !important;
}

html[data-theme="light"] input::placeholder,
html[data-theme="light"] textarea::placeholder {
  color: #7c8597 !important;
}

html[data-theme="light"] select:disabled,
html[data-theme="light"] input:disabled,
html[data-theme="light"] textarea:disabled,
html[data-theme="light"] .station-chooser-filter-grid select:disabled,
html[data-theme="light"] .station-chooser-filter-grid input:disabled {
  background: #eef2f8 !important;
  color: #747d8f !important;
  border-color: rgba(24, 31, 46, .13) !important;
  opacity: 1 !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.65) !important;
}

html[data-theme="light"] .app-select-button,
html[data-theme="light"] .variant-select-button,
html[data-theme="light"] #filterPanel.filter-dialog .app-select-button {
  background: linear-gradient(180deg, #ffffff, #f4f7fc) !important;
  color: #1f2430 !important;
  border-color: rgba(24, 31, 46, .18) !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.78), 0 1px 0 rgba(24,31,46,.04) !important;
}

html[data-theme="light"] .app-select-button::after,
html[data-theme="light"] .variant-select-button::after {
  color: #667085 !important;
}

html[data-theme="light"] .app-select-button.is-disabled,
html[data-theme="light"] .app-select-button:disabled,
html[data-theme="light"] .variant-select-button.is-disabled,
html[data-theme="light"] .variant-select-button:disabled {
  background: linear-gradient(180deg, #edf1f7, #e6ebf3) !important;
  color: #747d8f !important;
  border-color: rgba(24, 31, 46, .13) !important;
  opacity: 1 !important;
  cursor: not-allowed !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.66) !important;
}

html[data-theme="light"] .app-select-button.is-disabled::after,
html[data-theme="light"] .app-select-button:disabled::after,
html[data-theme="light"] .variant-select-button.is-disabled::after,
html[data-theme="light"] .variant-select-button:disabled::after {
  color: #9aa3b4 !important;
}

html[data-theme="light"] .app-select-menu,
html[data-theme="light"] .variant-select-menu {
  background: radial-gradient(circle at top left, rgba(255,56,92,.08), transparent 38%), #ffffff !important;
  color: #1f2430 !important;
  border-color: rgba(255,56,92,.36) !important;
  box-shadow: 0 20px 52px rgba(28, 38, 68, .20) !important;
}

html[data-theme="light"] .app-select-option,
html[data-theme="light"] .variant-option {
  color: #1f2430 !important;
}

html[data-theme="light"] .app-select-option:hover,
html[data-theme="light"] .app-select-option:focus-visible,
html[data-theme="light"] .app-select-option.selected,
html[data-theme="light"] .variant-option:hover,
html[data-theme="light"] .variant-option:focus-visible,
html[data-theme="light"] .variant-option.selected {
  background: #ffe8ef !important;
  color: #111827 !important;
}

html[data-theme="light"] .station-chooser-filter-grid {
  background: radial-gradient(circle at 0 0, rgba(255,56,92,.08), transparent 32%), rgba(255,255,255,.78) !important;
}

html[data-theme="light"] #filterPanel.filter-dialog .filter-grid input,
html[data-theme="light"] #filterPanel.filter-dialog .filter-grid select {
  background: #ffffff !important;
  color: #1f2430 !important;
  border-color: rgba(24, 31, 46, .18) !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.72) !important;
}
