*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  --bg:#08080f;--s1:#0c0c18;--s2:#101020;--s3:#161626;--s4:#1d1d30;--s5:#25253c;
  --g0:rgba(255,255,255,.025);--g1:rgba(255,255,255,.06);--g2:rgba(255,255,255,.12);--g3:rgba(255,255,255,.2);
  --accent:#e8175d;--a2:#ff6b9d;--a3:#ff4081;--ad:rgba(232,23,93,.1);--ab:rgba(232,23,93,.2);
  --grad:linear-gradient(135deg,#e8175d,#ff6b9d);
  --t1:#fff;--t2:rgba(255,255,255,.75);--t3:rgba(255,255,255,.44);--t4:rgba(255,255,255,.2);--t5:rgba(255,255,255,.08);
  --fw:264px;--ph:76px;--mn:58px;
  --sfb:env(safe-area-inset-bottom,0px);--sft:env(safe-area-inset-top,0px);
  --bounce:cubic-bezier(.34,1.56,.64,1);--smooth:cubic-bezier(.16,1,.3,1);--ease:cubic-bezier(.4,0,.2,1)
}
html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--t1);
  font-family:'DM Sans',sans-serif;-webkit-font-smoothing:antialiased;overscroll-behavior:none}
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse 60% 45% at 85% -5%,rgba(232,23,93,.08),transparent),
             radial-gradient(ellipse 40% 35% at -5% 90%,rgba(124,58,237,.06),transparent),
             radial-gradient(ellipse 30% 30% at 50% 115%,rgba(255,64,129,.05),transparent)}
.mi{font-family:'Material Symbols Rounded';font-variation-settings:'FILL' 1,'wght' 400,'GRAD' 0,'opsz' 24;
  font-size:22px;line-height:1;display:inline-flex;align-items:center;justify-content:center;
  user-select:none;font-style:normal;flex-shrink:0;color:inherit}
::-webkit-scrollbar{width:2px;height:2px}::-webkit-scrollbar-thumb{background:var(--s5);border-radius:99px}

/* ── SHELL ──────────────────────────────────────────── */
.shell{display:flex;height:100%;position:relative;z-index:1;flex-direction:column}
.top-row{display:flex;flex:1;min-height:0;overflow:hidden}

/* ── SIDEBAR ────────────────────────────────────────── */
.sidebar{width:var(--fw);flex-shrink:0;display:flex;flex-direction:column;overflow:hidden;
  background:rgba(8,8,15,.97);border-right:1px solid var(--g1)}
