:root{
  --bg:#0b0d12; --bg2:#12151d; --card:#171b25; --card2:#1d2230;
  --line:#262c3a; --txt:#e8ebf2; --muted:#8a92a6; --accent:#4f8cff;
  --accent2:#37e0a0; --star:#ffc24b; --danger:#ff5d6c; --warn:#ffb13b;
  --radius:14px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  background:var(--bg); color:var(--txt);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  font-size:15px; overscroll-behavior-y:none;
}
.hidden{display:none !important}
button{font-family:inherit; cursor:pointer}
input,select,button{font-size:15px}

/* ───── Login ───── */
.login{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(120% 80% at 50% 0%, #1a2030 0%, var(--bg) 60%);padding:16px}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:20px;
  padding:32px 24px;width:100%;max-width:340px;text-align:center}
.login-card .logo{font-size:46px}
.login-card h1{margin:6px 0 4px;font-size:22px}
.login-card p{color:var(--muted);margin:0 0 18px}
.login-card input{width:100%;padding:14px;border-radius:12px;border:1px solid var(--line);
  background:var(--bg2);color:var(--txt);margin-bottom:12px}
.login-card button{width:100%;padding:14px;border:0;border-radius:12px;
  background:var(--accent);color:#fff;font-weight:600}
.error{color:var(--danger);margin-top:10px;font-size:13px;min-height:16px}

/* ───── Layout ───── */
.app{display:flex;flex-direction:column;min-height:100vh;padding-bottom:160px}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;padding-top:max(14px,env(safe-area-inset-top));
  background:rgba(11,13,18,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.brand{font-weight:700;font-size:16px;display:flex;gap:8px;align-items:center}
.brand span{font-weight:600}
.status-pill{border:0;background:transparent;font-size:18px;color:var(--muted);padding:4px 8px;border-radius:10px}
.status-pill.online{color:var(--accent2)}
.status-pill.offline{color:var(--danger)}
.status-pill.busy{color:var(--warn)}

.tabs{position:sticky;top:53px;z-index:19;display:flex;background:var(--bg);border-bottom:1px solid var(--line)}
.tab{flex:1;background:transparent;border:0;color:var(--muted);padding:13px 0;font-weight:600;
  border-bottom:2px solid transparent}
.tab.active{color:var(--txt);border-bottom-color:var(--accent)}

.tab-panel{display:none;padding:12px 12px 0}
.tab-panel.active{display:block}

/* ───── Controls ───── */
.controls{display:flex;flex-direction:column;gap:10px;margin-bottom:8px}
.search{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--line);
  background:var(--card);color:var(--txt)}
.controls .row{display:flex;gap:8px;align-items:center}
.controls select{flex:1;padding:10px;border-radius:10px;border:1px solid var(--line);
  background:var(--card);color:var(--txt)}
.chk{display:flex;align-items:center;gap:6px;color:var(--muted);white-space:nowrap;padding:0 4px}
.chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}
.chip{flex:0 0 auto;padding:7px 13px;border-radius:999px;border:1px solid var(--line);
  background:var(--card);color:var(--muted);font-size:13px;white-space:nowrap}
.chip.active{background:var(--accent);border-color:var(--accent);color:#fff}
.count{color:var(--muted);font-size:13px;margin:6px 2px}

/* ───── Track list ───── */
.track-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.track{display:flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);padding:10px 12px}
.track.playing{border-color:var(--accent)}
.drag-handle{color:var(--muted);font-size:20px;cursor:grab;touch-action:none;padding:0 2px;user-select:none}
.t-main{flex:1;min-width:0}
.t-title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.t-sub{color:var(--muted);font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.t-badges{display:flex;gap:6px;margin-top:5px;flex-wrap:wrap}
.badge{font-size:11px;color:var(--muted);background:var(--card2);border-radius:6px;padding:2px 6px}
.badge.genre{color:#bcd0ff}
.badge.pending{color:#000;background:var(--warn)}
.stars{display:flex;gap:2px;font-size:17px;line-height:1;margin-top:6px}
.stars span{color:#4a5168;padding:2px 1px}
.stars span.on{color:var(--star)}
.t-actions{display:flex;gap:4px;align-items:center}
.iconbtn{border:0;background:var(--card2);color:var(--txt);width:36px;height:36px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;font-size:16px}
.iconbtn.add{background:var(--accent);color:#fff}
.iconbtn.rm{background:transparent;color:var(--danger)}
.iconbtn.play.playing{background:var(--accent);color:#fff}
.iconbtn:disabled{opacity:.35}

.load-more{display:block;margin:14px auto;padding:11px 22px;border-radius:10px;border:1px solid var(--line);
  background:var(--card);color:var(--txt)}
.empty{color:var(--muted);text-align:center;padding:40px 20px}

/* ───── Playlist header ───── */
.pl-header{display:flex;gap:8px;align-items:center;margin-bottom:6px}
.pl-header select{flex:1;padding:11px;border-radius:11px;border:1px solid var(--line);background:var(--card);color:var(--txt)}
.icon-btn{width:42px;height:42px;border-radius:11px;border:1px solid var(--line);background:var(--card);color:var(--txt);font-size:20px}
.pl-meta{color:var(--muted);font-size:13px;margin:2px 2px 10px}
.sortable-ghost{opacity:.35}
.sortable-chosen{border-color:var(--accent)}

/* ───── Sync bar ───── */
.sync-bar{position:fixed;left:0;right:0;bottom:64px;z-index:25;display:flex;gap:10px;align-items:center;
  padding:10px 12px;padding-bottom:calc(10px);background:linear-gradient(0deg,var(--bg) 60%,transparent);
}
.sync-msg{flex:1;color:var(--muted);font-size:12.5px;min-width:0}
.sync-btn{padding:13px 18px;border:0;border-radius:12px;background:var(--accent2);color:#04120c;font-weight:700}
.sync-btn:disabled{opacity:.5}

/* ───── Player ───── */
.player{position:fixed;left:8px;right:8px;bottom:8px;z-index:30;display:flex;align-items:center;gap:10px;
  background:var(--card2);border:1px solid var(--line);border-radius:14px;padding:8px 12px;
  box-shadow:0 8px 24px rgba(0,0,0,.4)}
.player-toggle{width:40px;height:40px;border-radius:50%;border:0;background:var(--accent);color:#fff;font-size:16px}
.player-info{flex:1;min-width:0}
.player-title{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}
.player-seek{width:100%;accent-color:var(--accent);height:4px}
.player-close{background:transparent;border:0;color:var(--muted);font-size:18px}

/* ───── Modal & toast ───── */
.modal{position:fixed;inset:0;z-index:40;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.6);padding:20px}
.modal-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px;width:100%;max-width:340px}
.modal-card h3{margin:0 0 12px}
.modal-card input{width:100%;padding:12px;border-radius:10px;border:1px solid var(--line);background:var(--bg2);color:var(--txt);margin-bottom:12px}
.modal-actions{display:flex;gap:8px;justify-content:flex-end}
.modal-actions button{padding:10px 16px;border-radius:10px;border:1px solid var(--line);background:var(--card2);color:var(--txt)}
.modal-actions .primary{background:var(--accent);border-color:var(--accent);color:#fff}
.modal-actions .danger{background:var(--danger);border-color:var(--danger);color:#fff}

.toast{position:fixed;left:50%;bottom:90px;transform:translateX(-50%);z-index:50;
  background:#000c;border:1px solid var(--line);color:#fff;padding:11px 18px;border-radius:12px;font-size:14px;max-width:90%}
