:root{
  color-scheme: dark;
  --bg0:#07080b; --bg1:#0b0d12;
  --card:rgba(18,22,31,.78);
  --border:rgba(255,255,255,.10);
  --border2:rgba(255,255,255,.06);
  --text:rgba(255,255,255,.92);
  --muted:rgba(255,255,255,.70);
  --accent:#ff2e2e;
  --radius:16px;
  --shadow:0 10px 30px rgba(0,0,0,.45);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; padding:0 14px 26px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:
    radial-gradient(900px 500px at 15% -10%, rgba(255,46,46,.16), transparent 60%),
    radial-gradient(900px 600px at 85% 0%, rgba(255,46,46,.10), transparent 65%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
  -webkit-font-smoothing:antialiased;
}

.wrap{width:80%;max-width:1800px;margin:0 auto;display:flex;flex-direction:column;gap:12px;padding-top:14px}
@media (max-width:900px){.wrap{width:95%}}

.stickyHeaderOuter{
  position:sticky;top:0;z-index:9999;
  padding:12px 0 10px;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  background: linear-gradient(180deg, rgba(7,8,11,.94), rgba(7,8,11,.72));
  border-bottom:1px solid var(--border2);
}
.headerCard{
  border:1px solid var(--border);
  border-radius:var(--radius);
  background: linear-gradient(180deg, rgba(18,22,31,.88), rgba(18,22,31,.68));
  box-shadow:var(--shadow);
  overflow:hidden;
}
.headerTop{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:14px 14px 12px}
.brand{display:flex;align-items:center;gap:12px;min-width:240px}
.brand img{height:42px;border-radius:12px;border:1px solid rgba(255,255,255,.10);box-shadow:0 10px 30px rgba(0,0,0,.35)}
.titleRow{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.brand .title{font-weight:900;font-size:20px}
.brand .path{font-size:13px;color:var(--muted);opacity:.9}

.headerSearch{
  width:min(420px, 52vw);
  border:1px solid var(--border);
  border-radius:999px;
  padding:9px 12px;
  font-size:14px;
  background:rgba(255,255,255,.02);
  color:var(--text);
  outline:none;
}
.headerSearch:focus{border-color:rgba(255,46,46,.55);box-shadow:0 0 0 4px rgba(255,46,46,.10)}

.actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.btn{
  border:1px solid var(--border);
  border-radius:999px;
  padding:9px 12px;
  font-size:13px;
  background:rgba(255,255,255,.02);
  text-decoration:none;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--text);
  transition: transform .10s ease, border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
.btn:hover{border-color:rgba(255,255,255,.18);background:rgba(255,255,255,.03);box-shadow:0 0 0 4px rgba(255,46,46,.06)}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.btnPrimary{border-color:rgba(255,46,46,.45);background:linear-gradient(180deg, rgba(255,46,46,.18), rgba(255,46,46,.08));box-shadow:0 0 0 4px rgba(255,46,46,.06)}
.pill{
  font-size:12px;padding:3px 10px;border-radius:999px;border:1px solid var(--border);
  color:var(--muted);background:rgba(255,255,255,.02);display:inline-flex;align-items:center;gap:8px;
}

.playerBar{
  border-top:1px solid var(--border2);
  padding:10px 14px 14px;
  display:flex;flex-direction:column;gap:10px;
}
.nowRow{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.nowMarquee{
  flex:1;min-width:220px;
  overflow:hidden;white-space:nowrap;
  border-radius:999px;border:1px solid var(--border2);
  background:rgba(255,255,255,.02);
  padding:6px 10px;
  position:relative;
}
.nowMarquee::before,.nowMarquee::after{
  content:"";position:absolute;top:0;bottom:0;width:26px;pointer-events:none;z-index:2;
}
.nowMarquee::before{left:0;background:linear-gradient(90deg, rgba(12,14,18,1), rgba(12,14,18,0))}
.nowMarquee::after{right:0;background:linear-gradient(270deg, rgba(12,14,18,1), rgba(12,14,18,0))}
.nowInner{display:inline-block;padding-right:40px;will-change:transform}
.nowMarquee.scrolling .nowInner{animation:marqueeMove var(--dur,12s) linear infinite}
@keyframes marqueeMove{0%{transform:translateX(0)}100%{transform:translateX(calc(-1 * var(--dist, 200px)))}}
.nowLabel{font-weight:600}
.nowTrack{color:var(--accent);font-weight:800;text-shadow:0 0 8px rgba(255,46,46,.55)}

/* Player + EQ layout */
.audioRow{
  display:grid;
  grid-template-columns: 1fr minmax(360px, 980px);
  align-items:start;
  gap:12px;
}
@media (max-width:980px){
  .audioRow{grid-template-columns:1fr}
}

/* Hide native audio UI (we drive it via custom controls) */
audio{width:100%;height:0;opacity:0;pointer-events:none}

/* Custom player */
.playerShell{
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  padding:12px 12px 10px;
  background:
    radial-gradient(700px 220px at 20% 20%, rgba(255,46,46,.18), transparent 60%),
    radial-gradient(620px 240px at 90% 20%, rgba(120,140,255,.14), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
  box-shadow:
    0 18px 55px rgba(0,0,0,.55),
    inset 0 0 0 1px rgba(255,255,255,.06);
  position:relative;
  overflow:hidden;
}
.playerShell::after{
  content:"";
  position:absolute; inset:-2px;
  background:conic-gradient(from 180deg, rgba(255,46,46,.0), rgba(255,46,46,.35), rgba(120,140,255,.25), rgba(255,46,46,.0));
  opacity:.35;
  filter:blur(16px);
  pointer-events:none;
}
.playerTop{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.playerBtns{display:flex;gap:8px;align-items:center}
.pBtn{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03);
  color:var(--text);
  border-radius:14px;
  padding:10px 12px;
  cursor:pointer;
  box-shadow:0 10px 30px rgba(0,0,0,.35);
  transition: transform .10s ease, border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
.pBtn:hover{border-color:rgba(255,255,255,.20);background:rgba(255,255,255,.05);box-shadow:0 0 0 4px rgba(255,46,46,.07), 0 14px 40px rgba(0,0,0,.45)}
.pBtn:active{transform:translateY(1px)}
.pBtnPrimary{border-color:rgba(255,46,46,.45);background:linear-gradient(180deg, rgba(255,46,46,.22), rgba(255,46,46,.10))}
.playerMeta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.playerTime{font-size:12px;color:rgba(255,255,255,.78);padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.02)}
.playerVol{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.02)}
.playerVol input[type="range"]{width:140px}

.playerSeek{position:relative;z-index:1;margin-top:10px}
.playerSeek input[type="range"]{
  width:100%;
  appearance:none;
  height:14px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  outline:none;
}
.playerSeek input[type="range"]::-webkit-slider-thumb{
  appearance:none;
  width:18px;height:18px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(0,0,0,.25);
  box-shadow:0 0 0 6px rgba(255,46,46,.10);
}
.playerSeek input[type="range"]::-moz-range-thumb{
  width:18px;height:18px;border-radius:999px;background:rgba(255,255,255,.92);
  border:1px solid rgba(0,0,0,.25);
  box-shadow:0 0 0 6px rgba(255,46,46,.10);
}
.seekGlow{
  position:absolute; inset:0;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(255,46,46,.0), rgba(255,46,46,.18), rgba(120,140,255,.12), rgba(255,46,46,.0));
  filter:blur(10px);
  opacity:.55;
  pointer-events:none;
}

/* EQ area */
.eqWrap{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:10px;
  width:100%;
}

/* ✅ EQ canvas is ~90% wide */
.eqCanvas{
  position:relative;
  z-index:1;
  width:100%;
  max-width:none;
  min-width:260px;
  height:54px;

  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(600px 180px at 20% 30%, rgba(255,46,46,.14), transparent 60%),
    radial-gradient(560px 220px at 90% 20%, rgba(120,140,255,.12), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  box-shadow:
    0 12px 36px rgba(0,0,0,.45),
    inset 0 0 0 1px rgba(255,255,255,.06);
}

.eqWrap{position:relative}
.eqWrap::before{
  content:"";
  position:absolute; inset:-1px;
  border-radius:18px;
  background:conic-gradient(from 90deg, rgba(255,46,46,.0), rgba(255,46,46,.25), rgba(120,140,255,.20), rgba(255,46,46,.0));
  filter:blur(18px);
  opacity:.35;
  pointer-events:none;
}

/* controls wrap under canvas */
.eqControls{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  width:100%;
}

.eqSelect, .eqPreset{
  border:1px solid var(--border);
  border-radius:999px;
  padding:9px 12px;
  background:rgba(255,255,255,.02);
  color:var(--text);
}
.eqKnob{
  display:flex;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.02);
}
.eqKnob label{
  font-size:12px;
  color:rgba(255,255,255,.75);
  white-space:nowrap;
}
.eqKnob input[type="range"]{width:120px}
.eqBadge{
  font-size:12px;
  padding:3px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.02);
  color:rgba(255,255,255,.78);
}

.grid{display:flex;gap:12px;align-items:stretch}
@media (max-width:920px){
  .grid{flex-direction:column}
}

/* Default split (JS can override widths inline) */
#foldersCard{width:50%}
#tracksCard{width:50%}
@media (max-width:920px){
  #foldersCard,#tracksCard{width:100%}
}

.splitter{
  width:10px;
  border-radius:999px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  cursor:col-resize;
  position:relative;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04);
}
.splitter::after{
  content:"";
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  width:2px; height:44px;
  border-radius:99px;
  background:linear-gradient(180deg, rgba(255,46,46,.0), rgba(255,46,46,.55), rgba(120,140,255,.40), rgba(255,46,46,.0));
  opacity:.75;
}
.splitter:hover{border-color:rgba(255,255,255,.18);box-shadow:0 0 0 4px rgba(255,46,46,.06), inset 0 0 0 1px rgba(255,255,255,.06)}
@media (max-width:920px){.splitter{display:none}}

