/* ============================================================
 * MMB Mini App — visual style
 *
 * Design notes:
 * - Telegram theme variables drive the palette: the app blends with
 *   whichever Telegram client the user is in (light/dark/custom).
 * - Hero shows live album art; the same image is used as a heavily
 *   blurred backdrop behind the whole UI (`#bg-art`) for a Spotify-ish
 *   ambient look that still respects Telegram's bg color underneath.
 * - All animated transitions use cubic-bezier(.2,.7,.2,1) (UI ease).
 * ============================================================ */

:root {
  --bg: var(--tg-theme-bg-color, #17212b);
  --fg: var(--tg-theme-text-color, #ffffff);
  --hint: var(--tg-theme-hint-color, #8a99ad);
  --link: var(--tg-theme-link-color, #6ab2f2);
  --btn: var(--tg-theme-button-color, #5288c1);
  --btn-fg: var(--tg-theme-button-text-color, #ffffff);
  --sec: var(--tg-theme-secondary-bg-color, #232e3c);
  --accent: var(--tg-theme-accent-text-color, var(--btn));
  --danger: #ec5555;

  /* Glass surfaces — partially transparent on top of the blurred backdrop. */
  --glass: color-mix(in srgb, var(--sec) 78%, transparent);
  --glass-strong: color-mix(in srgb, var(--sec) 90%, transparent);
  --line: color-mix(in srgb, var(--fg) 8%, transparent);

  --radius: 16px;
  --radius-sm: 12px;
  --ease: cubic-bezier(.2, .7, .2, 1);
  --shadow-card: 0 6px 24px -8px rgba(0, 0, 0, .35);
}

/* Older browsers without color-mix get sane fallbacks. */
@supports not (background: color-mix(in srgb, white, black)) {
  :root {
    --glass: var(--sec);
    --glass-strong: var(--sec);
    --line: rgba(255, 255, 255, .08);
  }
}

* { box-sizing: border-box; }
html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text",
               "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
  font-size: 15px;
  line-height: 1.4;
  -webkit-tap-highlight-color: transparent;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overscroll-behavior-y: contain;
}

/* ---------- Backdrop (blurred album art) ---------- */
#bg-art, #bg-veil {
  position: fixed; inset: 0; z-index: -1;
  pointer-events: none;
}
#bg-art {
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  filter: blur(80px) saturate(140%);
  transform: scale(1.2);
  opacity: 0;
  transition: opacity .8s var(--ease), background-image .4s var(--ease);
}
#bg-art.has-art { opacity: .55; }
#bg-veil {
  background:
    radial-gradient(ellipse at top, transparent 0%, var(--bg) 70%),
    linear-gradient(to bottom, color-mix(in srgb, var(--bg) 50%, transparent), var(--bg) 80%);
}
@supports not (background: color-mix(in srgb, white, black)) {
  #bg-veil { background: linear-gradient(to bottom, rgba(0,0,0,.4), var(--bg) 80%); }
}

/* ---------- Aurora gradient mesh (Sprint 3.3) ----------
 * Три медленно дрейфующих радиальных пятна поверх blurred art —
 * добавляют «движение» даже когда обложки нет (mix-blend-mode: screen). */
#bg-aurora {
  position: fixed; inset: 0; z-index: -1;
  pointer-events: none;
  overflow: hidden;
  mix-blend-mode: screen;
  opacity: .55;
}
#bg-aurora .aurora {
  position: absolute;
  width: 70vmax; height: 70vmax;
  border-radius: 50%;
  filter: blur(90px);
  will-change: transform;
}
#bg-aurora .a1 {
  background: radial-gradient(circle, color-mix(in srgb, var(--btn) 70%, transparent), transparent 60%);
  top: -20%; left: -20%;
  animation: aurora-1 22s ease-in-out infinite alternate;
}
#bg-aurora .a2 {
  background: radial-gradient(circle, color-mix(in srgb, #b14ef0 60%, transparent), transparent 60%);
  bottom: -25%; right: -20%;
  animation: aurora-2 28s ease-in-out infinite alternate;
}
#bg-aurora .a3 {
  background: radial-gradient(circle, color-mix(in srgb, #4ef0c2 50%, transparent), transparent 60%);
  top: 30%; right: -30%;
  animation: aurora-3 34s ease-in-out infinite alternate;
}
@supports not (background: color-mix(in srgb, white, black)) {
  #bg-aurora .a1 { background: radial-gradient(circle, rgba(82,136,193,.7), transparent 60%); }
  #bg-aurora .a2 { background: radial-gradient(circle, rgba(177,78,240,.6), transparent 60%); }
  #bg-aurora .a3 { background: radial-gradient(circle, rgba(78,240,194,.5), transparent 60%); }
}
@keyframes aurora-1 { from { transform: translate(0,0) rotate(0); }   to { transform: translate(15vw,12vh) rotate(40deg); } }
@keyframes aurora-2 { from { transform: translate(0,0) rotate(0); }   to { transform: translate(-12vw,-8vh) rotate(-30deg); } }
@keyframes aurora-3 { from { transform: translate(0,0) rotate(0); }   to { transform: translate(-20vw,15vh) rotate(25deg); } }

#app {
  max-width: 560px;
  margin: 0 auto;
  padding: 14px 14px calc(96px + env(safe-area-inset-bottom));
  display: flex; flex-direction: column;
  gap: 12px;
}

/* ---------- Cards (glass) ---------- */
.card {
  background: var(--glass);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-card);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  backdrop-filter: blur(20px) saturate(140%);
}

