:root{--bg: #0f1012;--bg-elevated: #16181c;--fg: #e8e8ea;--muted: #8a8c91;--accent: #6aa6ff;--accent-strong: #9bc2ff;--error: #ff6b6b;--warn: #d2a64a;--ok: #5fbf73;--surface: #1a1c20;--border: #2a2d33;--radius: 6px;--gap: .75rem}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--fg);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5}button{font:inherit;background:var(--surface);color:var(--fg);border:1px solid var(--border);border-radius:var(--radius);padding:.35rem .7rem;cursor:pointer}button:hover{border-color:var(--accent)}button:disabled{opacity:.5;cursor:not-allowed}input[type=text],input[type=search],input[type=password],select{font:inherit;background:var(--bg);color:var(--fg);border:1px solid var(--border);border-radius:var(--radius);padding:.4rem .6rem}input:focus,select:focus{outline:none;border-color:var(--accent)}.muted{color:var(--muted)}.small{font-size:.85rem}.error{color:var(--error)}.centered{min-height:100%;display:grid;place-items:center;padding:2rem}.login{display:flex;flex-direction:column;gap:var(--gap);width:100%;max-width:320px;padding:1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.login h1{margin:0 0 .5rem;font-size:1.3rem}.login label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;color:var(--muted)}.login button{background:var(--accent);color:#0a0a0a;border-color:transparent;font-weight:600}.login button:disabled{opacity:.6;cursor:progress}.login .error{margin:0}.shell{display:grid;grid-template-rows:auto 1fr auto;height:100%}.app-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem 1rem;background:var(--bg-elevated);border-bottom:1px solid var(--border)}.app-header h1{margin:0;font-size:1.05rem;letter-spacing:.02em}.app-header-left,.app-header-center,.app-header-right{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.ws-status{font-size:.75rem;text-transform:uppercase;padding:.1rem .4rem;border:1px solid var(--border);border-radius:var(--radius);letter-spacing:.05em;color:var(--muted)}.ws-status-connected{border-color:var(--ok);color:var(--ok)}.ws-status-connecting{border-color:var(--warn);color:var(--warn)}.ws-status-disconnected{border-color:var(--error);color:var(--error)}.mode-picker,.volume-slider{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--muted)}.volume-slider input[type=range]{width:110px}.output-picker{display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem}.output-picker-label{color:var(--muted)}.output-picker-options{display:inline-flex;gap:.5rem;flex-wrap:wrap}.output-picker-option{display:inline-flex;align-items:center;gap:.25rem;cursor:pointer}.app-main{display:grid;grid-template-columns:minmax(220px,280px) 1fr;gap:1rem;padding:1rem;overflow:hidden;min-height:0}.app-sidebar,.app-content{display:flex;flex-direction:column;gap:1rem;overflow-y:auto}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.8rem 1rem;display:flex;flex-direction:column;gap:.5rem}.panel h2{margin:0 0 .25rem;font-size:.95rem;font-weight:600;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}.playlist-list,.track-list,.queue-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem}.playlist-list-item,.track-list-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.4rem .5rem;border-radius:var(--radius)}.playlist-list-item:hover,.track-list-item:hover{background:#ffffff08}.playlist-list-item-meta,.track-list-meta{display:flex;flex-direction:column;min-width:0}.playlist-name,.track-title{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-list-actions{display:flex;gap:.3rem}.queue-list{font-variant-numeric:tabular-nums;font-size:.85rem}.queue-current{color:var(--accent-strong);font-weight:600}.playlist-list-item-wrap{display:flex;flex-direction:column}.playlist-list-item{display:grid;grid-template-columns:auto 1fr auto;gap:.5rem;align-items:center;padding:.4rem .5rem;border-radius:var(--radius)}.playlist-list-item:hover{background:#ffffff08}.playlist-disclosure{background:transparent;border:none;color:var(--muted);padding:0 .2rem;font-size:.9rem;cursor:pointer;width:1.4rem}.playlist-disclosure:hover{color:var(--accent)}.playlist-tracks{margin:.2rem 0 .4rem 1.4rem;padding-left:.6rem;border-left:1px solid var(--border)}.playlist-track-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.15rem;counter-reset:none}.playlist-track{display:grid;grid-template-columns:2ch 1fr auto;gap:.5rem;align-items:center;padding:.25rem .4rem;border-radius:var(--radius)}.playlist-track:hover{background:#ffffff08}.playlist-track.playing{background:#6aa6ff12;border-left:2px solid var(--accent);padding-left:calc(.4rem - 2px)}.playlist-track-pos{text-align:right;font-variant-numeric:tabular-nums}.playlist-track-meta{display:flex;flex-direction:column;min-width:0}.playlist-track-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.9rem}.playlist-track-actions{display:flex;gap:.2rem}.playlist-track-actions button{padding:.1rem .4rem;font-size:.85rem}.library-panel{min-height:0;overflow:hidden}.library-search{display:flex;gap:.5rem}.library-search input{flex:1}.library-meta{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.library-pager{display:flex;gap:.3rem}.track-table-wrap{overflow:auto;border:1px solid var(--border);border-radius:var(--radius);flex:1;min-height:0}.track-table{width:100%;border-collapse:collapse;font-size:.9rem}.track-table thead{position:sticky;top:0;background:var(--bg-elevated);z-index:1}.track-table th{text-align:left;font-weight:600;color:var(--muted);padding:.4rem .6rem;border-bottom:1px solid var(--border);white-space:nowrap;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase}.track-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.track-table th.sortable:hover{color:var(--accent)}.track-table th.sort-active{color:var(--accent-strong)}.track-table th .sort-indicator{display:inline-block;width:1ch;margin-left:.4ch;font-size:.7rem}.track-table td{padding:.35rem .6rem;border-bottom:1px solid rgba(255,255,255,.04);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:28ch}.track-table td.col-num{text-align:right;font-variant-numeric:tabular-nums;width:1%}.track-table td.col-actions{width:1%;white-space:nowrap}.track-table td.col-actions button{padding:.15rem .45rem;font-size:.85rem;margin-left:.2rem}.track-table tr.track-row:hover{background:#ffffff0a}.track-table tr.track-row.playing{background:#6aa6ff12}.track-table tr.track-row.playing td:first-child{border-left:2px solid var(--accent);padding-left:calc(.6rem - 2px)}.cell-link{background:transparent;border:none;padding:0;color:inherit;font:inherit;cursor:pointer;text-align:left;text-decoration:none}.cell-link:hover{color:var(--accent);text-decoration:underline}.upload-manager{display:flex;flex-direction:column;gap:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);margin-bottom:.25rem}.upload-manager-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.upload-manager-header h3{margin:0;font-size:.85rem;font-weight:600;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}.upload-manager-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.autotag-toggle{display:inline-flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none}.autotag-toggle input[type=checkbox]{margin:0}.upload-progress{display:flex;flex-direction:column;gap:.4rem;width:100%}.upload-progress-label{font-size:.85rem}.upload-progress progress{width:100%;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none}.upload-progress progress::-webkit-progress-bar{background:var(--border);border-radius:3px}.upload-progress progress::-webkit-progress-value{background:var(--accent);border-radius:3px}.upload-progress progress::-moz-progress-bar{background:var(--accent)}.drop-zone-uploading{cursor:progress}.ingest-counts{font-weight:400;color:var(--muted)}.ingest-counts strong{color:var(--fg)}.drop-zone{border:1px dashed var(--border);border-radius:var(--radius);padding:1rem;text-align:center;color:var(--muted);cursor:pointer;transition:border-color 80ms ease,background 80ms ease}.drop-zone:hover,.drop-zone:focus-visible{border-color:var(--accent);outline:none}.drop-zone-active{border-color:var(--accent);background:#6aa6ff0f;color:var(--accent-strong)}.incoming-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.2rem}.incoming-item{display:grid;grid-template-columns:1fr auto auto;gap:.5rem;align-items:center;padding:.3rem .4rem;border-radius:var(--radius)}.incoming-item:hover{background:#ffffff08}.incoming-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-variant-numeric:tabular-nums}.ingest-result{display:flex;flex-direction:column;gap:.4rem;padding:.5rem .7rem;border-left:3px solid var(--border);background:#ffffff05;border-radius:0 var(--radius) var(--radius) 0}.ingest-result.ingest-ok{border-left-color:var(--ok)}.ingest-result.ingest-failed{border-left-color:var(--error)}.ingest-summary{margin:0;font-weight:600;font-size:.9rem}.ingest-result.ingest-failed .ingest-summary{color:var(--error)}.ingest-result.ingest-ok .ingest-summary{color:var(--ok)}.ingest-output{margin:0;padding:.5rem .6rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);font-size:.78rem;white-space:pre-wrap;word-break:break-word;max-height:240px;overflow:auto}.ingest-stderr{color:var(--warn);border-color:var(--warn)}.ingest-result code{background:var(--bg);padding:0 .3rem;border-radius:3px;font-size:.8rem}.now-playing{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;align-items:center;padding:.6rem 1rem;background:var(--bg-elevated);border-top:1px solid var(--border)}.now-playing-track{display:flex;flex-direction:column;min-width:0}.now-playing-track strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.now-playing-controls{display:flex;gap:.4rem}.now-playing-controls button{font-size:1.1rem;width:2.4rem;text-align:center}.now-playing-position{display:flex;align-items:center;gap:.5rem;justify-content:flex-end;font-variant-numeric:tabular-nums;font-size:.8rem;color:var(--muted)}.seek-bar{width:clamp(120px,30vw,320px);height:6px;background:var(--border);border-radius:3px;cursor:pointer;position:relative}.seek-bar:hover{background:var(--surface)}.seek-bar:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.seek-bar-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .2s linear}.seek-bar.seek-bar-disabled{cursor:default;opacity:.5}.seek-bar.seek-bar-disabled:hover{background:var(--border)}