.noSelect{user-select:none}

.card{border:1px solid var(--border);border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow);overflow:hidden}
.cardHead{padding:14px;display:flex;align-items:baseline;justify-content:space-between;gap:10px;border-bottom:1px solid var(--border2)}
.cardHead h2{margin:0;font-size:15px}
.headLeft{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.list{list-style:none;margin:0;padding:0}
.row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border-top:1px solid var(--border2)}
.row:first-child{border-top:none}
.name{display:flex;align-items:center;gap:10px;min-width:0}
.text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60ch}
.rowActions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.muted{opacity:.8;font-size:13px;padding:14px;color:var(--muted)}

.trackMeta{display:flex;align-items:center;gap:10px;min-width:0}
.cover{
  width:40px;height:40px;border-radius:10px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
  flex:0 0 auto;
  overflow:hidden;
  position:relative;
}
.cover img{width:100%;height:100%;object-fit:cover;display:block}
.cover .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.35);font-size:12px}

/* Folder album grid */
.foldersGrid{
  display:grid;
  /* more compact folder tiles (about 50% smaller than before) */
  grid-template-columns:repeat(auto-fill, minmax(110px, 1fr));
  gap:12px;
  padding:12px;
}
.folderCard{
  border-radius:16px;
  overflow:hidden;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.folderCard:hover{
  transform:translateY(-6px) scale(1.02);
  box-shadow:0 25px 60px rgba(0,0,0,.55);
  border-color:rgba(255,255,255,.20);
}
.folderCard.active{
  border-color:rgba(255,46,46,.45);
  box-shadow:0 0 0 4px rgba(255,46,46,.08), 0 25px 60px rgba(0,0,0,.55);
}
.folderArt{
  aspect-ratio:1/1;
  background:rgba(255,255,255,.04);
}
.folderArt.cover{width:100%;height:100%;border-radius:0;border:none}
.folderInfo{padding:8px}
.folderTitle{font-weight:800;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.folderZip{margin-top:8px; display:flex; justify-content:center}
.folderLink{display:block;color:inherit;text-decoration:none}

/* Back to top */
.backToTop{
  position:fixed;right:18px;bottom:18px;z-index:100000;
  border:1px solid rgba(255,46,46,.50);
  background: linear-gradient(180deg, rgba(255,46,46,.22), rgba(255,46,46,.10));
  color:var(--text);border-radius:999px;padding:10px 14px;font-size:13px;font-weight:800;
  cursor:pointer;box-shadow:0 0 0 4px rgba(255,46,46,.10), 0 18px 50px rgba(0,0,0,.45);
  transition: transform .08s ease, opacity .15s ease, filter .15s ease;
  user-select:none;opacity:.15;
}
.backToTop.isHidden{opacity:0;pointer-events:none}
.backToTop:hover{opacity:1}
.backToTop:active{transform:translateY(1px)}

/* Minimal overlay */
.minimalOverlay{
  position:fixed;inset:0;z-index:200000;
  background: radial-gradient(900px 500px at 25% 0%, rgba(255,46,46,.18), transparent 60%),
              linear-gradient(180deg, #05060a, #090a0f);
  display:none;
}
.minimalOverlay.show{display:block}
.minWrap{
  height:100%;
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:18px;
  padding:18px;
}
@media (max-width:900px){ .minWrap{grid-template-columns:1fr;grid-template-rows:auto 1fr} }
.minCard{
  border:1px solid rgba(255,255,255,.10);
  border-radius:22px;
  background: rgba(18,22,31,.55);
  box-shadow: 0 20px 70px rgba(0,0,0,.55);
  overflow:hidden;
}
.minLeft{display:flex;flex-direction:column}
.minArt{
  aspect-ratio: 1/1;
  background: rgba(255,255,255,.03);
  display:flex;align-items:center;justify-content:center;
}
.minArt img{width:100%;height:100%;object-fit:cover;display:block}
.minInfo{padding:14px 16px;border-top:1px solid rgba(255,255,255,.06)}
.minTitle{font-weight:900;font-size:20px;color:var(--accent)}
.minSub{margin-top:6px;color:rgba(255,255,255,.75);font-size:14px}
.minControls{padding:14px 16px;display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:space-between}
.minBigBtn{font-size:16px;padding:12px 16px}
.minRight{display:flex;flex-direction:column}
.minTop{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;justify-content:space-between;align-items:center;gap:10px}
.minTop h3{margin:0;font-size:14px;color:rgba(255,255,255,.85)}
.minList{overflow:auto;max-height:100%}
.minItem{padding:12px 16px;border-top:1px solid rgba(255,255,255,.06);display:flex;gap:10px;align-items:center}
.minItem .t{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.minClose{border-color:rgba(255,255,255,.16)}

/* Manual EQ panel */
.eqToggle{
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.92);
  padding: 8px 10px;
  border-radius: 12px;
  font-weight: 700;
  letter-spacing: .2px;
  cursor: pointer;
  transition: transform .08s ease, background .2s ease, border-color .2s ease;
  white-space: nowrap;
}
.eqToggle:hover{ background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.22); }
.eqToggle:active{ transform: translateY(1px); }

.eqManual{
  width: 100%;
  margin-top: 10px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.28);
  backdrop-filter: blur(10px);
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}

.eqManualHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  margin-bottom: 10px;
}
.eqManualTitle{
  font-weight: 800;
  color: rgba(255,255,255,.92);
}
.eqReset{
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.9);
  padding: 6px 10px;
  border-radius: 12px;
  cursor:pointer;
  font-weight: 700;
}
.eqReset:hover{ background: rgba(255,255,255,.10); }