/* ---------- Hero ---------- */
.hero {
  padding: 18px 18px 16px;
  display: flex; flex-direction: column; align-items: center;
  gap: 14px;
  text-align: center;
}
.cover-wrap {
  position: relative;
  width: min(62vw, 280px);
  aspect-ratio: 1;
  border-radius: 18px;
  overflow: hidden;
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--btn) 30%, var(--sec)),
    color-mix(in srgb, var(--btn) 8%, var(--bg)));
  box-shadow: 0 14px 40px -10px rgba(0, 0, 0, .55);
  transition: transform .3s var(--ease);
}
.cover-wrap:active { transform: scale(.97); }
#cover {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  cursor: pointer;
  opacity: 0;
  transition: opacity .35s var(--ease);
}
#cover.loaded { opacity: 1; }
#cover-fallback {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  color: color-mix(in srgb, var(--fg) 65%, transparent);
  pointer-events: none;
}
@supports not (background: color-mix(in srgb, white, black)) {
  #cover-fallback { color: rgba(255,255,255,.65); }
}
#cover-fallback svg { width: 38%; height: 38%; }

/* Subtle pulsing glow when something is playing. */
.cover-glow {
  position: absolute; inset: -8px;
  border-radius: 22px;
  background: radial-gradient(closest-side,
    color-mix(in srgb, var(--btn) 60%, transparent), transparent 70%);
  opacity: 0;
  transition: opacity .5s var(--ease);
  z-index: -1;
  filter: blur(12px);
}
body.playing .cover-glow { opacity: .9; animation: pulse 3.4s ease-in-out infinite; }
@keyframes pulse {
  0%, 100% { transform: scale(1); opacity: .65; }
  50%      { transform: scale(1.07); opacity: .95; }
}

