*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base: #0a0a0a;--bg-elevated: #141414;--bg-highlight: #1c1c1c;--surface: #181818;--surface-hi: #282828;--surface-press: #3e3e3e;--text: #ffffff;--text-sub: #a7a7a7;--text-faint: #535353;--accent: #6366f1;--accent-hi: #818cf8;--accent-press: #4f46e5;--accent-gradient-top: rgba(99,102,241,.25);--sidebar-w: 240px;--player-h: 96px;--r-sm: 4px;--r-md: 8px;--r-lg: 12px;--r-full: 500px;--bg: #141414;--hover: #282828;--border: rgba(255,255,255,.07);--surface2: #222222;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;color-scheme:dark}html,body,#root{height:100%;overflow:hidden}body{background:var(--bg-base);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;cursor:pointer}.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr var(--right-sidebar-w);grid-template-rows:1fr auto auto;height:100vh;overflow:hidden}.sidebar{grid-row:1 / 2;background:#000;padding:16px 8px;display:flex;flex-direction:column;gap:8px;overflow-y:auto;border-right:1px solid rgba(255,255,255,.05);-webkit-user-select:none;user-select:none}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:8px 12px 16px}.logo-icon{color:var(--accent)}.logo-text{font-size:20px;font-weight:700;letter-spacing:-.5px}.sidebar-section{display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:14px;padding:10px 12px;border-radius:var(--r-md);color:var(--text-sub);font-weight:500;font-size:13px;cursor:pointer;background:none;border:none;width:100%;text-align:left;transition:color .1s,background .1s}.nav-item:hover,.nav-item.active{color:var(--text);background:var(--surface-hi)}.playlists-section{flex:1;overflow-y:auto;overflow-x:hidden}.section-header{display:flex;align-items:center;justify-content:space-between;padding:12px 12px 6px}.section-title{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-sub)}.icon-btn{background:none;border:none;color:var(--text-sub);cursor:pointer;padding:4px;border-radius:var(--r-sm);display:flex;align-items:center;transition:color .1s}.icon-btn:hover{color:var(--text)}.playlist-item svg{flex-shrink:0}.create-playlist{padding:4px 12px 8px}.playlist-input{width:100%;background:var(--surface-hi);border:1px solid var(--accent);border-radius:var(--r-sm);color:var(--text);padding:6px 10px;font-size:13px;outline:none}.main-content{overflow-y:auto;background:linear-gradient(180deg,var(--accent-gradient-top) 0%,var(--bg-base) 400px);padding:24px}.page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}.page-header-left{display:flex;align-items:baseline;gap:12px}.page-header h1{font-size:28px;font-weight:700}.track-count{color:var(--text-sub);font-size:13px}.track-table{width:100%}.track-table-header{display:grid;grid-template-columns:48px 1fr 200px 70px;padding:8px 16px;border-bottom:1px solid rgba(255,255,255,.07);color:var(--text-sub);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px;-webkit-user-select:none;user-select:none}.track-row{display:grid;grid-template-columns:48px 1fr 200px 70px;align-items:center;padding:6px 16px;border-radius:var(--r-sm);transition:background .1s}.track-row:hover{background:var(--surface-hi)}.track-row:hover .track-index{display:none}.track-row:hover .play-btn{display:flex!important}.track-row.current{background:#6366f114}.col-num{color:var(--text-sub);font-size:14px;display:flex;align-items:center;justify-content:center;height:40px;position:relative}.play-btn{display:none;align-items:center;justify-content:center;background:none;border:none;color:var(--text);cursor:pointer;position:absolute}.playing-bars{display:flex;align-items:flex-end;gap:2px;height:14px}.playing-bars span{display:block;width:3px;background:var(--accent);border-radius:2px;animation:bar 1.2s ease-in-out infinite}.playing-bars span:nth-child(1){height:8px;animation-delay:0s}.playing-bars span:nth-child(2){height:14px;animation-delay:.2s}.playing-bars span:nth-child(3){height:6px;animation-delay:.4s}@keyframes bar{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}.col-title{display:flex;align-items:center;gap:12px;min-width:0}.track-artwork{width:40px;height:40px;border-radius:var(--r-sm);object-fit:cover;flex-shrink:0}.track-artwork-placeholder{width:40px;height:40px;border-radius:var(--r-sm);background:var(--surface-hi);display:flex;align-items:center;justify-content:center;color:var(--text-faint);flex-shrink:0}.track-meta{display:flex;flex-direction:column;gap:2px;min-width:0}.track-name{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-name.accent{color:var(--accent)}.track-artist{font-size:12px;color:var(--text-sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-album{font-size:13px;color:var(--text-sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-duration{font-size:13px;color:var(--text-sub);text-align:right;font-variant-numeric:tabular-nums}.now-playing{grid-column:1 / -1;background:#0d0d0d;border-top:1px solid rgba(255,255,255,.07);display:grid;grid-template-columns:1fr 2fr 1fr;align-items:center;padding:0 28px;gap:24px;-webkit-user-select:none;user-select:none}.np-track-info{display:flex;align-items:center;gap:12px;min-width:0}.np-artwork{width:56px;height:56px;border-radius:var(--r-sm);object-fit:cover;flex-shrink:0}.np-artwork-placeholder{width:56px;height:56px;background:var(--surface-hi);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:var(--text-faint);flex-shrink:0}.np-meta{display:flex;flex-direction:column;gap:2px;min-width:0}.np-title{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.np-empty-label{color:var(--text-sub)}.np-artist{font-size:12px;color:var(--text-sub);white-space:nowrap}.np-controls{display:flex;flex-direction:column;align-items:center;gap:10px}.np-buttons{display:flex;align-items:center;gap:16px}.control-btn{background:none;border:none;color:var(--text-sub);cursor:pointer;padding:4px;display:flex;align-items:center;border-radius:var(--r-sm);transition:color .1s,transform .1s}.control-btn:hover{color:var(--text)}.control-btn.active{color:var(--accent)}.play-pause-btn{width:36px;height:36px;border-radius:50%;background:var(--text);color:#000;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s,background .1s}.play-pause-btn:hover{transform:scale(1.06);background:#e0e0e0}.np-progress{display:flex;align-items:center;gap:10px;width:100%}.np-time{font-size:11px;color:var(--text-sub);width:36px;text-align:center;font-variant-numeric:tabular-nums}.progress-bar{flex:1;height:5px;background:var(--surface-press);border-radius:3px;cursor:pointer;position:relative;transition:height .15s}.progress-bar:hover{height:8px}.progress-fill{height:100%;background:#ffffff59;border-radius:3px;transition:background .1s}.progress-bar:hover .progress-fill{background:var(--accent)}.progress-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;border-radius:50%;background:var(--text);opacity:0;pointer-events:none;box-shadow:0 1px 4px #0006;transition:opacity .15s}.progress-bar:hover .progress-thumb{opacity:1}.np-volume{display:flex;align-items:center;gap:8px;justify-content:flex-end}.volume-slider{-webkit-appearance:none;width:90px;height:4px;border-radius:2px;background:var(--surface-press);outline:none;cursor:pointer;transition:background .1s}.volume-slider:hover{background:var(--surface-hi)}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--text);cursor:pointer}.search-view{padding-top:8px}.search-header{margin-bottom:24px}.search-input-wrapper{display:flex;align-items:center;gap:10px;background:var(--surface-hi);border-radius:var(--r-full);padding:10px 16px;max-width:500px;color:var(--text-sub);border:2px solid transparent;transition:border-color .15s}.search-input-wrapper:focus-within{border-color:var(--text);color:var(--text)}.search-input{background:none;border:none;color:var(--text);font-size:15px;width:100%;outline:none;font-family:inherit}.search-input::placeholder{color:var(--text-sub)}.playlist-header{display:flex;align-items:flex-end;gap:24px;padding:24px 0 32px;background:linear-gradient(180deg,rgba(99,102,241,.12) 0%,transparent 100%)}.playlist-icon{width:180px;height:180px;background:var(--surface-hi);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--text-sub);flex-shrink:0;box-shadow:0 8px 40px #0009}.playlist-info{display:flex;flex-direction:column;gap:4px}.playlist-type{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text-sub)}.playlist-info h1{font-size:40px;font-weight:900;line-height:1.1}.loading{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-sub)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;gap:10px;color:var(--text-sub);text-align:center}.empty-state h2{color:var(--text);font-size:20px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b8;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--surface);border-radius:var(--r-lg);width:480px;max-width:90vw;box-shadow:0 20px 60px #0009;border:1px solid rgba(255,255,255,.08)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.07)}.modal-header h2{font-size:18px;font-weight:700}.modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:12px}.modal-body p{color:var(--text-sub);font-size:14px;line-height:1.5}.hint{font-size:12px!important;color:var(--text-faint)!important}.input-group{display:flex;align-items:center;gap:10px;background:var(--bg-elevated);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-md);padding:10px 14px;color:var(--text-sub);transition:border-color .15s}.input-group:focus-within{border-color:var(--accent);color:var(--text)}.input-icon{flex-shrink:0}.path-input{background:none;border:none;color:var(--text);font-size:13px;width:100%;outline:none;font-family:monospace}.error-msg{color:#f87171;font-size:13px;background:#f871711a;padding:8px 12px;border-radius:var(--r-sm)}.scan-result{background:#6366f11a;border:1px solid rgba(99,102,241,.2);padding:12px 14px;border-radius:var(--r-md);font-size:13px;color:var(--text-sub)}.scan-result p:first-child{color:var(--text);font-weight:600;margin-bottom:6px}.scan-result ul{padding-left:18px}.scan-result li{margin-bottom:3px}.modal-footer{display:flex;gap:8px;justify-content:flex-end;padding:16px 24px;border-top:1px solid rgba(255,255,255,.07)}.btn-primary{background:var(--accent);color:#fff;border:none;padding:10px 20px;border-radius:var(--r-full);font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .1s,transform .1s}.btn-primary:hover{background:var(--accent-hi)}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--text);border:1px solid rgba(255,255,255,.2);padding:10px 20px;border-radius:var(--r-full);font-size:14px;font-weight:600;cursor:pointer;transition:border-color .1s}.btn-secondary:hover{border-color:#ffffff80}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin .8s linear infinite}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface-press);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-faint)}::selection{background:var(--accent);color:#fff}.library{padding-bottom:24px}.lib-topbar{display:flex;align-items:center;gap:12px;margin-bottom:32px}.lib-upload-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--r-full);background:var(--accent);color:#fff;font-size:13px;font-weight:600;border:none;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s,transform .1s}.lib-upload-btn:hover{background:var(--accent-hi);transform:translateY(-1px)}.lib-upload-btn:active{transform:translateY(0)}.lib-search-wrap{flex:1;position:relative;display:flex;align-items:center}.lib-search-icon{position:absolute;left:13px;color:var(--text-sub);pointer-events:none}.lib-search-input{width:100%;padding:10px 36px 10px 38px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--surface-hi);color:var(--text);font-size:13px;outline:none;transition:border-color .15s,background .15s}.lib-search-input::placeholder{color:var(--text-faint)}.lib-search-input:focus{border-color:var(--accent);background:var(--bg-highlight)}.lib-search-clear{position:absolute;right:10px;background:none;border:none;color:var(--text-sub);cursor:pointer;padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:color .12s}.lib-search-clear:hover{color:var(--text)}.lib-section{margin-bottom:40px}.lib-section-header{display:flex;align-items:baseline;gap:10px;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border)}.lib-section-header h2{font-size:18px;font-weight:700}.lib-section-count{font-size:12px;color:var(--text-sub);background:var(--surface-hi);padding:2px 8px;border-radius:var(--r-full)}.lib-empty-tracks{color:var(--text-sub);font-size:13px;padding:16px 0}.album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:20px;padding-bottom:32px}.album-card{background:none;border:none;cursor:pointer;text-align:left;padding:12px;border-radius:var(--r-md);transition:background .15s}.album-card:hover{background:var(--surface-hi)}.album-cover-wrap{position:relative;width:100%;aspect-ratio:1;border-radius:var(--r-md);overflow:hidden;margin-bottom:10px;box-shadow:0 4px 20px #0006}.album-cover{width:100%;height:100%;object-fit:cover;display:block}.album-cover-placeholder{width:100%;height:100%;background:var(--surface-hi);display:flex;align-items:center;justify-content:center;color:var(--text-faint)}.album-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.album-cover-wrap:hover .album-card-overlay{opacity:1}.album-play-btn{width:44px;height:44px;border-radius:50%;background:var(--accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0006;transform:scale(.9);transition:transform .15s,background .15s}.album-play-btn:hover{transform:scale(1);background:var(--accent-hi)}.album-card-info{display:flex;flex-direction:column;gap:2px}.album-card-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.album-card-artist{font-size:12px;color:var(--text-sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.album-card-year{font-size:11px;color:var(--text-faint)}.back-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-sub);font-size:13px;font-weight:500;cursor:pointer;padding:6px 0;margin-bottom:16px;transition:color .1s}.back-btn:hover{color:var(--text)}.album-detail-header{display:flex;align-items:flex-end;gap:24px;padding-bottom:32px;background:linear-gradient(180deg,rgba(99,102,241,.12) 0%,transparent 100%)}.album-detail-art{flex-shrink:0}.album-detail-cover{width:200px;height:200px;object-fit:cover;border-radius:var(--r-md);box-shadow:0 8px 40px #0009}.album-detail-cover-placeholder{width:200px;height:200px;background:var(--surface-hi);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--text-faint)}.album-detail-info{display:flex;flex-direction:column;gap:6px}.album-detail-info h1{font-size:36px;font-weight:900;line-height:1.1}.album-detail-meta{font-size:13px;color:var(--text-sub)}.album-detail-actions{display:flex;gap:12px;margin-top:8px}.context-menu{background:#2a2a2a;border:1px solid rgba(255,255,255,.1);border-radius:var(--r-md);padding:6px;min-width:190px;box-shadow:0 8px 32px #0009;z-index:9999}.context-track-label{padding:6px 10px 8px;display:flex;flex-direction:column;gap:2px}.context-title{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.context-artist{font-size:12px;color:var(--text-sub)}.context-divider{height:1px;background:#ffffff12;margin:4px 0}.context-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;background:none;border:none;color:var(--text-sub);font-size:13px;font-weight:500;cursor:pointer;border-radius:var(--r-sm);transition:background .1s,color .1s;text-align:left}.context-item:hover{background:var(--surface-press);color:var(--text)}.context-item-indent{padding-left:20px}.context-sub-label{display:block;padding:6px 10px 2px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint)}.context-empty{display:block;padding:6px 10px;font-size:12px;color:var(--text-faint)}.context-playlist-list{display:flex;flex-direction:column}.toasts{position:fixed;bottom:calc(var(--player-h) + 16px);right:16px;display:flex;flex-direction:column;gap:8px;z-index:10000;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--r-md);font-size:13px;font-weight:500;box-shadow:0 4px 16px #0006;animation:toast-in .2s ease;pointer-events:all;max-width:300px}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.toast-success{background:#1a3a2a;border:1px solid #166534;color:#4ade80}.toast-error{background:#3a1a1a;border:1px solid #991b1b;color:#f87171}.toast-info{background:#1a1a3a;border:1px solid #1e3a8a;color:#93c5fd}.toast span{flex:1}.toast-close{background:none;border:none;color:inherit;opacity:.6;cursor:pointer;padding:2px;display:flex;flex-shrink:0}.toast-close:hover{opacity:1}.playlist-item-wrap{position:relative;display:flex;align-items:center}.playlist-item-wrap .playlist-item{flex:1;padding-right:28px}.playlist-menu-btn{position:absolute;right:6px;background:none;border:none;color:var(--text-sub);opacity:0;padding:2px;border-radius:var(--r-sm);display:flex;align-items:center;transition:opacity .15s}.playlist-item-wrap:hover .playlist-menu-btn,.playlist-item-wrap.active .playlist-menu-btn{opacity:1}.playlist-menu-btn:hover{background:var(--surface-hi);color:var(--text)}.playlist-dropdown{position:absolute;left:8px;top:calc(100% + 2px);background:var(--surface-hi);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-md);box-shadow:0 8px 24px #00000080;z-index:9999;min-width:160px;overflow:hidden}.playlist-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:9px 14px;background:none;border:none;color:var(--text);font-size:13px;text-align:left;cursor:pointer}.playlist-dropdown-item:hover{background:var(--surface-press)}.playlist-dropdown-item.danger{color:#f87171}.playlist-dropdown-item.danger:hover{background:#3a1a1a}.modal-lg{max-width:560px}.upload-drop-zone{border:2px dashed var(--surface-press);border-radius:var(--r-lg);padding:40px 24px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;display:flex;flex-direction:column;align-items:center;gap:6px}.upload-drop-zone:hover,.upload-drop-zone.dragging{border-color:var(--accent);background:#6366f10f}.upload-icon{color:var(--accent);margin-bottom:4px}.upload-hint-main{font-size:15px;font-weight:600}.upload-hint-sub{color:var(--text-sub);font-size:13px}.upload-hint-types{color:var(--text-faint);font-size:11px;margin-top:4px}.upload-file-input{display:none}.upload-file-list{margin-top:16px;display:flex;flex-direction:column;gap:4px;max-height:240px;overflow-y:auto}.upload-file-row{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg-elevated);border-radius:var(--r-sm);font-size:12px}.upload-file-icon{color:var(--text-sub);flex-shrink:0}.upload-file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-file-size{color:var(--text-faint);flex-shrink:0}.upload-progress-bar{flex:1;height:3px;background:var(--surface-hi);border-radius:99px;overflow:hidden}.upload-progress-fill{height:100%;background:var(--accent);border-radius:99px;transition:width .2s}.upload-status-ok{color:#4ade80;flex-shrink:0}.upload-status-err{color:#f87171;flex-shrink:0}.upload-remove-btn{background:none;border:none;color:var(--text-faint);cursor:pointer;padding:2px;display:flex;flex-shrink:0}.upload-remove-btn:hover{color:#f87171}.modal-edit{max-width:540px}.edit-track-body{display:flex;gap:20px}.edit-artwork-section{flex-shrink:0}.edit-artwork-preview{width:160px;height:160px;border-radius:var(--r-md);overflow:hidden;cursor:pointer;position:relative;background:var(--surface-hi);display:flex;align-items:center;justify-content:center;color:var(--text-faint)}.edit-artwork-preview img{width:100%;height:100%;object-fit:cover}.edit-artwork-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;opacity:0;transition:opacity .15s;font-size:12px;font-weight:600}.edit-artwork-preview:hover .edit-artwork-overlay{opacity:1}.edit-track-fields{flex:1;display:flex;flex-direction:column;gap:10px}.edit-field{display:flex;flex-direction:column;gap:4px}.edit-field span{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-sub)}.edit-field input{background:var(--bg-elevated);border:1px solid var(--surface-press);border-radius:var(--r-sm);color:var(--text);font-family:inherit;font-size:13px;padding:7px 10px;outline:none;transition:border-color .15s}.edit-field input:focus{border-color:var(--accent)}.edit-field-row{display:flex;gap:10px}.edit-field-row .edit-field{flex:1}.edit-track-footer{display:flex;align-items:center;justify-content:space-between}.edit-track-footer-right{display:flex;gap:8px}.btn-danger{display:flex;align-items:center;gap:6px;padding:8px 14px;background:transparent;border:1px solid #991b1b;color:#f87171;border-radius:var(--r-full);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.btn-danger:hover,.btn-danger.confirming{background:#3a1a1a}.context-item-danger{color:#f87171!important}.context-item-danger:hover{background:#3a1a1a!important}.context-item-danger.confirming{background:#3a1a1a!important;font-weight:600}.playlist-track-table .track-row.dragging{opacity:.4}.playlist-track-table .track-row.drag-over{border-top:2px solid var(--accent)}.col-drag{width:24px;display:flex;align-items:center;justify-content:center;color:var(--text-faint);cursor:grab;flex-shrink:0}.col-drag:active{cursor:grabbing}.drag-handle{opacity:.4}.track-row:hover .drag-handle{opacity:1}.col-remove{width:32px;display:flex;align-items:center;justify-content:flex-end;flex-shrink:0}.track-remove-btn{background:none;border:none;color:var(--text-faint);padding:4px;display:flex;border-radius:var(--r-sm);opacity:0;transition:opacity .15s,color .15s;cursor:pointer}.track-row:hover .track-remove-btn{opacity:1}.track-remove-btn:hover{color:#f87171}.playlist-name-row{display:flex;align-items:center;gap:10px}.playlist-edit-btn{color:var(--text-faint);opacity:0;transition:opacity .15s}.playlist-header:hover .playlist-edit-btn{opacity:1}.playlist-edit-btn:hover{color:var(--text);opacity:1!important}.playlist-play-btn{align-self:center;margin-left:auto;margin-top:0}.album-detail-actions{gap:10px}.auth-page{display:flex;align-items:center;justify-content:center;width:100vw;height:100vh;background:var(--bg-base)}.auth-card{width:380px;background:var(--surface);border:1px solid rgba(255,255,255,.06);border-radius:var(--r-lg);padding:36px 32px 28px;display:flex;flex-direction:column;gap:24px}.auth-logo{display:flex;flex-direction:column;align-items:center;gap:6px}.auth-title{font-size:22px;font-weight:700;letter-spacing:-.3px}.auth-subtitle{font-size:13px;color:var(--text-sub)}.auth-tabs{display:flex;background:var(--bg-elevated);border-radius:var(--r-sm);padding:3px;gap:3px}.auth-tab{flex:1;padding:7px 0;border:none;background:transparent;color:var(--text-sub);font-size:13px;font-weight:500;border-radius:3px;transition:all .15s}.auth-tab.active{background:var(--surface-hi);color:var(--text)}.auth-tab:hover:not(.active){color:var(--text)}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-field label{font-size:12px;font-weight:500;color:var(--text-sub);text-transform:uppercase;letter-spacing:.5px}.auth-field input{width:100%;padding:10px 12px;background:var(--bg-elevated);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-sm);color:var(--text);font-size:14px;font-family:inherit;transition:border-color .15s;outline:none}.auth-field input:focus{border-color:var(--accent)}.auth-field input::placeholder{color:var(--text-faint)}.auth-error{font-size:13px;color:#f87171;background:#f871711a;border:1px solid rgba(248,113,113,.2);border-radius:var(--r-sm);padding:8px 12px}.auth-submit{width:100%;padding:10px;font-size:14px;font-weight:600;margin-top:4px}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-switch{text-align:center;font-size:13px;color:var(--text-sub)}.auth-switch-btn{background:none;border:none;color:var(--accent-hi);font-size:13px;font-family:inherit;cursor:pointer;padding:0}.auth-switch-btn:hover{text-decoration:underline}.sidebar-user{display:flex;align-items:center;gap:10px;padding:10px 12px;margin:8px 8px 0;border-radius:var(--r-md);background:var(--bg-elevated);border:1px solid rgba(255,255,255,.05)}.sidebar-user-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}.sidebar-user-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.sidebar-user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{font-size:11px;color:var(--text-sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-logout-btn{background:none;border:none;color:var(--text-faint);padding:4px;border-radius:var(--r-sm);display:flex;align-items:center;flex-shrink:0;transition:color .15s}.sidebar-logout-btn:hover{color:#f87171}:root{--right-sidebar-w: 260px}.right-panel{grid-column:3;grid-row:1;background:var(--bg-elevated);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;padding:16px 12px;gap:20px}.rp-section{display:flex;flex-direction:column;gap:8px}.rp-section-title{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);padding:0 4px}.rp-profile{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 8px;background:var(--bg-highlight);border-radius:var(--r-md)}.rp-avatar-wrap{position:relative}.rp-owner-crown{position:absolute;top:-6px;right:-6px;font-size:14px}.rp-profile-name{font-size:14px;font-weight:700;color:var(--text-primary);text-align:center}.rp-profile-username{font-size:11px;color:var(--text-sub);text-align:center}.rp-profile-bio{font-size:11px;color:var(--text-faint);text-align:center;line-height:1.4}.rp-profile-actions{display:flex;flex-direction:column;gap:6px;width:100%}.rp-action-row{display:flex;gap:6px}.rp-action-messages{width:100%;justify-content:center;background:#6366f11a!important;border-color:#6366f140!important;color:var(--accent-hi)!important}.rp-action-messages:hover{background:#6366f12e!important}.rp-profile-actions button{flex:1;padding:5px 10px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-base);color:var(--text-secondary);font-size:11px;cursor:pointer;transition:background .15s}.rp-profile-actions button:hover{background:var(--bg-highlight)}.rp-request-item{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--bg-highlight);border-radius:var(--r-sm)}.rp-request-name{flex:1;font-size:12px;color:var(--text-primary)}.rp-request-actions{display:flex;gap:4px}.rp-request-actions button{padding:3px 8px;border-radius:var(--r-sm);border:none;font-size:11px;cursor:pointer}.rp-btn-accept{background:var(--accent);color:#fff}.rp-btn-decline{background:var(--bg-elevated);color:var(--text-faint)}.rp-btn-decline:hover{color:#f87171}.rp-friend-item{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:var(--r-sm);cursor:pointer;transition:background .12s}.rp-friend-item:hover{background:var(--bg-highlight)}.rp-friend-name{flex:1;font-size:12px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rp-jam-item{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--bg-highlight);border-radius:var(--r-sm)}.rp-jam-name{flex:1;font-size:12px;font-weight:600;color:var(--text-primary)}.rp-jam-host{font-size:10px;color:var(--text-sub)}.rp-empty{font-size:11px;color:var(--text-faint);padding:4px 8px}.avatar-img{border-radius:50%;object-fit:cover;flex-shrink:0}.avatar-placeholder{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;flex-shrink:0;font-size:.45em;line-height:1}.jam-bar{grid-column:1 / -1;display:flex;align-items:center;gap:12px;padding:6px 20px;background:color-mix(in srgb,var(--accent) 20%,var(--bg-elevated));border-top:1px solid color-mix(in srgb,var(--accent) 40%,transparent);font-size:12px}.jam-bar-icon{color:var(--accent)}.jam-bar-name{font-weight:700;color:var(--text-primary)}.jam-bar-host{color:var(--text-sub)}.jam-bar-participants{display:flex;gap:-4px;margin-left:auto}.jam-bar-participants .avatar-placeholder,.jam-bar-participants .avatar-img{margin-left:-4px;border:2px solid var(--bg-elevated)}.jam-bar-leave{margin-left:12px;padding:4px 10px;border-radius:var(--r-sm);border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:11px;cursor:pointer;transition:background .15s}.jam-bar-leave:hover{background:#f8717126;color:#f87171}.messages-view{display:grid;grid-template-columns:280px 1fr;height:100%;overflow:hidden;border-radius:var(--r-lg);background:var(--surface)}.conv-list{border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;background:var(--surface)}.conv-list-header{padding:20px 16px 14px;font-size:15px;font-weight:700;letter-spacing:.01em;color:var(--text);border-bottom:1px solid var(--border);flex-shrink:0}.conv-list-scroll{flex:1;overflow-y:auto;padding:6px 0}.conv-row{display:flex;align-items:center;gap:11px;padding:9px 14px;width:100%;border:none;background:none;cursor:pointer;text-align:left;transition:background .12s;color:var(--text);border-radius:0}.conv-row:hover{background:var(--surface-hi)}.conv-row.active{background:#6366f121}.conv-row-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.conv-row-name{font-size:13px;font-weight:600;color:var(--text)}.conv-row-last{font-size:12px;color:var(--text-sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conv-unread-badge{background:var(--accent);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px;flex-shrink:0}.conv-empty{padding:40px 20px;font-size:13px;color:var(--text-sub);line-height:1.7;text-align:center}.conv-thread{display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--bg-elevated)}.conv-thread-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-faint);font-size:14px}.conv-thread-header{padding:13px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:11px;background:var(--surface);flex-shrink:0;font-size:14px;font-weight:600;color:var(--text);min-height:56px}.conv-messages{flex:1;overflow-y:auto;padding:20px 20px 12px;display:flex;flex-direction:column;gap:6px}.conv-input-row{display:flex;align-items:center;gap:10px;padding:12px 16px 16px;border-top:1px solid var(--border);background:var(--surface);flex-shrink:0}.conv-input{flex:1;padding:10px 16px;border-radius:var(--r-full);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);font-size:13px;outline:none;transition:border-color .15s,background .15s}.conv-input:focus{border-color:var(--accent);background:var(--bg-highlight)}.conv-send-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s,opacity .15s}.conv-send-btn:hover{background:var(--accent-hi)}.conv-send-btn:disabled{opacity:.3;cursor:not-allowed}.msg-row{display:flex;align-items:flex-end;gap:8px}.msg-row.me{flex-direction:row-reverse}.msg-row+.msg-row{margin-top:2px}.msg-bubble-wrap{display:flex;flex-direction:column;gap:3px;max-width:65%}.msg-row.me .msg-bubble-wrap{align-items:flex-end}.msg-bubble{padding:9px 14px;font-size:13px;line-height:1.5;background:var(--surface-hi);color:var(--text);word-break:break-word;border-radius:18px 18px 18px 4px}.msg-row.me .msg-bubble{background:var(--accent);color:#fff;border-bottom-left-radius:18px;border-bottom-right-radius:4px}.msg-time{font-size:10px;color:var(--text-faint);padding:0 4px;align-self:flex-end}.msg-row.me .msg-time{align-self:flex-start}.msg-track-card{display:flex;align-items:center;gap:10px;padding:9px 11px;background:var(--surface);border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:background .12s;width:240px;max-width:100%}.msg-track-card:hover{background:var(--surface-hi)}.msg-track-card.loading{color:var(--text-sub);font-size:12px;min-height:56px}.msg-track-art{width:40px;height:40px;border-radius:6px;object-fit:cover;flex-shrink:0}.msg-track-art-placeholder{width:40px;height:40px;border-radius:6px;background:var(--bg-highlight);display:flex;align-items:center;justify-content:center;color:var(--text-faint);flex-shrink:0}.msg-track-info{flex:1;min-width:0}.msg-track-title{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.msg-track-artist{font-size:11px;color:var(--text-sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;margin-top:2px}.msg-track-play{width:28px;height:28px;border-radius:50%;background:var(--accent);border:none;color:#fff;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s}.msg-track-play:hover{background:var(--accent-hi)}.ep-avatar-section{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 0 16px}.ep-avatar-btn{padding:5px 12px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-highlight);color:var(--text-secondary);font-size:12px;cursor:pointer}.ep-avatar-btn:hover{background:var(--bg-elevated)}.ep-field{display:flex;flex-direction:column;gap:4px}.ep-label{font-size:11px;color:var(--text-sub);font-weight:600;text-transform:uppercase;letter-spacing:.06em}.ep-input{padding:8px 10px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-highlight);color:var(--text-primary);font-size:13px;outline:none}.ep-input:focus{border-color:var(--accent)}.ep-textarea{resize:vertical;min-height:64px}.ep-accent-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.ep-accent-swatch{width:24px;height:24px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s}.ep-accent-swatch:hover{transform:scale(1.15)}.ep-accent-swatch.selected{border-color:var(--text-primary)}.ep-accent-custom{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);cursor:pointer;padding:0;background:none}.us-search-wrap{position:relative;margin-bottom:8px}.us-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-faint);pointer-events:none}.us-search-input{width:100%;padding:8px 10px 8px 32px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-highlight);color:var(--text-primary);font-size:13px;outline:none}.us-search-input:focus{border-color:var(--accent)}.us-results{display:flex;flex-direction:column;gap:4px;max-height:340px;overflow-y:auto}.us-user-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-sm);border:none;background:transparent;cursor:pointer;width:100%;text-align:left;transition:background .12s}.us-user-row:hover{background:var(--bg-highlight)}.us-user-info{flex:1;min-width:0}.us-user-name{display:block;font-size:13px;font-weight:600;color:var(--text-primary)}.us-user-sub{display:block;font-size:11px;color:var(--text-sub)}.us-user-action{padding:4px 10px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-elevated);font-size:11px;cursor:pointer;color:var(--text-secondary);white-space:nowrap;transition:background .12s}.us-user-action:hover{background:var(--bg-highlight)}.us-user-action.sent{color:var(--text-faint);cursor:default}.us-user-action.friends{color:var(--accent);cursor:default}.us-empty{font-size:12px;color:var(--text-faint);padding:8px;text-align:center}.share-content-label{font-size:13px;font-weight:600;color:var(--text-primary);padding:6px 10px;background:var(--bg-highlight);border-radius:var(--r-sm);margin-bottom:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.share-compose{display:flex;flex-direction:column;gap:10px}.share-to-row{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg-highlight);border-radius:var(--r-sm);font-size:13px;color:var(--text-primary)}.share-to-label{color:var(--text-sub)}.share-to-clear{margin-left:auto;background:none;border:none;color:var(--text-faint);cursor:pointer;display:flex;align-items:center}.share-to-clear:hover{color:#f87171}.share-message-input{width:100%;padding:8px 10px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-highlight);color:var(--text-primary);font-size:13px;outline:none;resize:vertical}.share-message-input:focus{border-color:var(--accent)}.rp-profile-top{display:flex;align-items:center;gap:10px;width:100%}.rp-avatar-img{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0}.rp-avatar-placeholder{width:44px;height:44px;border-radius:50%;background:var(--bg-highlight);display:flex;align-items:center;justify-content:center;color:var(--text-faint);flex-shrink:0}.rp-profile-info{flex:1;min-width:0}.rp-display-name{display:block;font-size:13px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rp-username{display:block;font-size:11px;color:var(--text-sub)}.rp-bio{font-size:11px;color:var(--text-faint);line-height:1.4;width:100%}.rp-action-btn{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--r-sm);border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:11px;cursor:pointer;flex:1;justify-content:center;transition:background .12s}.rp-action-btn:hover{background:var(--bg-highlight)}.rp-action-btn.danger:hover{color:#f87171}.rp-badge{background:var(--accent);color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;padding:0 3px;margin-left:5px}.rp-request-row{display:flex;align-items:center;gap:6px;padding:5px 6px;border-radius:var(--r-sm);background:var(--bg-highlight)}.rp-request-name{flex:1;font-size:12px;color:var(--text-primary);min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rp-icon-btn{width:24px;height:24px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.rp-icon-btn.accept{background:var(--accent);color:#fff}.rp-icon-btn.decline{background:var(--bg-elevated);color:var(--text-faint)}.rp-icon-btn.decline:hover{color:#f87171}.rp-section-header{display:flex;align-items:center;justify-content:space-between}.rp-create-jam-btn{width:20px;height:20px;border-radius:50%;border:1px solid var(--border);background:transparent;color:var(--text-sub);font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;line-height:1}.rp-create-jam-btn:hover{background:var(--bg-highlight);color:var(--text-primary)}.rp-add-friend-btn{width:24px;height:24px;border-radius:50%;border:none;background:var(--surface-hi);color:var(--text-sub);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .12s,color .12s;flex-shrink:0}.rp-add-friend-btn:hover{background:var(--accent);color:#fff}.rp-jam-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--r-sm);border:none;background:transparent;width:100%;text-align:left;cursor:pointer;transition:background .12s}.rp-jam-row:hover,.rp-jam-row.active{background:color-mix(in srgb,var(--accent) 15%,transparent)}.rp-jam-icon{color:var(--accent);display:flex}.rp-jam-info{flex:1;min-width:0}.rp-jam-name{display:block;font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rp-jam-host{display:block;font-size:10px;color:var(--text-sub)}.rp-jam-count{font-size:11px;color:var(--text-faint);display:flex;align-items:center;gap:2px}.rp-section-grow{flex:1}.rp-share-row{display:flex;align-items:flex-start;gap:8px;padding:7px 6px;border-radius:var(--r-sm);transition:background .12s}.rp-share-row:hover{background:var(--bg-highlight)}.rp-share-icon{color:var(--accent);flex-shrink:0;margin-top:2px}.rp-share-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.rp-share-label{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rp-share-from{font-size:10px;color:var(--text-sub)}.rp-share-message{font-size:11px;color:var(--text-faint);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rp-friend-row{display:flex;align-items:center;gap:2px;border-radius:var(--r-sm);transition:background .12s}.rp-friend-row:hover{background:var(--bg-highlight)}.rp-friend-main{display:flex;align-items:center;gap:8px;flex:1;min-width:0;padding:5px 6px;border:none;background:transparent;text-align:left;cursor:pointer;border-radius:var(--r-sm)}.rp-friend-info{flex:1;min-width:0}.rp-friend-name{display:flex;align-items:center;gap:3px;font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rp-friend-sub{display:block;font-size:10px;color:var(--text-sub)}.rp-crown-inline{color:#fbbf24;flex-shrink:0}.rp-friend-msg-icon{color:var(--text-faint);flex-shrink:0}.rp-friend-row:hover .rp-friend-msg-icon{color:var(--accent)}.rp-icon-btn.remove-friend{opacity:0;pointer-events:none;color:var(--text-faint);margin-right:4px;transition:opacity .12s,color .12s}.rp-friend-row:hover .rp-icon-btn.remove-friend{opacity:1;pointer-events:auto}.rp-icon-btn.remove-friend:hover{color:#ef4444}.ep-body{display:flex;flex-direction:column;gap:16px}.ep-avatar-wrap{position:relative;width:80px;height:80px;border-radius:50%;cursor:pointer;overflow:hidden}.ep-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.ep-avatar-placeholder{width:100%;height:100%;border-radius:50%;background:var(--bg-highlight);display:flex;align-items:center;justify-content:center;color:var(--text-faint)}.ep-avatar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:#00000080;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;opacity:0;font-size:10px;color:#fff;transition:opacity .15s}.ep-avatar-wrap:hover .ep-avatar-overlay{opacity:1}.ep-fields{display:flex;flex-direction:column;gap:12px}.ep-color-swatch{width:24px;height:24px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s}.ep-color-swatch:hover{transform:scale(1.15)}.ep-color-swatch.selected{border-color:var(--text-primary)}.ep-color-custom{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);cursor:pointer;padding:0;background:none}.edit-field-uploader{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-faint);padding:4px 0 8px;border-bottom:1px solid var(--border);margin-bottom:4px}.edit-field-uploader strong{color:var(--text-sub)}.notif-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0}.sidebar-nav-item{position:relative}.sidebar-nav-badge{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:var(--accent);color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px}.btn-danger{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:6px;border:none;font-size:13px;font-weight:500;cursor:pointer;background:#ef444426;color:#f87171;transition:background .15s}.btn-danger:hover{background:#ef44444d}.btn-danger.confirming{background:#ef44444d;color:#fca5a5}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.album-delete-warning{margin-top:8px;font-size:12px;color:#f87171;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.album-delete-cancel{background:none;border:none;color:var(--text-sub);font-size:12px;cursor:pointer;text-decoration:underline;padding:0}.album-delete-cancel:hover{color:var(--text)}.mtm-modal{max-width:480px}.mtm-body{padding:16px 20px;display:flex;flex-direction:column;gap:14px}.mtm-track-label{font-size:13px;color:var(--text-sub)}.mtm-track-label strong{color:var(--text)}.mtm-track-sub{display:block;margin-top:2px;font-size:12px}.mtm-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);padding-bottom:0}.mtm-tab{background:none;border:none;border-bottom:2px solid transparent;padding:6px 12px;font-size:13px;color:var(--text-sub);cursor:pointer;margin-bottom:-1px;transition:color .15s,border-color .15s}.mtm-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.mtm-tab:hover:not(.active){color:var(--text)}.mtm-loading,.mtm-empty{font-size:13px;color:var(--text-sub);padding:12px 0;text-align:center}.mtm-album-list{display:flex;flex-direction:column;gap:2px;max-height:260px;overflow-y:auto}.mtm-album-row{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:6px;border:none;background:none;cursor:pointer;text-align:left;transition:background .12s;color:var(--text)}.mtm-album-row:hover{background:var(--hover)}.mtm-album-row.selected{background:rgba(var(--accent-rgb, 99,102,241),.15)}.mtm-album-art{width:36px;height:36px;border-radius:4px;object-fit:cover;flex-shrink:0}.mtm-album-art-placeholder{width:36px;height:36px;border-radius:4px;background:var(--surface2);display:flex;align-items:center;justify-content:center;color:var(--text-sub);flex-shrink:0}.mtm-album-info{display:flex;flex-direction:column;min-width:0}.mtm-album-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mtm-album-artist{font-size:11px;color:var(--text-sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mtm-custom-fields{display:flex;flex-direction:column;gap:12px}
