: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:40vh}}.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-upload{background:var(--panel-raised);border:1px solid var(--line);border-radius:var(--radius);color:var(--text);align-items:center;gap:8px;margin:0 4px 22px;padding:10px 14px;font-size:13px;font-weight:600;transition:border-color .15s,color .15s;display:flex}.sidebar-upload:hover{border-color:var(--copper);color:var(--copper-bright)}.sidebar-upload .plus{color:var(--copper);font-size:16px;line-height:1}.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);margin:16px 12px 6px;font-size:10px}.sidebar-label:first-child{margin-top:0}.sidebar-item{border-radius:var(--radius);color:var(--text-dim);text-align:left;justify-content:space-between;align-items:center;gap:8px;padding:9px 12px;font-size:14px;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 1fr 90px 90px 44px;align-items:center;gap:12px;padding:9px 10px;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{color:var(--copper-bright)}.col-index{width:24px;color:var(--text-faint);font-family:var(--font-mono);justify-content:center;align-items:center;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{flex-direction:column;gap:2px;min-width:0;display:flex}.track-title{white-space:nowrap;text-overflow:ellipsis;font-size:14.5px;font-weight:500;overflow:hidden}.tracklist-row.active .track-title{color:var(--copper-bright)}.track-artist{color:var(--text-faint);white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;overflow:hidden}.col-format,.col-size{font-family:var(--font-mono);color:var(--text-faint);font-size:12px}.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:12px;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<=720px){.tracklist{padding:20px 16px 30px}.tracklist-row{grid-template-columns:34px 1fr 44px}.col-format,.col-size{display:none}}.player{height:var(--player-h);background:var(--panel);border-top:1px solid var(--line-soft);flex-shrink:0;grid-template-columns:280px 1fr 200px;align-items:center;gap:20px;padding:0 20px;display:grid}.player--empty{color:var(--text-faint);justify-content:center;align-items:center;font-size:13px;display:flex}.player-now{align-items:center;gap:14px;min-width:0;display:flex}.player-disc svg{filter:drop-shadow(0 4px 10px #0006);width:46px;height:46px;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:2px;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:12.5px;overflow:hidden}.player-center{flex-direction:column;align-items:center;gap:8px;width:100%;max-width:560px;margin:0 auto;display:flex}.player-controls{align-items:center;gap:18px;display:flex}.ctrl-btn{color:var(--text-dim);padding:4px;transition:color .15s;display:flex}.ctrl-btn:hover{color:var(--text)}.ctrl-btn--main{background:var(--copper);color:#1a1612;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px}.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:4px}.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-volume{width:140px;color:var(--text-faint);justify-self:end;align-items:center;gap:8px;display:flex}.seek-bar--vol{flex:none;width:90px}@media (width<=880px){.player{grid-template-rows:auto auto;grid-template-columns:1fr;gap:8px;height:auto;padding:10px 14px}.player-volume{display:none}.player-now{justify-content:center}}.upload-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;background:#0a080699;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.upload-modal{background:var(--panel);border:1px solid var(--line);border-radius:10px;flex-direction:column;gap:16px;width:480px;max-width:100%;max-height:85vh;padding:22px;display:flex}.upload-modal-head{justify-content:space-between;align-items:center;display:flex}.upload-modal-head h2{font-family:var(--font-display);margin:0;font-size:20px;font-weight:600}.upload-close{color:var(--text-faint);padding:4px 8px;font-size:22px;line-height:1}.upload-close:hover{color:var(--text)}.upload-dropzone{border:1.5px dashed var(--line);border-radius:var(--radius);text-align:center;cursor:pointer;padding:32px 16px;transition:border-color .15s,background .15s}.upload-dropzone:hover,.upload-dropzone.drag{border-color:var(--copper);background:var(--panel-raised)}.dz-title{margin:0 0 4px;font-size:14px;font-weight:500}.dz-sub{color:var(--text-faint);margin:0;font-size:12px}.upload-list{flex-direction:column;gap:10px;max-height:220px;display:flex;overflow-y:auto}.upload-item{grid-template-columns:1fr 80px 50px;align-items:center;gap:10px;font-size:12.5px;display:grid}.ui-name{white-space:nowrap;text-overflow:ellipsis;color:var(--text-dim);overflow:hidden}.ui-bar{background:var(--line-soft);border-radius:2px;height:4px;overflow:hidden}.ui-fill{background:var(--copper);height:100%;transition:width .15s}.ui-fill.done{background:var(--copper-bright)}.ui-fill.error{background:var(--danger)}.ui-status{font-family:var(--font-mono);color:var(--text-faint);text-align:right;font-size:11px}.upload-actions{justify-content:flex-end;gap:10px;display:flex}.upload-cancel{color:var(--text-dim);border-radius:var(--radius);padding:9px 16px;font-size:13px}.upload-cancel:hover{color:var(--text)}.upload-start{background:var(--copper);color:#1a1612;border-radius:var(--radius);padding:9px 16px;font-size:13px;font-weight:600}.upload-start:hover:not(:disabled){background:var(--copper-bright)}.upload-start:disabled{opacity:.5;cursor:default}.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}}