.meta { width: 100%; min-width: 0; }
.title {
  font-size: 18px; font-weight: 700;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  letter-spacing: -.01em;
}
.artist {
  color: var(--hint); font-size: 14px; margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* ---------- Progress ---------- */
.progress {
  position: relative;
  width: 100%; height: 22px;
  cursor: pointer;
  margin-top: 2px;
}
.progress-track {
  position: absolute; left: 0; right: 0; top: 50%;
  height: 4px; transform: translateY(-50%);
  background: var(--line);
  border-radius: 4px;
}
.progress-fill {
  position: absolute; left: 0; top: 50%;
  height: 4px; transform: translateY(-50%);
  width: 0%;
  background: linear-gradient(90deg, var(--btn), color-mix(in srgb, var(--btn) 50%, #fff));
  border-radius: 4px;
  transition: width .5s linear;
  box-shadow: 0 0 12px color-mix(in srgb, var(--btn) 60%, transparent);
}
@supports not (background: color-mix(in srgb, white, black)) {
  .progress-fill {
    background: var(--btn);
    box-shadow: 0 0 12px rgba(82,136,193,.6);
  }
}
.progress-thumb {
  position: absolute; top: 50%;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--fg);
  transform: translate(-50%, -50%) scale(0);
  transition: transform .2s var(--ease), left .5s linear;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .4);
}
.progress:hover .progress-thumb,
.progress.active .progress-thumb { transform: translate(-50%, -50%) scale(1); }

.time-row {
  display: flex; justify-content: space-between;
  width: 100%;
  font-size: 12px;
  color: var(--hint);
  font-variant-numeric: tabular-nums;
  margin-top: -2px;
}

/* ---------- Transport ---------- */
.transport {
  display: flex; align-items: center; justify-content: center;
  gap: 14px;
  padding: 4px 0;
}
.ctrl {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--glass);
  border: 1px solid var(--line);
  color: var(--fg);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: transform .15s var(--ease), background .2s var(--ease), filter .15s;
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  box-shadow: var(--shadow-card);
}
.ctrl svg, .ctrl iconify-icon { width: 26px; height: 26px; }
.ctrl:active { transform: scale(.92); filter: brightness(1.2); }
.ctrl-play {
  width: 72px; height: 72px;
  background: linear-gradient(135deg, var(--btn), color-mix(in srgb, var(--btn) 60%, #fff));
  color: var(--btn-fg);
  border: none;
  box-shadow:
    0 10px 28px -6px color-mix(in srgb, var(--btn) 70%, transparent),
    0 2px 0 0 rgba(255, 255, 255, .12) inset;
}
@supports not (background: color-mix(in srgb, white, black)) {
  .ctrl-play {
    background: var(--btn);
    box-shadow: 0 10px 28px -6px rgba(82,136,193,.7);
  }
}
.ctrl-play svg { width: 32px; height: 32px; }

/* Shuffle / Repeat side buttons — smaller, dim when off, accent when on. */
.ctrl-mode {
  width: 44px; height: 44px;
  background: transparent;
  border: 1px solid transparent;
  color: var(--hint);
  box-shadow: none;
}
.ctrl-mode svg { width: 20px; height: 20px; }
.ctrl-mode.active {
  color: var(--btn);
  background: color-mix(in srgb, var(--btn) 14%, transparent);
  border-color: color-mix(in srgb, var(--btn) 35%, transparent);
}
@supports not (background: color-mix(in srgb, white, black)) {
  .ctrl-mode.active {
    color: var(--btn);
    background: rgba(82,136,193,.14);
    border-color: rgba(82,136,193,.35);
  }
}

/* ---------- Seek chips ---------- */
.seek-row {
  display: flex; justify-content: space-between;
  gap: 8px;
}
.chip {
  flex: 1;
  height: 40px;
  background: var(--glass);
  color: var(--fg);
  border: 1px solid var(--line);
  border-radius: 12px;
  font: inherit; font-size: 13px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: transform .15s var(--ease), background .2s var(--ease);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
}
.chip:active { transform: scale(.94); background: var(--btn); color: var(--btn-fg); }
.chip.danger { color: var(--danger); }
.chip.danger:active { background: var(--danger); color: #fff; }
.chip svg, .chip iconify-icon { width: 16px; height: 16px; vertical-align: -2px; }

/* ---------- Volume ---------- */
.vol { padding: 14px 16px; }
.vol-head {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 13px; color: var(--hint);
  margin-bottom: 10px;
}
.vol-label {
  font-variant-numeric: tabular-nums;
  color: var(--fg);
  font-weight: 600;
}
.vol-row {
  display: grid;
  grid-template-columns: 40px 1fr 40px 40px;
  gap: 10px;
  align-items: center;
}
.iconbtn {
  width: 40px; height: 40px;
  border-radius: 10px;
  background: color-mix(in srgb, var(--bg) 50%, transparent);
  color: var(--fg);
  border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: transform .12s var(--ease), background .2s;
}
@supports not (background: color-mix(in srgb, white, black)) {
  .iconbtn { background: rgba(0,0,0,.2); }
}
.iconbtn svg, .iconbtn iconify-icon { width: 20px; height: 20px; }
.iconbtn:active { transform: scale(.9); background: var(--btn); color: var(--btn-fg); }
.iconbtn-toggle.muted { background: var(--danger); color: #fff; border-color: transparent; }

/* Custom range — track + thumb. */
input[type=range] {
  -webkit-appearance: none; appearance: none;
  width: 100%; height: 24px;
  background: transparent;
  cursor: pointer;
}
input[type=range]::-webkit-slider-runnable-track {
  height: 5px;
  background: linear-gradient(to right,
    var(--btn) 0%, var(--btn) var(--vol-pct, 50%),
    var(--line) var(--vol-pct, 50%), var(--line) 100%);
  border-radius: 3px;
}
input[type=range]::-moz-range-track {
  height: 5px;
  background: var(--line);
  border-radius: 3px;
}
input[type=range]::-moz-range-progress {
  height: 5px;
  background: var(--btn);
  border-radius: 3px;
}
input[type=range]::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 18px; height: 18px;
  margin-top: -7px;
  border-radius: 50%;
  background: var(--fg);
  box-shadow: 0 2px 6px rgba(0, 0, 0, .4);
  cursor: pointer;
  transition: transform .15s var(--ease);
}
input[type=range]::-webkit-slider-thumb:active { transform: scale(1.2); }
input[type=range]::-moz-range-thumb {
  width: 18px; height: 18px;
  border: none; border-radius: 50%;
  background: var(--fg);
  box-shadow: 0 2px 6px rgba(0, 0, 0, .4);
}

/* ---------- Tabs ---------- */
.tabs {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 4px;
  background: var(--glass);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 6px;
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
}
.tab {
  background: transparent;
  border: none;
  color: var(--hint);
  font: inherit; font-size: 12px;
  padding: 8px 4px;
  border-radius: 10px;
  cursor: pointer;
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  transition: background .25s var(--ease), color .25s var(--ease), transform .15s var(--ease);
}
.tab .tab-icon { font-size: 18px; line-height: 1; }
.tab iconify-icon.tab-icon { width: 20px; height: 20px; }
.tab .tab-label { font-size: 11px; font-weight: 500; }
.tab:active { transform: scale(.95); }
.tab.active {
  background: var(--btn);
  color: var(--btn-fg);
  box-shadow: 0 4px 14px -4px color-mix(in srgb, var(--btn) 60%, transparent);
}
@supports not (background: color-mix(in srgb, white, black)) {
  .tab.active { box-shadow: 0 4px 14px -4px rgba(82,136,193,.6); }
}

/* ---------- Search ---------- */
#search {
  width: 100%;
  height: 40px;
  background: var(--glass);
  border: 1px solid var(--line);
  border-radius: 12px;
  color: var(--fg);
  font: inherit;
  padding: 0 14px;
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  outline: none;
  transition: border-color .2s, background .2s;
}
#search:focus { border-color: var(--btn); }
#search::placeholder { color: var(--hint); }

/* ---------- Content list ---------- */
#content {
  display: flex; flex-direction: column; gap: 6px;
  animation: fadeIn .35s var(--ease);
}
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.item {
  display: flex; align-items: center; gap: 10px;
  width: 100%;
  background: var(--glass);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px 14px;
  text-align: left;
  min-height: 48px;
  color: var(--fg);
  font: inherit;
  cursor: pointer;
  position: relative;
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  transition: transform .12s var(--ease), background .2s, border-color .2s;
}
.item:active { transform: scale(.98); background: var(--glass-strong); }
.item.now-playing {
  border-color: var(--btn);
  background: color-mix(in srgb, var(--btn) 14%, var(--glass));
}
.item.now-playing::before {
  content: ""; position: absolute;
  left: 0; top: 12px; bottom: 12px; width: 3px;
  background: var(--btn);
  border-radius: 0 3px 3px 0;
}
.item .name {
  flex: 1; min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  font-size: 14px;
}
.item .badge {
  color: var(--hint);
  font-size: 12px;
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
}

.hint {
  color: var(--hint);
  padding: 24px;
  text-align: center;
  font-size: 14px;
}

/* Stale-cache banner. */
.banner {
  text-align: center;
  font-size: 12px;
  color: var(--hint);
  padding: 8px;
  background: color-mix(in srgb, var(--btn) 8%, transparent);
  border: 1px solid var(--line);
  border-radius: 10px;
}
@supports not (background: color-mix(in srgb, white, black)) {
  .banner { background: rgba(82,136,193,.08); }
}

/* ---------- Devices grid ---------- */
.dev-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.dev-grid .item { padding: 16px 12px; min-height: 56px; }

/* ---------- Sleep timer row ---------- */
.sleep-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  padding: 0 2px;
  font-size: 13px;
}
.sleep-chip {
  font-size: 12px;
  padding: 6px 12px;
  min-height: 32px;
}
.sleep-chip.active {
  background: color-mix(in srgb, var(--btn) 24%, transparent);
  border-color: var(--btn);
  color: var(--btn);
}
.sleep-status {
  margin-left: auto;
  color: var(--btn);
  font-variant-numeric: tabular-nums;
  font-size: 12px;
}