.logo{padding:16px 14px 12px;display:flex;align-items:center;gap:10px;flex-shrink:0}
.logo-ic{width:36px;height:36px;border-radius:10px;background:var(--grad);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(232,23,93,.4)}
.logo-ic .mi{font-size:19px;color:#fff}
.logo-nm{font-family:'Syne',sans-serif;font-weight:900;font-size:1.05rem;letter-spacing:-.5px;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.logo-sb{font-size:.44rem;color:var(--t4);letter-spacing:2.5px;text-transform:uppercase;font-weight:700}
.snav{padding:4px 8px 0;flex-shrink:0}
.scat{font-size:.44rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--t5);padding:9px 10px 2px;font-weight:700}
.sni{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:9px;cursor:pointer;
  color:var(--t3);font-size:.79rem;font-weight:600;transition:all .14s;border:1px solid transparent;user-select:none;position:relative}
.sni:hover{background:var(--g0);color:var(--t2)}.sni:active{transform:scale(.97)}
.sni.on{background:var(--ad);color:var(--a2);border-color:var(--ab)}
.sni.on::before{content:"";position:absolute;left:0;top:22%;bottom:22%;width:2px;background:var(--grad);border-radius:0 2px 2px 0}
.sni .mi{font-size:17px;color:inherit}
.snb{margin-left:auto;font-size:.48rem;font-weight:800;background:var(--grad);color:#fff;padding:2px 5px;border-radius:99px}
/* queue */
.sq-head{display:flex;align-items:center;justify-content:space-between;padding:8px 12px 3px;border-top:1px solid var(--g0);flex-shrink:0}
.sq-lbl{font-size:.44rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--t4);font-weight:700}
.sq-clr{background:none;border:none;cursor:pointer;font-family:inherit;font-size:.6rem;color:var(--t4);padding:2px 7px;border-radius:5px;font-weight:600;transition:all .14s}
.sq-clr:hover{color:var(--a2);background:var(--ad)}
.sq-wrap{flex:1;overflow-y:auto;padding:0 5px 40px;min-height:0}
.sq-item{display:flex;align-items:center;gap:7px;padding:5px 7px;border-radius:7px;cursor:pointer;transition:background .14s;border:1px solid transparent}
.sq-item:hover{background:var(--g0)}.sq-item.now{background:var(--ad);border-color:var(--ab)}
.sq-art{width:30px;height:30px;border-radius:5px;object-fit:cover;background:var(--s3);flex-shrink:0}
.sq-info{flex:1;min-width:0}
.sq-nm{font-size:.69rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sq-nm.now{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.sq-by{font-size:.6rem;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sq-rm{background:none;border:none;color:var(--t4);cursor:pointer;width:16px;height:16px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;opacity:0;transition:all .14s;flex-shrink:0}
.sq-item:hover .sq-rm{opacity:1}.sq-rm .mi{font-size:10px;color:inherit}

/* ── TOPBAR ─────────────────────────────────────────── */
.topbar{display:flex;align-items:center;gap:7px;padding:9px 16px;
  background:rgba(8,8,15,.95);backdrop-filter:blur(24px);border-bottom:1px solid var(--g1);flex-shrink:0;z-index:10}
.srch{flex:1;max-width:440px;position:relative}
.srch-ic{position:absolute;left:11px;top:50%;transform:translateY(-50%);font-size:15px;color:var(--t3);pointer-events:none;transition:color .2s}
.srch:focus-within .srch-ic{color:var(--accent)}
#sIn{width:100%;background:var(--s2);border:1.5px solid var(--g1);border-radius:100px;
  padding:8px 36px 8px 36px;color:var(--t1);font-family:'DM Sans',sans-serif;font-size:.81rem;outline:none;transition:all .2s;font-weight:500}
#sIn:focus{border-color:rgba(232,23,93,.35);background:var(--s3);box-shadow:0 0 0 3px rgba(232,23,93,.06)}
#sIn::placeholder{color:var(--t4)}
.srch-clr{position:absolute;right:9px;top:50%;transform:translateY(-50%);background:none;border:none;
  cursor:pointer;color:var(--t3);display:none;align-items:center;justify-content:center;transition:color .14s;padding:3px}
.srch-clr .mi{font-size:14px;color:inherit}.srch-clr:hover{color:var(--t1)}.srch-clr.vis{display:flex}
.tb-r{display:flex;align-items:center;gap:3px;margin-left:auto}
.ib{width:32px;height:32px;border-radius:50%;background:var(--g0);border:1.5px solid var(--g1);
  display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--t3);transition:all .14s;flex-shrink:0}
.ib:hover{background:var(--g1);color:var(--t1)}.ib:active{transform:scale(.86)}.ib.on{background:var(--ad);color:var(--a2);border-color:var(--ab)}.ib .mi{font-size:15px;color:inherit}
#btnInstall{display:none;background:var(--grad);border:none;color:#fff;padding:5px 12px;border-radius:100px;
  font-family:'DM Sans',sans-serif;font-size:.7rem;font-weight:700;cursor:pointer;align-items:center;gap:4px;transition:all .15s;box-shadow:0 3px 10px rgba(232,23,93,.3)}
#btnInstall.vis{display:flex}#btnInstall:hover{transform:translateY(-1px)}#btnInstall .mi{font-size:13px;color:#fff}

/* ── CONTENT ────────────────────────────────────────── */
.maincol{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.content{flex:1;overflow-y:auto;overflow-x:hidden;padding:14px 16px 10px;-webkit-overflow-scrolling:touch}
.view{display:none}.view.on{display:block;animation:fadeUp .2s var(--smooth) both}
@keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ── NOW PLAYING HERO ───────────────────────────────── */
.nphero{border-radius:16px;padding:14px 18px;margin-bottom:14px;
  background:linear-gradient(135deg,rgba(232,23,93,.07),rgba(255,64,129,.04) 50%,rgba(124,58,237,.04));
  border:1px solid rgba(232,23,93,.13);display:flex;align-items:center;gap:13px;overflow:hidden;position:relative;cursor:pointer}
.nphero::after{content:"";position:absolute;top:-40%;right:-5%;width:180px;height:180px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,23,93,.07),transparent 70%);pointer-events:none}
.np-thumb{width:66px;height:66px;border-radius:11px;object-fit:cover;flex-shrink:0;
  box-shadow:0 6px 20px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.06);transition:transform .35s var(--bounce)}
