*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0d0d0d;--bg-panel: #141414;--bg-row: #1a1a1a;--bg-row-hover: #222;--bg-input: #1e1e1e;--border: #2a2a2a;--text: #c8c8c8;--text-dim: #777;--text-bright: #eee;--accent: #e8a030;--accent-dim:#b07820;--danger: #d44;--green: #3a3;--mono: "JetBrains Mono", "Fira Code", monospace;--sans: system-ui, -apple-system, sans-serif;--radius: 4px;--player-h: 72px;--sidebar-w: 340px}html{font-size:14px}body{font-family:var(--sans);background:var(--bg);color:var(--text);min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:#333;border-radius:3px}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem}.login-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:8px;padding:2.5rem 2rem;width:100%;max-width:360px}.login-logo{font-family:var(--mono);font-weight:600;font-size:1.1rem;color:var(--accent);letter-spacing:.08em;text-transform:uppercase;text-align:center;margin-bottom:2rem}.login-field{margin-bottom:1rem}.login-field label{display:block;font-size:.75rem;font-family:var(--mono);color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.35rem}.login-field input{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:.55rem .7rem;font-size:.9rem;outline:none}.login-field input:focus{border-color:var(--accent-dim)}.login-error{color:var(--danger);font-size:.8rem;margin-bottom:.75rem;min-height:1.2em}.login-submit{width:100%;background:var(--accent);color:#111;border:none;border-radius:var(--radius);padding:.6rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}.login-submit:hover{background:#f0b040}.login-submit:disabled{opacity:.5;cursor:not-allowed}.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 1rem;height:42px;background:var(--bg-panel);border-bottom:1px solid var(--border);flex-shrink:0}.topbar-logo{font-family:var(--mono);font-weight:600;font-size:.9rem;color:var(--accent);letter-spacing:.08em;text-transform:uppercase}.topbar-right{display:flex;align-items:center;gap:1rem}.topbar-status{font-family:var(--mono);font-size:.75rem;color:var(--text-dim)}.topbar-status .dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:5px;vertical-align:middle}.dot-connected{background:var(--green)}.dot-reconnecting{background:var(--accent)}.dot-disconnected{background:var(--danger)}.topbar-logout{background:none;border:1px solid var(--border);color:var(--text-dim);font-size:.72rem;font-family:var(--mono);padding:3px 10px;border-radius:var(--radius);cursor:pointer;transition:color .15s,border-color .15s}.topbar-logout:hover{color:var(--text);border-color:var(--text-dim)}.main{display:flex;flex:1;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--bg-panel)}.sidebar-header{padding:.75rem 1rem .5rem;display:flex;align-items:center;gap:.5rem}.sidebar-header h2{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);flex:1}.sidebar-header .count{font-family:var(--mono);font-size:.7rem;color:var(--accent);background:#e8a0301f;padding:2px 7px;border-radius:8px}.search-box{padding:0 1rem .5rem}.search-box input{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:.4rem .6rem;font-size:.8rem;font-family:var(--mono);outline:none}.search-box input:focus{border-color:var(--accent-dim)}.search-box input::placeholder{color:#555}.track-list{flex:1;overflow-y:auto;padding:0}.track-row{display:grid;grid-template-columns:36px 1fr 60px 32px;align-items:center;gap:0;padding:.35rem 1rem;border-bottom:1px solid rgba(255,255,255,.03);cursor:pointer;transition:background .12s}.track-row:hover{background:var(--bg-row-hover)}.track-row.playing{background:#e8a03014}.track-idx{font-family:var(--mono);font-size:.7rem;color:var(--text-dim);text-align:center}.track-row.playing .track-idx{color:var(--accent)}.track-info{overflow:hidden}.track-title{font-size:.85rem;color:var(--text-bright);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-artist{font-size:.72rem;color:var(--text-dim);font-family:var(--mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-dur{font-family:var(--mono);font-size:.72rem;color:var(--text-dim);text-align:right}.track-add-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:1rem;padding:2px;border-radius:var(--radius);transition:color .15s,background .15s;text-align:center}.track-add-btn:hover{color:var(--accent);background:#e8a0301a}.import-section{border-top:1px solid var(--border);padding:.75rem 1rem}.import-section h3{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin-bottom:.5rem}.import-row{display:flex;gap:.4rem;margin-bottom:.5rem}.import-row input{flex:1;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:.35rem .5rem;font-size:.78rem;font-family:var(--mono);outline:none}.import-row input:focus{border-color:var(--accent-dim)}.btn{background:var(--accent);color:#111;border:none;border-radius:var(--radius);padding:.35rem .7rem;font-size:.78rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.btn:hover{background:#f0b040}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-outline{background:transparent;border:1px solid var(--accent-dim);color:var(--accent)}.btn-outline:hover{background:#e8a0301a}.import-job{background:var(--bg-row);border-radius:var(--radius);padding:.4rem .6rem;margin-top:.4rem}.import-job-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.3rem}.import-job-title{font-size:.75rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.import-job-status{font-family:var(--mono);font-size:.7rem}.import-status-running{color:var(--accent)}.import-status-queued{color:var(--text-dim)}.import-status-completed{color:var(--green)}.import-status-failed{color:var(--danger)}.import-status-cancelled{color:var(--text-dim)}.import-progress-track{height:4px;background:#222;border-radius:2px;overflow:hidden}.import-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s}.center{flex:1;display:flex;flex-direction:column;overflow:hidden}.queue-header{padding:.75rem 1.2rem .5rem;display:flex;align-items:center;gap:.6rem;border-bottom:1px solid var(--border)}.queue-header h2{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);flex:1}.queue-header .queue-count{font-family:var(--mono);font-size:.7rem;color:var(--text-dim)}.queue-list{flex:1;overflow-y:auto;padding:.3rem 0}.queue-item{display:grid;grid-template-columns:30px auto 60px 56px;align-items:center;padding:.5rem 1.2rem;border-bottom:1px solid rgba(255,255,255,.03);transition:background .12s}.queue-item:hover{background:var(--bg-row-hover)}.queue-item.active{background:#e8a03014;border-left:3px solid var(--accent);padding-left:calc(1.2rem - 3px)}.queue-pos{font-family:var(--mono);font-size:.72rem;color:var(--text-dim)}.queue-item.active .queue-pos{color:var(--accent)}.queue-info{overflow:hidden}.queue-title{font-size:.85rem;color:var(--text-bright);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-artist{font-size:.72rem;color:var(--text-dim);font-family:var(--mono)}.queue-dur{font-family:var(--mono);font-size:.72rem;color:var(--text-dim);text-align:right}.queue-actions{display:flex;gap:2px;justify-content:flex-end}.queue-move-btn,.queue-remove{background:none;border:none;color:#555;cursor:pointer;font-size:.85rem;padding:2px 4px;border-radius:var(--radius);transition:color .15s}.queue-move-btn:hover{color:var(--text)}.queue-remove:hover{color:var(--danger)}.queue-move-btn:disabled{opacity:.2;cursor:default}.queue-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-dim);font-size:.85rem;gap:.5rem}.queue-empty-icon{font-size:2rem;opacity:.3}.player{height:var(--player-h);background:var(--bg-panel);border-top:1px solid var(--border);display:grid;grid-template-columns:var(--sidebar-w) 1fr 160px;align-items:center;flex-shrink:0}.player-info{padding:0 1rem;overflow:hidden}.player-track-title{font-size:.9rem;color:var(--text-bright);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-track-artist{font-size:.75rem;color:var(--text-dim);font-family:var(--mono)}.player-center{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:0 1rem}.player-controls{display:flex;align-items:center;gap:.8rem}.player-btn{background:none;border:none;color:var(--text);cursor:pointer;font-size:1.1rem;padding:4px;border-radius:50%;transition:color .15s,background .15s;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.player-btn:hover{color:var(--text-bright);background:#ffffff0f}.player-btn-play{width:40px;height:40px;font-size:1.3rem;background:var(--accent);color:#111;border-radius:50%}.player-btn-play:hover{background:#f0b040;color:#111}.player-progress-row{display:flex;align-items:center;gap:.5rem;width:100%;max-width:600px}.player-time{font-family:var(--mono);font-size:.68rem;color:var(--text-dim);min-width:38px;text-align:center}.vu-meter{flex:1;height:8px;display:flex;gap:2px;align-items:center;cursor:pointer}.vu-segment{flex:1;height:100%;border-radius:1px;background:#222;transition:background .1s}.vu-segment.lit-green{background:#3a6}.vu-segment.lit-yellow{background:#c90}.vu-segment.lit-red{background:#d44}.player-volume{padding:0 1rem;display:flex;align-items:center;gap:.4rem}.vol-icon{color:var(--text-dim);font-size:.9rem;cursor:pointer}.vol-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:80px;height:4px;background:#333;border-radius:2px;outline:none}.vol-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--accent);cursor:pointer}@media(max-width:768px){.main{flex-direction:column}.sidebar{width:100%;min-width:0;max-height:50vh;border-right:none;border-bottom:1px solid var(--border)}.player{grid-template-columns:1fr;height:auto;padding:.5rem;gap:.4rem}.player-volume{display:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