/* ---------- Equalizer (поверх hero, активен когда body.playing) ---------- */
.eq {
  position: absolute;
  bottom: 10px; right: 10px;
  display: flex; align-items: flex-end;
  gap: 3px;
  height: 22px; width: 30px;
  padding: 4px 5px;
  background: rgba(0, 0, 0, .42);
  border-radius: 8px;
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  opacity: 0;
  transition: opacity .25s var(--ease);
  pointer-events: none;
}
.eq span {
  width: 3px;
  background: var(--btn);
  border-radius: 2px;
  height: 30%;
  box-shadow: 0 0 6px color-mix(in srgb, var(--btn) 70%, transparent);
}
body.playing .eq { opacity: 1; }
body.playing .eq span { animation: eqbounce 0.9s ease-in-out infinite; }
body.playing .eq span:nth-child(1) { animation-delay: -.30s; animation-duration: .85s; }
body.playing .eq span:nth-child(2) { animation-delay: -.15s; animation-duration: 1.05s; }
body.playing .eq span:nth-child(3) { animation-delay: -.50s; animation-duration: .75s; }
body.playing .eq span:nth-child(4) { animation-delay: -.10s; animation-duration: .95s; }
@keyframes eqbounce {
  0%, 100% { height: 25%; }
  50%      { height: 95%; }
}