.nphero:hover .np-thumb{transform:scale(1.06) rotate(-2deg)}
.np-ph{width:66px;height:66px;border-radius:11px;background:var(--grad);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.np-ph .mi{font-size:28px;color:#fff}
.np-info{flex:1;min-width:0;z-index:1}
.np-stat-row{display:flex;align-items:center;gap:6px;margin-bottom:3px}
.np-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);flex-shrink:0;animation:pdot 2s ease infinite}
@keyframes pdot{0%{box-shadow:0 0 0 0 rgba(232,23,93,.7)}70%{box-shadow:0 0 0 6px transparent}100%{box-shadow:0 0 0 0 transparent}}
.np-stat{font-size:.5rem;letter-spacing:2px;text-transform:uppercase;color:var(--a2);font-weight:800}
.np-tit{font-family:'Syne',sans-serif;font-weight:800;font-size:1.01rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2;margin-bottom:1px}
.np-art{font-size:.72rem;color:var(--t2);margin-bottom:9px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.np-prog-wrap{cursor:pointer}
.np-prog{height:2px;background:var(--s4);border-radius:99px;overflow:hidden;margin-bottom:4px}
.np-fill{height:100%;background:var(--grad);width:0%;transition:width .3s linear}
.np-times{display:flex;justify-content:space-between;font-size:.58rem;color:var(--t3);font-weight:600}
.np-wave{display:none;align-items:center;gap:2px;height:11px;margin-top:5px}
.nw{width:2px;border-radius:2px;background:var(--grad)}
.nw:nth-child(1){height:30%;animation:wv 1.1s ease .0s infinite}.nw:nth-child(2){height:80%;animation:wv 1.1s ease .1s infinite}
.nw:nth-child(3){height:100%;animation:wv 1.1s ease .2s infinite}.nw:nth-child(4){height:55%;animation:wv 1.1s ease .3s infinite}
.nw:nth-child(5){height:85%;animation:wv 1.1s ease .4s infinite}.nw:nth-child(6){height:40%;animation:wv 1.1s ease .5s infinite}
.nw:nth-child(7){height:65%;animation:wv 1.1s ease .6s infinite}
@keyframes wv{0%,100%{transform:scaleY(.25);opacity:.35}50%{transform:scaleY(1);opacity:1}}

/* ── CHIPS ──────────────────────────────────────────── */
.chips{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:13px}
.chip{display:inline-flex;align-items:center;gap:4px;padding:6px 11px;border-radius:100px;
  font-size:.7rem;font-weight:700;cursor:pointer;border:1.5px solid var(--g1);background:var(--g0);
  color:var(--t3);transition:all .14s;user-select:none}
.chip:hover{background:var(--g1);color:var(--t2);transform:translateY(-1px)}.chip:active{transform:scale(.96)}
.chip.on{background:var(--ad);border-color:var(--ab);color:var(--a2)}.chip .mi{font-size:12px;color:inherit}
.sec{display:flex;align-items:center;gap:8px;margin-bottom:11px}
.sec-title{font-family:'Syne',sans-serif;font-weight:800;font-size:.88rem;letter-spacing:-.2px}
.sec-back{background:none;border:none;cursor:pointer;color:var(--t3);display:flex;align-items:center;gap:4px;
  font-family:'DM Sans',sans-serif;font-size:.75rem;font-weight:600;padding:4px 8px;border-radius:7px;transition:all .14s}
.sec-back:hover{background:var(--g1);color:var(--t1)}.sec-back .mi{font-size:16px;color:inherit}
.pill{font-size:.46rem;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;padding:2px 7px;border-radius:99px;color:#fff}
.p-sv{background:linear-gradient(135deg,#00b4d8,#0077b6)}.p-re{background:linear-gradient(135deg,#e8175d,#ff6b9d)}
.p-al{background:linear-gradient(135deg,#f59e0b,#ef4444)}.p-ar{background:linear-gradient(135deg,#8b5cf6,#06b6d4)}
.p-tr{background:linear-gradient(135deg,#7c3aed,#10b981)}
.spinner{display:flex;justify-content:center;padding:32px 0}
.spin{width:22px;height:22px;border:2px solid var(--s4);border-top-color:var(--accent);border-radius:50%;animation:spin .55s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── CARDS ──────────────────────────────────────────── */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(138px,1fr));gap:9px;margin-bottom:18px}
.card{background:var(--s2);border:1px solid var(--g0);border-radius:13px;padding:9px;cursor:pointer;
  transition:all .2s var(--smooth);overflow:hidden}
.card:hover{transform:translateY(-5px);box-shadow:0 14px 30px rgba(0,0,0,.5);border-color:rgba(232,23,93,.18);background:var(--s3)}
.card:active{transform:scale(.97)}
.card:hover .cplay{opacity:1;transform:translateY(0) scale(1)}
.cart-w{width:100%;aspect-ratio:1;border-radius:8px;overflow:hidden;margin-bottom:7px;background:var(--s3);position:relative}
.cart{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}.card:hover .cart{transform:scale(1.07)}
.cplay{position:absolute;bottom:5px;right:5px;width:30px;height:30px;border-radius:50%;background:var(--grad);border:none;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateY(6px) scale(.7);transition:all .2s var(--bounce);box-shadow:0 4px 12px rgba(232,23,93,.5)}
.cplay .mi{font-size:15px;color:#fff}
.ctit{font-weight:700;font-size:.73rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
.csub{font-size:.61rem;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* album / artist result cards */
.scard{background:var(--s2);border:1px solid var(--g0);border-radius:13px;padding:9px;cursor:pointer;transition:all .2s var(--smooth)}
.scard:hover{transform:translateY(-4px);background:var(--s3);border-color:rgba(232,23,93,.15)}
.scard-img{width:100%;aspect-ratio:1;border-radius:8px;object-fit:cover;background:var(--s3);display:block}
.scard-img.circle{border-radius:50%}
.scard-badge{font-size:.46rem;text-transform:uppercase;letter-spacing:1.5px;font-weight:800;padding:2px 6px;border-radius:99px;display:inline-flex;margin-bottom:5px}
.scard-badge.alb{background:rgba(245,158,11,.15);color:#f59e0b}.scard-badge.art{background:rgba(139,92,246,.15);color:#8b5cf6}
.scard-nm{font-size:.73rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:5px}
.scard-sub{font-size:.61rem;color:var(--t3)}

/* ── REEL ───────────────────────────────────────────── */
.reel-row{display:flex;gap:9px;overflow-x:auto;padding-bottom:5px;margin-bottom:16px;scroll-snap-type:x mandatory;scrollbar-width:none}
.reel-row::-webkit-scrollbar{display:none}
.rcard{flex-shrink:0;width:110px;cursor:pointer;scroll-snap-align:start;transition:transform .2s var(--smooth)}
.rcard:hover{transform:translateY(-4px)}.rcard:hover .rplay{opacity:1;transform:translate(-50%,-50%) scale(1)}
.rthumb{width:110px;height:160px;border-radius:11px;overflow:hidden;position:relative;box-shadow:0 7px 18px rgba(0,0,0,.55);margin-bottom:5px}
.rimg{width:100%;height:100%;object-fit:cover;display:block}
.rgrad{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.88),transparent 50%)}
.rplay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);
  width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.88);
  display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s var(--bounce)}
.rplay .mi{font-size:17px;color:#111}
.rtag{position:absolute;top:5px;left:5px;font-size:.45rem;font-weight:800;letter-spacing:.8px;text-transform:uppercase;background:var(--grad);color:#fff;padding:2px 5px;border-radius:4px}
.rbot{position:absolute;bottom:5px;left:6px;right:6px}
.rname{font-size:.68rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rby{font-size:.57rem;color:rgba(255,255,255,.48)}
.rlbl{font-size:.68rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rsub{font-size:.59rem;color:var(--t3)}

/* ── TRACK LIST ─────────────────────────────────────── */
.tl{display:flex;flex-direction:column;gap:1px}
.tr{display:flex;align-items:center;gap:9px;padding:6px 8px;border-radius:9px;cursor:pointer;transition:all .14s;border:1px solid transparent}
.tr:hover{background:var(--s2);border-color:var(--g0)}.tr.now{background:var(--ad);border-color:var(--ab)}
.tr-n{width:18px;text-align:center;font-size:.66rem;color:var(--t3);flex-shrink:0;font-weight:700}
.tr-img{width:38px;height:38px;border-radius:6px;object-fit:cover;flex-shrink:0;background:var(--s3)}
.tr-info{flex:1;min-width:0}
.tr-tit{font-size:.79rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:1px}
.tr.now .tr-tit{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.tr-meta{font-size:.64rem;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tr-dur{font-size:.64rem;color:var(--t3);flex-shrink:0;font-weight:600}
.tr-acts{display:flex;align-items:center;gap:1px;opacity:0;flex-shrink:0;transition:opacity .14s}
.tr:hover .tr-acts,.tr.now .tr-acts{opacity:1}
.tact{width:25px;height:25px;border-radius:50%;background:none;border:1px solid transparent;cursor:pointer;
  display:flex;align-items:center;justify-content:center;color:var(--t3);transition:all .14s}
.tact:hover{background:var(--s3);border-color:var(--g1);color:var(--t1)}.tact.on{color:var(--a2)}.tact .mi{font-size:13px;color:inherit}

/* ── LIBRARY ────────────────────────────────────────── */
.lib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(136px,1fr));gap:9px;margin-bottom:16px}
.plc{background:var(--s2);border:1px solid var(--g0);border-radius:13px;padding:11px;cursor:pointer;transition:all .2s var(--smooth)}
.plc:hover{transform:translateY(-4px);background:var(--s3);border-color:rgba(232,23,93,.14)}
.plc-add{border-style:dashed;border-color:var(--g2);background:transparent;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;min-height:108px;color:var(--t3)}
.plc-add:hover{border-color:rgba(232,23,93,.4);color:var(--a2);background:var(--ad)}
.plc-add .mi{font-size:24px;color:inherit}.plc-add-lbl{font-size:.68rem;font-weight:700;color:inherit}
.plc-ic{width:46px;height:46px;border-radius:9px;display:flex;align-items:center;justify-content:center;margin-bottom:8px}
.plc-ic .mi{font-size:21px;color:#fff}
.plc-nm{font-size:.76rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:1px}
.plc-cnt{font-size:.6rem;color:var(--t3)}
/* playlist detail hero */
.pl-hero{border-radius:16px;padding:16px 18px;margin-bottom:14px;
  background:linear-gradient(135deg,rgba(124,58,237,.09),rgba(239,68,68,.06));
  border:1px solid rgba(124,58,237,.2);display:flex;align-items:center;gap:13px;flex-wrap:wrap;position:relative;overflow:hidden}
.pl-hero-ic{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 6px 16px rgba(0,0,0,.4)}
.pl-hero-ic .mi{font-size:22px;color:#fff}
.pl-hero-nm{font-family:'Syne',sans-serif;font-weight:800;font-size:.88rem;margin-bottom:2px}
.pl-hero-sub{font-size:.68rem;color:var(--t2)}
.pl-acts{display:flex;gap:6px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:100px;
  font-family:'DM Sans',sans-serif;font-size:.73rem;font-weight:700;cursor:pointer;border:none;transition:all .14s}
.btn:active{transform:scale(.95)}
.btn-r{background:var(--grad);color:#fff;box-shadow:0 3px 10px rgba(232,23,93,.3)}.btn-r:hover{transform:translateY(-1px)}
.btn-g{background:transparent;color:#ef4565;border:1.5px solid rgba(239,69,101,.22)}.btn-g:hover{background:rgba(239,69,101,.07)}
.btn-n{background:var(--g1);color:var(--t2);border:1.5px solid var(--g1)}.btn-n:hover{background:var(--g2)}

/* ── DESKTOP PLAYER ─────────────────────────────────── */
.player-bar{background:rgba(8,8,15,.97);border-top:1px solid var(--g1);backdrop-filter:blur(30px);flex-shrink:0;position:relative;z-index:20}
.xf-bar{position:absolute;top:0;left:0;height:1.5px;background:var(--grad);width:0%;transition:width .5s linear;z-index:1;opacity:.8}
.pb{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:var(--ph);padding:0 16px;gap:7px}
.pb-l{display:flex;align-items:center;gap:9px}
.pb-iw{width:44px;height:44px;border-radius:7px;overflow:hidden;flex-shrink:0;background:var(--s3)}
.pb-img{width:100%;height:100%;object-fit:cover;display:block}
.pb-iph{width:100%;height:100%;background:var(--grad);display:flex;align-items:center;justify-content:center}.pb-iph .mi{font-size:17px;color:#fff}
.pb-trk{min-width:0}.pb-tit{font-size:.78rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px;margin-bottom:1px}
.pb-sub{font-size:.63rem;color:var(--t3)}
.pb-b{background:none;border:none;cursor:pointer;color:var(--t3);padding:3px;border-radius:50%;transition:all .14s;display:flex}
.pb-b:hover{color:var(--a2);transform:scale(1.15)}.pb-b.on{color:var(--a2)}.pb-b .mi{font-size:16px;color:inherit}
.pb-c{display:flex;flex-direction:column;align-items:center;gap:4px}
.pb-ctrls{display:flex;align-items:center;gap:2px}
.ctrl{width:29px;height:29px;border-radius:50%;background:none;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;color:var(--t3);transition:all .14s}
.ctrl:hover{background:var(--g0);color:var(--t1);transform:scale(1.1)}.ctrl.on{color:var(--accent)}.ctrl .mi{font-size:17px;color:inherit}
.play-btn{width:40px;height:40px;border-radius:50%;background:var(--grad);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(232,23,93,.5);transition:all .2s var(--bounce)}
.play-btn:hover{transform:scale(1.1)}.play-btn:active{transform:scale(.92)}.play-btn .mi{font-size:20px;color:#fff}
.pb-prog{display:flex;align-items:center;gap:6px;width:300px;max-width:100%}
.pb-t{font-size:.58rem;color:var(--t3);width:28px;text-align:center;flex-shrink:0;font-weight:600}
.pb-bar{flex:1;height:3px;border-radius:99px;background:var(--s4);cursor:pointer;transition:height .14s;position:relative}
.pb-bar:hover{height:5px}
.pb-fill{height:100%;border-radius:99px;background:var(--grad);width:0%}
.pb-r{display:flex;align-items:center;gap:3px;justify-content:flex-end}
.vol-w{display:flex;align-items:center;gap:5px}
.vol-sl{-webkit-appearance:none;appearance:none;width:68px;height:3px;border-radius:99px;background:var(--s4);outline:none;cursor:pointer}
.vol-sl::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:#fff;cursor:pointer}
/* sleep badge */
.sl-badge{background:linear-gradient(135deg,#7c3aed,#4f46e5);color:#fff;border:none;border-radius:100px;
  padding:4px 9px;font-size:.6rem;font-weight:700;cursor:pointer;display:none;align-items:center;gap:3px;font-family:'DM Sans',sans-serif}
.sl-badge.vis{display:flex}.sl-badge .mi{font-size:12px;color:#fff}

/* ── MOBILE NAV ─────────────────────────────────────── */
.mob-nav{display:none;background:rgba(6,6,13,.99);backdrop-filter:blur(30px);
  border-top:1px solid rgba(232,23,93,.1);flex-shrink:0;padding-bottom:var(--sfb);z-index:10}
.mob-nav-row{display:flex}
.mob-ni{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2px;padding:7px 4px 4px;cursor:pointer;user-select:none;position:relative}
.mob-ni::before{content:"";position:absolute;top:0;left:25%;right:25%;height:2px;background:var(--grad);
  border-radius:99px;transform:scaleX(0);transition:transform .2s var(--bounce)}
.mob-ni.on::before{transform:scaleX(1)}
.mob-ni-bg{width:42px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s var(--smooth)}
.mob-ni.on .mob-ni-bg{background:rgba(232,23,93,.14)}
.mob-ni .mi{font-size:23px;color:var(--t3);transition:all .2s}.mob-ni.on .mi{color:var(--a2);transform:scale(1.1)}
.mob-ni .lbl{font-size:.56rem;font-weight:700;color:var(--t3);transition:color .2s}.mob-ni.on .lbl{color:var(--a2)}

/* ── MOBILE MINI PLAYER ─────────────────────────────── */
.mob-player{display:none;background:rgba(10,10,20,.99);backdrop-filter:blur(30px);
  border-top:1px solid var(--g1);flex-shrink:0;position:relative;z-index:9}
.mob-prog{position:absolute;top:0;left:0;right:0;height:2px;background:var(--s4)}
.mob-prog-fill{position:absolute;top:0;left:0;height:100%;background:var(--grad);width:0%;transition:width .3s linear}
.mob-row{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer}
.mob-aw{width:42px;height:42px;border-radius:8px;flex-shrink:0;overflow:hidden;background:var(--s3)}
.mob-aw img{width:100%;height:100%;object-fit:cover;display:block}
.mob-aw-ph{width:100%;height:100%;background:var(--grad);display:flex;align-items:center;justify-content:center}.mob-aw-ph .mi{font-size:17px;color:#fff}
.mob-mid{flex:1;min-width:0}.mob-tit{font-size:.82rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mob-sub{font-size:.65rem;color:var(--t3)}
.mob-ctrl{display:flex;align-items:center;flex-shrink:0}
.mob-lk{background:none;border:none;cursor:pointer;color:var(--t3);width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .14s}
.mob-lk:active{transform:scale(.8)}.mob-lk.on{color:var(--a2)}.mob-lk .mi{font-size:21px;color:inherit}
.mob-pp{width:38px;height:38px;border-radius:50%;background:var(--grad);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;box-shadow:0 3px 9px rgba(232,23,93,.4);transition:transform .15s var(--bounce)}
.mob-pp:active{transform:scale(.88)}.mob-pp .mi{font-size:22px;color:#fff}
.mob-nx{background:none;border:none;cursor:pointer;color:var(--t2);width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.mob-nx:active{transform:scale(.88)}.mob-nx .mi{font-size:22px;color:inherit}

/* ── PLAYER SHEET ───────────────────────────────────── */
.psheet{position:fixed;inset:0;z-index:500;display:flex;flex-direction:column;
  transform:translateY(100%);transition:transform .38s var(--smooth);overflow:hidden;padding-top:var(--sft)}
.ps-bg{position:absolute;inset:-50px;z-index:0;background-size:cover;background-position:center;
  filter:blur(75px) saturate(1.9) brightness(.35);transform:scale(1.2);pointer-events:none;transition:background-image .6s}
.ps-dark{position:absolute;inset:0;z-index:1;
  background:linear-gradient(to bottom,rgba(8,8,15,.45),rgba(8,8,15,.8) 40%,rgba(8,8,15,.97) 65%);pointer-events:none}
.psheet.open{transform:translateY(0)}
.ps-inner{position:relative;z-index:2;display:flex;flex-direction:column;height:100%;padding-bottom:calc(12px + var(--sfb))}
.ps-pill{width:32px;height:3px;border-radius:99px;background:var(--g2);margin:10px auto 0;flex-shrink:0}
.ps-top{display:flex;align-items:center;justify-content:space-between;padding:8px 16px 2px;flex-shrink:0}
.ps-dn{background:none;border:none;cursor:pointer;color:var(--t2);display:flex;align-items:center;gap:3px;font-family:'DM Sans',sans-serif;font-size:.71rem;font-weight:600;padding:6px 8px;border-radius:8px;transition:all .14s}
.ps-dn:hover{background:var(--g0)}.ps-dn .mi{font-size:20px;color:inherit}
.ps-badge{font-size:.52rem;font-weight:800;letter-spacing:.8px;text-transform:uppercase;padding:3px 9px;border-radius:99px}
.ps-art-area{flex-shrink:0;padding:10px 22px 0;display:flex;justify-content:center}
.ps-art{width:min(76vw,280px);aspect-ratio:1;border-radius:18px;object-fit:cover;
  box-shadow:0 18px 46px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.06);display:block}
.ps-art.playing{animation:artBob 4s ease-in-out infinite}
@keyframes artBob{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-9px) rotate(1deg)}}
.ps-art-ph{width:min(76vw,280px);aspect-ratio:1;border-radius:18px;background:var(--grad);display:flex;align-items:center;justify-content:center;box-shadow:0 18px 46px rgba(232,23,93,.3)}
.ps-art-ph .mi{font-size:75px;color:#fff}
.ps-meta{padding:13px 22px 3px;flex-shrink:0}
.ps-tit{font-family:'Syne',sans-serif;font-weight:900;font-size:1.18rem;letter-spacing:-.3px;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px}
.ps-row2{display:flex;align-items:center;justify-content:space-between;gap:8px}
.ps-sub{font-size:.82rem;color:var(--t2);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.ps-lk{background:none;border:none;cursor:pointer;color:var(--t3);padding:5px;border-radius:50%;display:flex;flex-shrink:0;transition:all .2s var(--bounce)}
.ps-lk:active{transform:scale(.78)}.ps-lk.on{color:var(--a2)}.ps-lk .mi{font-size:25px;color:inherit}
.ps-prog-area{padding:7px 22px;flex-shrink:0}
.ps-bar{height:3px;background:var(--s4);border-radius:99px;cursor:pointer;margin-bottom:4px;transition:height .14s}.ps-bar:hover{height:6px}
.ps-fill{height:100%;background:var(--grad);border-radius:99px;width:0%}
.ps-times{display:flex;justify-content:space-between;font-size:.6rem;color:var(--t3);font-weight:600}
.ps-ctrls{display:flex;align-items:center;justify-content:center;gap:1px;padding:2px 10px 0;flex-shrink:0}
.ps-c{width:46px;height:46px;border-radius:50%;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--t2);transition:all .14s}
.ps-c:active{transform:scale(.85)}.ps-c.on{color:var(--accent)}.ps-c .mi{font-size:25px;color:inherit}
.ps-pp{width:60px;height:60px;border-radius:50%;background:var(--grad);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;box-shadow:0 6px 22px rgba(232,23,93,.55);transition:all .2s var(--bounce)}
.ps-pp:active{transform:scale(.88)}.ps-pp .mi{font-size:30px;color:#fff}
.ps-extra{display:flex;align-items:center;justify-content:space-around;padding:3px 10px 0;flex-shrink:0}
.ps-xb{background:none;border:none;cursor:pointer;color:var(--t3);width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .14s}
.ps-xb:active{transform:scale(.86)}.ps-xb.on{color:var(--accent)}.ps-xb .mi{font-size:22px;color:inherit}
/* tabs */
.ps-tabs{display:flex;gap:0;padding:0 22px;flex-shrink:0;border-bottom:1px solid var(--g1);margin-top:5px}
.ps-tab{flex:1;padding:7px 0;text-align:center;font-size:.67rem;font-weight:700;color:var(--t3);cursor:pointer;border-bottom:2px solid transparent;transition:all .14s;letter-spacing:.4px;text-transform:uppercase}
.ps-tab.on{color:var(--a2);border-bottom-color:var(--a2)}
.ps-panel{flex:1;overflow-y:auto;padding:12px 22px;min-height:0;display:none;-webkit-overflow-scrolling:touch}
.ps-panel.on{display:block}
/* lyrics */
.lyr{line-height:1.9;color:var(--t2);font-size:.84rem;white-space:pre-line;font-weight:500}
.lyr-none{color:var(--t4);font-style:italic;font-size:.78rem;padding:8px 0}
.lyr-loading{display:flex;align-items:center;gap:8px;color:var(--t3);font-size:.77rem}
/* queue in sheet */
.shq-item{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--g0);cursor:pointer}
.shq-item.now .shq-nm{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.shq-img{width:34px;height:34px;border-radius:5px;object-fit:cover;flex-shrink:0;background:var(--s3)}
.shq-nm{font-size:.74rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.shq-by{font-size:.61rem;color:var(--t3)}

/* ── EQ PANEL ───────────────────────────────────────── */
.float-panel{position:fixed;bottom:calc(var(--ph) + 8px);right:12px;
  background:rgba(10,10,20,.98);border-radius:16px;padding:18px;z-index:400;
  box-shadow:0 18px 46px rgba(0,0,0,.7);backdrop-filter:blur(22px);display:none}
.float-panel.open{display:block;animation:panelIn .18s var(--smooth)}
@keyframes panelIn{from{opacity:0;transform:translateY(7px)}to{opacity:1;transform:none}}
.eq-panel{border:1px solid rgba(232,23,93,.18);width:min(360px,calc(100vw - 20px))}
.sleep-panel{border:1px solid rgba(124,58,237,.25);width:230px}
.xf-panel{border:1px solid rgba(6,182,212,.25);width:230px}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px}
.panel-title{font-family:'Syne',sans-serif;font-weight:800;font-size:.82rem}
.panel-title.eq-c{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.panel-title.sl-c{background:linear-gradient(135deg,#7c3aed,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.panel-title.xf-c{background:linear-gradient(135deg,#06b6d4,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.tog-row{display:flex;align-items:center;gap:6px;font-size:.63rem;color:var(--t3);font-weight:600}
.tog{width:30px;height:16px;border-radius:99px;background:var(--s4);cursor:pointer;position:relative;transition:background .2s;flex-shrink:0;border:1px solid var(--g1)}
.tog.on{background:var(--grad);border-color:transparent}
.tog::after{content:"";position:absolute;top:2.5px;left:2.5px;width:11px;height:11px;border-radius:50%;background:#fff;transition:transform .2s var(--bounce)}
.tog.on::after{transform:translateX(14px)}
/* EQ */
.eq-pres{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:13px}
.eq-p{padding:3px 9px;border-radius:99px;border:1px solid var(--g1);background:var(--s3);cursor:pointer;color:var(--t3);font-size:.63rem;font-weight:700;transition:all .14s}
.eq-p:hover{color:var(--t1)}.eq-p.on{background:var(--ad);border-color:var(--ab);color:var(--a2)}
.eq-bands{display:flex;gap:6px;justify-content:space-between;align-items:flex-end;height:105px;padding:0 2px}
.eq-band{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1}
.eq-val{font-size:.47rem;color:var(--a2);font-weight:800;height:10px;text-align:center}
.eq-rng{-webkit-appearance:none;appearance:none;writing-mode:vertical-lr;direction:rtl;width:3px;height:70px;border-radius:99px;cursor:pointer;outline:none;background:var(--s4)}
.eq-rng::-webkit-slider-thumb{-webkit-appearance:none;width:11px;height:11px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);cursor:pointer}
.eq-freq{font-size:.46rem;color:var(--t4);text-align:center;font-weight:600}
.eq-foot{margin-top:9px;display:flex;gap:5px}
.eq-b{flex:1;padding:6px;border-radius:7px;border:1px solid var(--g1);background:var(--s3);color:var(--t3);font-family:'DM Sans',sans-serif;font-weight:700;font-size:.67rem;cursor:pointer;transition:all .14s}
.eq-b:hover{color:var(--t1);background:var(--s4)}
/* sleep / xfade opts */
.panel-opts{display:flex;flex-direction:column;gap:3px}
.popt{padding:8px 10px;border-radius:8px;border:1px solid var(--g1);background:var(--s3);color:var(--t2);
  font-family:'DM Sans',sans-serif;font-size:.74rem;font-weight:600;cursor:pointer;transition:all .14s;display:flex;align-items:center;gap:7px}
.popt:hover{background:var(--s4);color:var(--t1)}.popt.on{background:rgba(124,58,237,.15);border-color:rgba(124,58,237,.4);color:#a78bfa}
.popt.on.xf{background:rgba(6,182,212,.13);border-color:rgba(6,182,212,.35);color:#22d3ee}
.popt .mi{font-size:15px;color:inherit}

/* ── MODALS ─────────────────────────────────────────── */
.overlay{position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.72);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:16px}
.overlay.open{display:flex;animation:ovIn .16s ease}
@keyframes ovIn{from{opacity:0}to{opacity:1}}
.modal{background:var(--s2);border:1px solid var(--g2);border-radius:18px;padding:20px;width:min(330px,100%);box-shadow:0 22px 56px rgba(0,0,0,.7)}
.modal-title{font-family:'Syne',sans-serif;font-weight:800;font-size:.9rem;margin-bottom:13px}
.modal-inp{width:100%;background:var(--s3);border:1.5px solid var(--g1);border-radius:9px;
  padding:9px 13px;color:var(--t1);font-family:'DM Sans',sans-serif;font-size:.82rem;outline:none;transition:border-color .2s;margin-bottom:2px}
.modal-inp:focus{border-color:rgba(232,23,93,.35)}
.modal-inp::placeholder{color:var(--t4)}
.ic-grid{display:flex;gap:5px;flex-wrap:wrap;margin:9px 0}
.ic-opt{width:33px;height:33px;border-radius:7px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:2px solid transparent;transition:all .15s}
.ic-opt:hover{transform:scale(1.12)}.ic-opt.on{border-color:#fff;box-shadow:0 0 0 2px rgba(255,255,255,.25)}.ic-opt .mi{font-size:15px;color:#fff}
.modal-row{display:flex;justify-content:flex-end;gap:7px;margin-top:13px}
/* add-to-playlist modal */
.atp-list{display:flex;flex-direction:column;gap:3px;max-height:240px;overflow-y:auto;margin-bottom:4px}
.atp-item{padding:9px 11px;border-radius:9px;border:1px solid var(--g1);background:var(--s3);color:var(--t2);
  font-family:'DM Sans',sans-serif;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .14s;display:flex;align-items:center;gap:9px}
.atp-item:hover{background:var(--s4);color:var(--t1)}
.atp-ic{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.atp-ic .mi{font-size:14px;color:#fff}

/* ── EMPTY / MISC ───────────────────────────────────── */
.empty{display:flex;flex-direction:column;align-items:center;gap:9px;padding:40px 16px;color:var(--t3);text-align:center}
.empty .mi{font-size:44px;color:var(--t4)}.empty p{font-size:.78rem;line-height:1.7;max-width:220px}
.empty-sm{font-size:.71rem;color:var(--t4);padding:14px;text-align:center}
.toast{position:fixed;bottom:calc(var(--ph) + 10px);left:50%;transform:translateX(-50%) translateY(10px);
  background:rgba(10,10,20,.97);backdrop-filter:blur(18px);border:1px solid rgba(232,23,93,.22);
  border-radius:100px;padding:7px 15px;font-size:.76rem;font-weight:600;display:flex;align-items:center;gap:5px;
  opacity:0;transition:all .22s var(--smooth);z-index:9999;pointer-events:none;white-space:nowrap;
  box-shadow:0 7px 20px rgba(0,0,0,.5);max-width:calc(100vw - 36px)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}.toast .mi{font-size:14px;color:var(--a2)}

/* ── RESPONSIVE ─────────────────────────────────────── */
@media(max-width:768px){
  .sidebar,.player-bar{display:none!important}
  .mob-player,.mob-nav{display:block!important}
  .topbar{padding:8px 11px}
  .content{padding:10px 11px 8px}
  .cards{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:7px}
  .lib-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:7px}
  .nphero{padding:12px 13px;gap:10px}.np-thumb,.np-ph{width:60px;height:60px;border-radius:10px}
  .np-tit{font-size:.95rem}.chips{gap:4px}.chip{padding:5px 10px;font-size:.68rem}
  .toast{bottom:calc(var(--sfb) + 130px)}
  .float-panel{bottom:calc(var(--sfb) + 128px);right:8px;left:8px;width:auto}
  .eq-panel,.sleep-panel,.xf-panel{width:100%}
  #btnInstall{display:none!important}
}