.eqBands{
  display:flex;
  flex-direction:column;
  gap: 10px;
  width:100%;
}
.eqBand{
  display:flex;
  flex-direction:column;
  gap: 8px;
  padding: 10px 10px;
  border-radius: 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.06);
}
.eqBandLabel{
  font-size: 12px;
  color: rgba(255,255,255,.75);
  font-weight: 700;
  letter-spacing: .2px;
}

/* Vertical range slider */
.eqBandSlider{
  width: 100%;
  height: 8px;
  -webkit-appearance: none;
  appearance: none;
  background: rgba(255,255,255,.12);
  border-radius: 999px;
  outline: none;
}

@media (max-width: 880px){
  .eqBands{ grid-template-columns: repeat(5, minmax(0,1fr)); }
  .eqBandSlider{ height: 96px; }
}


/* ===== COMPACT MODE ===== */

.player-eq-wrapper{
display:grid;
grid-template-columns:1fr 320px;
gap:10px;
align-items:center;
}

.modern-player{
padding:8px 12px;
border-radius:10px;
}

.player-controls{
gap:6px;
}

.player-btn{
width:30px;
height:30px;
border-radius:8px;
}

.seek-bar{
height:4px;
margin-top:4px;
}

.equalizer-container{
padding:8px;
border-radius:10px;
}