/* ---------- Skeleton shimmer (loader для списков) ---------- */
.skeleton {
  display: flex; flex-direction: column; gap: 6px;
}
.skeleton-row {
  height: 44px;
  border-radius: var(--radius-sm);
  background: linear-gradient(90deg,
    color-mix(in srgb, var(--fg) 6%, transparent) 0%,
    color-mix(in srgb, var(--fg) 14%, transparent) 50%,
    color-mix(in srgb, var(--fg) 6%, transparent) 100%);
  background-size: 200% 100%;
  animation: shimmer 1.4s linear infinite;
}
@supports not (background: color-mix(in srgb, white, black)) {
  .skeleton-row {
    background: linear-gradient(90deg, rgba(255,255,255,.06), rgba(255,255,255,.14), rgba(255,255,255,.06));
    background-size: 200% 100%;
  }
}
@keyframes shimmer { from { background-position: 200% 0; } to { background-position: -200% 0; } }

/* ---------- Ripple-эффект (Material-style) ---------- */
.has-ripple { position: relative; overflow: hidden; isolation: isolate; }
.ripple {
  position: absolute;
  border-radius: 50%;
  transform: translate(-50%, -50%) scale(0);
  background: color-mix(in srgb, var(--fg) 22%, transparent);
  pointer-events: none;
  animation: ripple-grow .55s var(--ease) forwards;
  z-index: 0;
}
@supports not (background: color-mix(in srgb, white, black)) {
  .ripple { background: rgba(255,255,255,.22); }
}
@keyframes ripple-grow {
  to { transform: translate(-50%, -50%) scale(1); opacity: 0; }
}

