:root{--ink:#1a1612;--panel:#221d18;--panel-raised:#2a241d;--line:#3a332b;--line-soft:#2e2823;--text:#f2e9dc;--text-dim:#b9ad9b;--text-faint:#7d7264;--copper:#c97b4a;--copper-bright:#e8b86d;--copper-dim:#8a5536;--danger:#b3553f;--font-display:"Fraunces", serif;--font-body:"Inter", -apple-system, sans-serif;--font-mono:"JetBrains Mono", monospace;--radius:6px;--player-h:92px}*{box-sizing:border-box}html,body{background:var(--ink);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;margin:0;padding:0}#root{height:100vh;overflow:hidden}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}button:focus-visible,input:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--copper-bright);outline-offset:2px}input{background:var(--panel-raised);border:1px solid var(--line);color:var(--text);border-radius:var(--radius);padding:10px 14px;font-family:inherit}::selection{background:var(--copper-dim);color:var(--text)}*{scrollbar-width:thin;scrollbar-color:var(--line) transparent}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.001ms!important;animation-duration:.001ms!important}}.login-screen{background:radial-gradient(at 30% 20%,#2a241d 0%,#1a1612 60%);justify-content:center;align-items:center;gap:64px;height:100%;padding:24px;display:flex}.login-disc svg{filter:drop-shadow(0 12px 28px #00000080);width:220px;height:220px;animation:16s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-card{flex-direction:column;gap:14px;width:340px;display:flex}.login-eyebrow{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--copper);margin:0;font-size:11px}.login-card h1{font-family:var(--font-display);margin:0;font-size:34px;font-weight:600;line-height:1.1}.login-sub{color:var(--text-dim);margin:0 0 6px;font-size:14px}.login-card input{font-size:15px}.login-error{color:var(--danger);margin:0;font-size:13px}.login-btn{background:var(--copper);color:#1a1612;border-radius:var(--radius);padding:12px 16px;font-size:14px;font-weight:600;transition:background .15s}.login-btn:hover:not(:disabled){background:var(--copper-bright)}.login-btn:disabled{opacity:.5;cursor:default}@media (width<=640px){.login-screen{flex-direction:column;gap:32px}.login-disc svg{width:140px;height:140px}.login-card{width:100%;max-width:320px}}.sidebar{background:var(--panel);border-right:1px solid var(--line-soft);flex-direction:column;flex-shrink:0;width:248px;height:100%;padding:20px 14px;display:flex;overflow-y:auto}@media (width<=720px){.sidebar{border-right:none;border-bottom:1px solid var(--line-soft);width:100%;height:auto;max-height:38vh}}.sidebar-brand{font-family:var(--font-display);align-items:center;gap:10px;padding:0 8px 18px;font-size:19px;font-weight:600;display:flex}.brand-disc{flex-shrink:0;width:26px;height:26px}.sidebar-nav{flex-direction:column;gap:2px;display:flex}.sidebar-label{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);align-items:center;gap:6px;margin:16px 12px 6px;font-size:10px;display:flex}.sidebar-label:first-child{margin-top:0}.sidebar-loading{color:var(--copper-dim);font-size:11px;animation:1.4s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}.sidebar-item{border-radius:var(--radius);color:var(--text-dim);text-align:left;justify-content:space-between;align-items:center;gap:8px;padding:8px 12px;font-size:13.5px;transition:background .1s,color .1s;display:flex}.sidebar-item span:first-child{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-item .count{font-family:var(--font-mono);color:var(--text-faint);flex-shrink:0;font-size:11px}.sidebar-item:hover{background:var(--panel-raised);color:var(--text)}.sidebar-item.active{background:var(--panel-raised);color:var(--copper-bright)}.sidebar-item.active .count{color:var(--copper-dim)}.tracklist{flex:1;padding:28px 36px 40px;overflow-y:auto}.tracklist-header{margin-bottom:24px}.tracklist-header h1{font-family:var(--font-display);margin:0 0 4px;font-size:32px;font-weight:600}.tracklist-header p{color:var(--text-faint);font-size:13px;font-family:var(--font-mono);margin:0}.tracklist-table{flex-direction:column;display:flex}.tracklist-row{border-radius:var(--radius);grid-template-columns:44px 2fr 1fr 72px 60px 40px;align-items:center;gap:12px;padding:6px 10px;transition:background .1s;display:grid}.tracklist-row--head{color:var(--text-faint);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line-soft);margin-bottom:4px;padding-bottom:10px;font-size:11px}.tracklist-row:not(.tracklist-row--head):hover{background:var(--panel-raised)}.tracklist-row.active .track-title{color:var(--copper-bright)}.col-index{color:var(--text-faint);font-family:var(--font-mono);justify-content:center;align-items:center;height:44px;font-size:13px;display:flex;position:relative}.idx-play{color:var(--text);justify-content:center;align-items:center;display:none;position:absolute;inset:0}.tracklist-row:hover .idx-num{display:none}.tracklist-row:hover .idx-play{display:flex}.col-title{align-items:center;gap:12px;min-width:0;display:flex}.track-cover{background:var(--panel-raised);border-radius:4px;flex-shrink:0;width:36px;height:36px;overflow:hidden}.track-cover img{object-fit:cover;width:100%;height:100%;display:block}.track-info{flex-direction:column;gap:2px;min-width:0;display:flex}.track-title{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.track-artist{color:var(--text-faint);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.col-album,.col-format,.col-duration{font-family:var(--font-mono);color:var(--text-faint);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.col-actions{justify-content:center;display:flex}.row-delete{opacity:0;color:var(--text-faint);border-radius:4px;padding:6px;transition:opacity .1s,color .15s}.tracklist-row:hover .row-delete{opacity:1}.row-delete:hover{color:var(--danger)}.eq{align-items:flex-end;gap:2px;height:14px;display:flex}.eq span{background:var(--copper-bright);width:2.5px;animation:1s ease-in-out infinite eq-bounce}.eq span:first-child{height:40%;animation-delay:-.2s}.eq span:nth-child(2){height:100%;animation-delay:-.6s}.eq span:nth-child(3){height:65%;animation-delay:-.9s}@keyframes eq-bounce{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}.tracklist-empty{color:var(--text-faint);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:6px;display:flex}.empty-title{font-family:var(--font-display);color:var(--text-dim);margin:0;font-size:20px}.empty-sub{margin:0;font-size:13px}@media (width<=900px){.col-album{display:none}.tracklist-row{grid-template-columns:44px 1fr 72px 60px 40px}}@media (width<=640px){.tracklist{padding:16px 12px 28px}.tracklist-row{grid-template-columns:34px 1fr 40px}.col-format,.col-duration,.col-album{display:none}.track-cover{width:30px;height:30px}}:root{--player-h:100px}.player{height:var(--player-h);background:var(--panel);border-top:1px solid var(--line-soft);flex-shrink:0;grid-template-columns:280px 1fr 220px;align-items:center;gap:16px;padding:0 20px;display:grid;position:relative;overflow:hidden}.player--empty{color:var(--text-faint);justify-content:center;align-items:center;gap:12px;font-size:13px;display:flex}.player-waveform{pointer-events:none;opacity:.18;width:100%;height:100%;position:absolute;inset:0}.player-waveform--idle{opacity:.06}.player-now{z-index:1;align-items:center;gap:12px;min-width:0;display:flex;position:relative}.player-cover{background:var(--panel-raised);border-radius:6px;flex-shrink:0;width:52px;height:52px;overflow:hidden}.player-cover img{object-fit:cover;width:100%;height:100%;display:block}.player-disc svg{width:52px;height:52px;display:block}.player-disc.spinning svg{animation:6s linear infinite disc-spin}@keyframes disc-spin{to{transform:rotate(360deg)}}.player-meta{flex-direction:column;gap:1px;min-width:0;display:flex}.player-title{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.player-artist{color:var(--text-faint);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.player-album{color:var(--copper-dim);white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-family:var(--font-mono);overflow:hidden}.player-center{z-index:1;flex-direction:column;align-items:center;gap:8px;width:100%;max-width:580px;margin:0 auto;display:flex;position:relative}.player-controls{align-items:center;gap:14px;display:flex}.ctrl-btn{color:var(--text-dim);border-radius:4px;padding:4px;transition:color .15s;display:flex}.ctrl-btn:hover{color:var(--text)}.ctrl-btn--mode{color:var(--text-faint)}.ctrl-btn--mode.active{color:var(--copper-bright)}.ctrl-btn--main{background:var(--copper);color:#1a1612;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;padding:0;transition:background .15s}.ctrl-btn--main:hover{background:var(--copper-bright);color:#1a1612}.player-seek{align-items:center;gap:10px;width:100%;display:flex}.time{font-family:var(--font-mono);color:var(--text-faint);text-align:center;flex-shrink:0;width:38px;font-size:11px}.seek-bar{appearance:none;background:linear-gradient(to right, var(--copper) var(--pct), var(--line) var(--pct));cursor:pointer;border-radius:2px;flex:1;height:3px}.seek-bar::-webkit-slider-thumb{-webkit-appearance:none;background:var(--copper-bright);cursor:pointer;opacity:0;border-radius:50%;width:11px;height:11px;transition:opacity .1s}.seek-bar:hover::-webkit-slider-thumb{opacity:1}.seek-bar:focus-visible::-webkit-slider-thumb{opacity:1}.seek-bar::-moz-range-thumb{background:var(--copper-bright);border:none;border-radius:50%;width:11px;height:11px}.player-right{z-index:1;justify-content:flex-end;align-items:center;gap:12px;display:flex;position:relative}.player-volume{color:var(--text-faint);align-items:center;gap:6px;display:flex}.seek-bar--vol{flex:none;width:80px}@media (width<=960px){.player{grid-template-columns:200px 1fr 44px}.player-album{display:none}.player-volume .seek-bar--vol{width:60px}}@media (width<=720px){.player{grid-template-rows:auto auto;grid-template-columns:1fr;gap:8px;height:auto;padding:10px 14px 12px}.player-right{display:none}.player-now{justify-content:center}.player-cover{width:40px;height:40px}}.device-picker-wrap{position:relative}.device-dropdown{background:var(--panel-raised);border:1px solid var(--line-soft);z-index:100;border-radius:8px;min-width:220px;padding:6px;position:absolute;bottom:calc(100% + 10px);right:0;box-shadow:0 8px 24px #00000080}.device-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);margin:4px 8px 8px;font-size:10px}.device-option{width:100%;color:var(--text-dim);text-align:left;border-radius:5px;align-items:center;gap:8px;padding:8px 10px;font-size:13px;transition:background .1s,color .1s;display:flex}.device-option span{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.device-option:hover{color:var(--text);background:#ffffff0f}.device-option.selected{color:var(--copper-bright)}.device-option svg:first-child{opacity:.5;flex-shrink:0}.device-option.selected svg:first-child{opacity:1}.queue-panel{background:var(--panel);border-left:1px solid var(--line-soft);flex-direction:column;flex-shrink:0;width:300px;height:100%;display:flex}.queue-header{border-bottom:1px solid var(--line-soft);justify-content:space-between;align-items:center;padding:16px 16px 14px;display:flex}.queue-title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);font-size:11px}.queue-close{color:var(--text-faint);border-radius:4px;padding:4px;transition:color .15s;display:flex}.queue-close:hover{color:var(--text)}.queue-list{flex:1;padding:6px 8px;overflow-y:auto}.queue-empty{text-align:center;color:var(--text-faint);margin:32px auto;font-size:13px}.queue-item{border-radius:var(--radius);cursor:default;grid-template-columns:22px 32px 1fr 24px 24px;align-items:center;gap:8px;padding:6px 8px;transition:background .1s;display:grid}.queue-item:hover{background:var(--panel-raised)}.queue-item.active .queue-track-title{color:var(--copper-bright)}.queue-num{font-family:var(--font-mono);color:var(--text-faint);text-align:right;font-size:11px}.queue-cover{object-fit:cover;border-radius:3px;flex-shrink:0;width:32px;height:32px}.queue-info{flex-direction:column;gap:1px;min-width:0;display:flex}.queue-track-title{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.queue-track-artist{color:var(--text-faint);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.queue-play,.queue-remove{opacity:0;color:var(--text-faint);border-radius:3px;padding:4px;transition:opacity .1s,color .1s;display:flex}.queue-item:hover .queue-play,.queue-item:hover .queue-remove{opacity:1}.queue-play:hover{color:var(--copper-bright)}.queue-remove:hover{color:var(--danger)}@media (width<=960px){.queue-panel{width:260px}}.app-shell{flex-direction:column;height:100vh;display:flex}.app-body{flex:1;min-height:0;display:flex}.app-main{background:linear-gradient(#221d18 0%,#1a1612 220px);flex-direction:column;flex:1;min-width:0;display:flex}.app-status{color:var(--text-faint);margin:40px auto;font-size:14px}.app-status--error{color:var(--danger)}@media (width<=720px){.app-body{flex-direction:column;min-height:0}}