.eq-sliders{
gap:5px;
}

.eq-sliders input{
width:16px;
}




/* ===== Ultra-compact single-line player + EQ modal ===== */
.audioRowUltra{
  grid-template-columns: 1fr auto;
  align-items:center;
}
@media (max-width:980px){
  .audioRowUltra{grid-template-columns:1fr}
}

.playerShellUltra{
  padding:10px 10px;
  border-radius:16px;
}
.playerInline{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  gap:10px;
  width:100%;
}
.playerInlineMid{flex:1;min-width:160px}
.pSeekUltra{
  width:100%;
  appearance:none;
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  outline:none;
}
.pSeekUltra::-webkit-slider-thumb{
  appearance:none;
  width:14px;height:14px;border-radius:999px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(0,0,0,.25);
  box-shadow:0 0 0 5px rgba(255,46,46,.10);
}
.pSeekUltra::-moz-range-thumb{
  width:14px;height:14px;border-radius:999px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(0,0,0,.25);
  box-shadow:0 0 0 5px rgba(255,46,46,.10);
}

.playerMetaUltra .playerVol input[type="range"]{width:110px}
@media (max-width:640px){
  .playerMetaUltra .playerVol{display:none}
  .playerMetaUltra .playerTime{display:none}
}

.eqMini{
  width:320px;
  height:46px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.02);
  box-shadow:0 10px 30px rgba(0,0,0,.35);
}
@media (max-width:980px){
  .eqMini{width:100%}
}