/* Усиленный glow на play-кнопке когда играет. */
body.playing .ctrl-play {
  animation: play-pulse 2.6s ease-in-out infinite;
}
@keyframes play-pulse {
  0%, 100% { box-shadow: 0 10px 28px -6px color-mix(in srgb, var(--btn) 70%, transparent), 0 0 0 0 color-mix(in srgb, var(--btn) 50%, transparent); }
  50%      { box-shadow: 0 14px 36px -4px color-mix(in srgb, var(--btn) 90%, transparent), 0 0 0 8px color-mix(in srgb, var(--btn) 0%, transparent); }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* ---------- Topbar ---------- */
.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 4px 4px 0;
  margin-bottom: -4px;
}
.brand {
  display: inline-flex; align-items: center; gap: 8px;
  font-weight: 700; letter-spacing: .04em;
  font-size: 14px;
  color: var(--fg);
  opacity: .85;
}
.brand iconify-icon { color: var(--btn); animation: spin 12s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.topbtn {
  width: 38px; height: 38px;
  background: var(--glass);
  border: 1px solid var(--line);
}

/* ---------- Quick actions grid ---------- */
.quick-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}
.quick {
  display: flex; flex-direction: column; align-items: flex-start;
  justify-content: center;
  gap: 2px;
  padding: 14px 14px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: var(--glass);
  color: var(--fg);
  cursor: pointer;
  text-align: left;
  position: relative;
  overflow: hidden;
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  backdrop-filter: blur(20px) saturate(140%);
  box-shadow: var(--shadow-card);
  transition: transform .15s var(--ease), filter .15s var(--ease);
  min-height: 78px;
}
.quick:active { transform: scale(.97); filter: brightness(1.15); }
.quick iconify-icon {
  color: var(--btn);
  filter: drop-shadow(0 0 12px color-mix(in srgb, var(--btn) 60%, transparent));
}
.q-label { font-weight: 700; font-size: 15px; }
.q-sub { color: var(--hint); font-size: 12px; }
/* Цветовые акценты для четырёх плиток */
.quick.q-rand    { background: linear-gradient(135deg, color-mix(in srgb, #b14ef0 26%, var(--glass)), var(--glass)); }
.quick.q-rand iconify-icon { color: #d18cff; }
.quick.q-dl      { background: linear-gradient(135deg, color-mix(in srgb, #4ef0c2 22%, var(--glass)), var(--glass)); }
.quick.q-dl iconify-icon { color: #6ff0c2; }
.quick.q-fav     { background: linear-gradient(135deg, color-mix(in srgb, #ec5555 22%, var(--glass)), var(--glass)); }
.quick.q-fav iconify-icon { color: #ff7a7a; }
.quick.q-shuffle { background: linear-gradient(135deg, color-mix(in srgb, var(--btn) 26%, var(--glass)), var(--glass)); }
.quick.q-shuffle.active {
  border-color: color-mix(in srgb, var(--btn) 60%, transparent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--btn) 35%, transparent), var(--shadow-card);
}
@supports not (background: color-mix(in srgb, white, black)) {
  .quick.q-rand, .quick.q-dl, .quick.q-fav, .quick.q-shuffle { background: var(--glass); }
}

/* ---------- Theme picker ---------- */
.theme-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  padding: 4px 0 8px;
}
.theme-card {
  display: flex; flex-direction: column; align-items: center;
  gap: 4px;
  padding: 14px 6px;
  border-radius: var(--radius-sm);
  background: var(--sec);
  border: 1.5px solid transparent;
  color: var(--fg);
  cursor: pointer;
  transition: transform .12s var(--ease), border-color .15s var(--ease);
}
.theme-card:active { transform: scale(.95); }
.theme-card.active { border-color: var(--btn); box-shadow: 0 0 0 2px color-mix(in srgb, var(--btn) 30%, transparent); }
.theme-card iconify-icon { color: var(--btn); }
.theme-card span { font-weight: 600; font-size: 13px; }
.theme-card small { color: var(--hint); font-size: 11px; }

/* ---------- Theme overrides (data-theme on <html>) ---------- */
html[data-theme="night"] {
  --bg: #0e1726;
  --fg: #e8eef7;
  --hint: #7a8cab;
  --sec: #1a2436;
  --btn: #6aa9ff;
  --btn-fg: #fff;
  --link: #88bdff;
  --accent: #88bdff;
}
html[data-theme="amoled"] {
  --bg: #000;
  --fg: #f3f3f3;
  --hint: #6e6e6e;
  --sec: #0d0d0d;
  --btn: #d4af37;
  --btn-fg: #000;
  --link: #d4af37;
  --accent: #d4af37;
}
html[data-theme="neon"] {
  --bg: #0a0420;
  --fg: #f0e7ff;
  --hint: #8c7ec4;
  --sec: #160a35;
  --btn: #ff39c8;
  --btn-fg: #fff;
  --link: #4ef0ff;
  --accent: #4ef0ff;
}
html[data-theme="neon"] body { background: radial-gradient(ellipse at top, #1a0850 0%, #06031a 80%); }
html[data-theme="light"] {
  --bg: #f5f6fa;
  --fg: #15171c;
  --hint: #707686;
  --sec: #ffffff;
  --btn: #5288c1;
  --btn-fg: #fff;
  --link: #4577b3;
  --accent: #4577b3;
  --shadow-card: 0 6px 18px -8px rgba(0,0,0,.18);
}
html[data-theme="light"] #bg-veil {
  background: radial-gradient(ellipse at top, transparent 0%, var(--bg) 70%),
              linear-gradient(to bottom, color-mix(in srgb, var(--bg) 50%, transparent), var(--bg) 80%);
}
html[data-theme="ocean"] {
  --bg: #04222a;
  --fg: #e7faff;
  --hint: #6ea4b3;
  --sec: #0a3743;
  --btn: #2cd5d9;
  --btn-fg: #04222a;
  --link: #2cd5d9;
  --accent: #2cd5d9;
}

/* ---------- Bottom sheet (long-press menu) ---------- */
.sheet-backdrop {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, .55);
  z-index: 100;
  opacity: 0;
  transition: opacity .25s var(--ease);
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
}
.sheet-backdrop:not(.hidden) { opacity: 1; }

.sheet {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 101;
  background: var(--glass-strong);
  border-top: 1px solid var(--line);
  border-radius: 20px 20px 0 0;
  padding: 12px 16px calc(20px + env(safe-area-inset-bottom));
  -webkit-backdrop-filter: blur(30px) saturate(160%);
  backdrop-filter: blur(30px) saturate(160%);
  box-shadow: 0 -10px 40px -10px rgba(0, 0, 0, .5);
  transform: translateY(100%);
  transition: transform .3s var(--ease);
  max-width: 560px;
  margin: 0 auto;
}
.sheet:not(.hidden) { transform: translateY(0); }
.sheet-handle {
  width: 40px; height: 4px;
  background: var(--hint);
  border-radius: 2px;
  margin: 0 auto 14px;
  opacity: .5;
}
.sheet-title {
  font-size: 14px;
  color: var(--hint);
  text-align: center;
  margin-bottom: 12px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sheet-actions {
  display: flex; flex-direction: column; gap: 6px;
}
.sheet-action {
  display: flex; align-items: center; gap: 12px;
  background: transparent;
  border: none;
  color: var(--fg);
  font: inherit; font-size: 15px;
  padding: 14px 12px;
  border-radius: 12px;
  text-align: left;
  cursor: pointer;
  transition: background .15s var(--ease);
}
.sheet-action:active { background: var(--glass); }
.sheet-action svg { width: 22px; height: 22px; flex-shrink: 0; opacity: .9; }
.sheet-action.danger { color: var(--danger); }
.sheet-action .ico-fav.on { color: var(--danger); }

.hidden { display: none !important; }

/* ---------- Toast ---------- */
.toast {
  position: fixed;
  left: 50%;
  bottom: calc(28px + env(safe-area-inset-bottom));
  transform: translate(-50%, 20px);
  z-index: 200;
  background: var(--glass-strong);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 10px 18px;
  font-size: 14px;
  color: var(--fg);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  box-shadow: 0 6px 24px -6px rgba(0, 0, 0, .5);
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s var(--ease), transform .25s var(--ease);
  max-width: 80vw;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.toast.show {
  opacity: 1;
  transform: translate(-50%, 0);
}

/* ---------- Heart (favorite) badge in list items ---------- */
.fav-btn {
  width: 32px; height: 32px;
  border-radius: 8px;
  background: transparent;
  border: none;
  color: var(--hint);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  transition: color .15s, transform .12s var(--ease);
}
.fav-btn svg { width: 18px; height: 18px; }
.fav-btn:active { transform: scale(.85); }
.fav-btn.on { color: var(--danger); }

/* Playlist row gets a big play button on the right. */
.pl-play-btn {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: none;
  background: var(--btn);
  color: var(--btn-fg);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  cursor: pointer;
  transition: transform .12s var(--ease);
  box-shadow: 0 4px 12px -3px color-mix(in srgb, var(--btn) 70%, transparent);
}
@supports not (background: color-mix(in srgb, white, black)) {
  .pl-play-btn { box-shadow: 0 4px 12px -3px rgba(82,136,193,.7); }
}
.pl-play-btn svg { width: 16px; height: 16px; margin-left: 1px; }
.pl-play-btn:active { transform: scale(.88); }

/* Section header inside the list (e.g. "✨ Избранное"). */
.section-head {
  font-size: 11px; font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--hint);
  padding: 12px 4px 4px;
}