/* Modal */
.modalOverlay{
  position:fixed; inset:0;
  display:none;
  align-items:flex-start;
  justify-content:center;
  padding:5vh 18px 18px;
  background:rgba(0,0,0,.62);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  z-index:100000;
}
.modalOverlay.open{display:flex}
.modalCard{
  position:relative;
  width:90vw;
  max-width:1100px;
  max-height:min(86vh, 900px);
  overflow:auto;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(18,22,31,.92), rgba(18,22,31,.72));
  box-shadow:0 30px 90px rgba(0,0,0,.75);
}
.modalHead{
  cursor:move;
  user-select:none;
  -webkit-user-select:none;
  position:sticky; top:0;
  display:flex; align-items:center; justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(18,22,31,.96), rgba(18,22,31,.78));
  z-index:2;
}
.modalTitle{font-weight:900; letter-spacing:.2px}
.modalClose{padding:8px 12px}

.modalBody{padding:14px; display:flex; flex-direction:column; gap:12px}

/* Make EQ canvas larger in modal */
.modalBody .eqCanvas{height:220px}


/* Range thumb styling */
.eqBandSlider::-webkit-slider-thumb{
  -webkit-appearance:none;
  appearance:none;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(0,0,0,.25);
  box-shadow: 0 6px 18px rgba(0,0,0,.35);
}
.eqBandSlider::-moz-range-thumb{
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(0,0,0,.25);
  box-shadow: 0 6px 18px rgba(0,0,0,.35);
}
.eqBandSlider::-moz-range-track{
  height: 8px;
  background: rgba(255,255,255,.12);
  border-radius: 999px;
}

.eqBandMeta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}
.eqBandHz{
  font-size: 12px;
  color: rgba(255,255,255,.78);
  font-weight: 700;
  letter-spacing: .2px;
}
.eqBandVal{
  font-size: 12px;
  color: rgba(255,255,255,.72);
  font-weight: 700;
}


.modalFoot{
  display:flex;
  justify-content:flex-end;
  padding: 12px 14px 16px;
  gap:10px;
  position:sticky;
  bottom:0;
  background: linear-gradient(180deg, rgba(18,22,31,0), rgba(18,22,31,.92));
  border-top: 1px solid rgba(255,255,255,.08);
}
.modalCloseBtn{
  padding:10px 14px;
  border-radius:12px;
}


body.noSelect{user-select:none;-webkit-user-select:none;}


/* Sub-folder tiles: cover on top, title below (album cover under name area) */
.foldersGrid.subMode .folderCard{
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 10px;
}
.foldersGrid.subMode .folderArt{
  width: 72px;
  height: 72px;
  border-radius: 12px;
}
.foldersGrid.subMode .folderInfo{
  width: 100%;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 10px;
}
.foldersGrid.subMode .folderTitle{
  text-align: left;
}
/* Tracks list: no per-row art */
.trackRow .trackMeta .cover{ display:none !important; }


/* Fancy ZIP button */
.zipBtn{
  padding:10px 16px;
  border-radius:999px;
  border:1px solid rgba(255,46,46,.55);
  background: linear-gradient(180deg, rgba(255,46,46,.20), rgba(255,255,255,.03));
  box-shadow: 0 10px 22px rgba(255,46,46,.14), inset 0 1px 0 rgba(255,255,255,.10);
  letter-spacing:.2px;
}
.zipBtn:hover{
  transform: translateY(-1px);
  border-color: rgba(255,46,46,.80);
  box-shadow: 0 14px 28px rgba(255,46,46,.20), inset 0 1px 0 rgba(255,255,255,.12);
}
.zipBtn:active{ transform: translateY(0px) scale(.99); }

/* --- Scrolling text (Spotify-style) --- */
.scrollClip{position:relative;overflow:hidden;white-space:nowrap;min-width:0}
.scrollClip{mask-image:linear-gradient(to right, transparent, #000 10%, #000 90%, transparent)}
.scrollInner{display:inline-block;will-change:transform}

/* Scroll long text on hover (tracks) */
.trackRow .scrollInner{transform:translateX(0)}
.trackRow:hover .scrollInner{animation:scrollText 8s linear infinite}

/* Album label: scroll on hover */
.tracksHead{display:flex;flex-direction:column;gap:4px;min-width:0}
.tracksAlbum{max-width:60vw;min-width:0;opacity:.85;font-size:.9rem}
.tracksAlbum:hover .scrollInner{animation:scrollText 10s linear infinite}

@keyframes scrollText{
  0%{transform:translateX(0)}
  100%{transform:translateX(-55%)}
}
