:root{--bg: #0a0a0a;--bg-card: #161616;--bg-hover: #1e1e1e;--bg-player: #111111;--text: #e8e8e8;--text-sub: #888888;--accent: #4f9eff;--accent-dim: #2a5a9e;--fav-color: #ff4f6d;--radius: 8px;--player-height: 72px;--header-height: 56px}*{margin:0;padding:0;box-sizing:border-box}button:focus:not(:focus-visible),a:focus:not(:focus-visible){outline:none}button,a{-webkit-tap-highlight-color:transparent}html,body{height:100%;min-width:290px;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;-webkit-font-smoothing:antialiased;overflow:hidden;overscroll-behavior:none;-webkit-user-select:none;user-select:none;touch-action:pan-x pan-y}input,textarea,[contenteditable]{-webkit-user-select:text;user-select:text}.hidden{display:none!important}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sub{color:var(--text-sub);font-size:.85rem}#bg-blur{position:fixed;top:-60px;right:-60px;bottom:-60px;left:-60px;background-size:cover;background-position:center;filter:blur(80px) saturate(1.6) brightness(1.1);opacity:0;transition:opacity 1.5s ease;z-index:0;pointer-events:none}#bg-blur:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#0a0a0a73}#app{position:relative;z-index:1;height:100%}#header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:#0a0a0ad9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;padding:0 20px;z-index:100}.logo{font-size:1.3rem;font-weight:700;letter-spacing:-.02em;color:var(--text);text-decoration:none}#search-btn{color:var(--text-sub);transition:color .2s}#search-btn:hover{color:var(--text)}.header-actions{display:flex;align-items:center;gap:12px}.login-btn{color:var(--text);text-decoration:none;font-size:.85rem;padding:6px 16px;border-radius:20px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);transition:background .2s,border-color .2s;white-space:nowrap}.login-btn:hover{background:#ffffff24;border-color:#fff3}.user-menu{position:relative}.user-avatar{width:32px;height:32px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:border-color .2s}.user-avatar:hover{border-color:var(--accent)}.user-dropdown{position:absolute;top:42px;right:0;background:#1a1a1a;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:12px 16px;min-width:200px;box-shadow:0 8px 32px #00000080;z-index:200}.user-dropdown-name{font-weight:600;font-size:.9rem;margin-bottom:2px}.user-dropdown-email{color:var(--text-sub);font-size:.8rem;margin-bottom:8px}.user-dropdown-badge{display:inline-block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);background:#4f9eff1f;padding:2px 8px;border-radius:4px;margin-bottom:8px}.user-dropdown-link{display:block;color:var(--accent);text-decoration:none;font-size:.85rem;padding:6px 0;transition:color .2s}.user-dropdown-link:hover{color:#fff}.toggle-switch{width:36px;height:20px;border-radius:10px;background:#ffffff26;position:relative;transition:background .2s;flex-shrink:0}.toggle-switch.on{background:var(--accent)}.toggle-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s}.toggle-switch.on .toggle-knob{transform:translate(16px)}.user-dropdown-logout{display:block;color:var(--text-sub);text-decoration:none;font-size:.85rem;padding-top:8px;border-top:1px solid rgba(255,255,255,.06);transition:color .2s}.user-dropdown-logout:hover{color:var(--text)}.view-mode-section{padding-top:8px;margin-top:4px;border-top:1px solid rgba(255,255,255,.06)}.view-mode-label{font-size:.7rem;color:var(--text-sub);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.view-mode-buttons{display:flex;gap:4px}.view-mode-btn{flex:1;padding:4px 0;font-size:.75rem;text-align:center;border:1px solid rgba(255,255,255,.1);border-radius:4px;background:transparent;color:var(--text-sub);cursor:pointer;transition:all .2s}.view-mode-btn:hover{background:#ffffff0d;color:var(--text)}.view-mode-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.view-mode-indicator{position:absolute;bottom:-2px;right:-2px;font-size:.55rem;background:var(--accent);color:#fff;padding:1px 4px;border-radius:6px;line-height:1.2;pointer-events:none;white-space:nowrap}#main{position:fixed;top:var(--header-height);left:0;right:0;bottom:0;overflow-y:auto;padding:24px 20px 40px;scroll-behavior:smooth}#main h2{font-size:1.2rem;font-weight:600;margin-bottom:16px;margin-top:8px}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-bottom:32px}.browse-subheading{font-size:1.25rem;font-weight:600;color:#fff;margin:8px 0 16px}.card{background:#ffffff0a;border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:background .2s,transform .15s}.card:hover{background:#ffffff14;transform:translateY(-2px)}.card:active{transform:translateY(0)}.card img{width:100%;aspect-ratio:1;object-fit:cover;display:block;background:#1a1a1a}.card-info{padding:10px 12px}.card-title{font-size:.9rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;gap:4px}.card-fav{color:var(--fav-color);font-size:.75rem;flex-shrink:0}.card-sub{font-size:.78rem;color:var(--text-sub);margin-top:2px}.card.playing{outline:2px solid var(--accent);outline-offset:-2px}.card.playing .card-title{color:var(--accent)}.empty-state{color:var(--text-sub);text-align:center;padding:40px 20px;grid-column:1 / -1}.btn-back{background:none;border:none;color:var(--text-sub);font-size:.95rem;cursor:pointer;padding:4px 0;margin-bottom:16px}.btn-back:hover{color:var(--text)}#album-header{display:flex;gap:20px;margin-bottom:24px;align-items:flex-end}#album-header img,.album-no-cover{width:180px;height:180px;border-radius:var(--radius);object-fit:cover;background:#1a1a1a;flex-shrink:0}.album-meta h2{font-size:1.6rem;margin-bottom:4px}.liked-cover{width:100%;aspect-ratio:1;border-radius:var(--radius);background:linear-gradient(135deg,#4f46e5,#7c3aed,#a855f7);display:flex;align-items:center;justify-content:center}.liked-icon{font-size:2.5rem;color:#fff}.liked-cover-lg{width:180px;height:180px;border-radius:var(--radius);background:linear-gradient(135deg,#4f46e5,#7c3aed,#a855f7);display:flex;align-items:center;justify-content:center;flex-shrink:0}.liked-icon-lg{font-size:4rem;color:#fff}.playlist-cover{width:100%;aspect-ratio:1;border-radius:var(--radius);background:linear-gradient(135deg,#1a6b4a,#2d9b6e,#3ec98b);display:flex;align-items:center;justify-content:center}.playlist-icon{font-size:2.5rem;color:#fff}.playlist-cover-lg{width:180px;height:180px;border-radius:var(--radius);background:linear-gradient(135deg,#1a6b4a,#2d9b6e,#3ec98b);display:flex;align-items:center;justify-content:center;flex-shrink:0}.playlist-icon-lg{font-size:4rem;color:#fff}.new-playlist-cover{width:100%;aspect-ratio:1;border-radius:var(--radius);background:#ffffff0f;border:2px dashed rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center}.new-playlist-icon{font-size:3rem;color:var(--text-sub)}.all-songs-cover{width:100%;aspect-ratio:1;border-radius:var(--radius);background:linear-gradient(135deg,#1e3a5f,#2563eb,#60a5fa);display:flex;align-items:center;justify-content:center}.all-songs-icon{font-size:2.5rem;color:#fff}.all-songs-cover-lg{width:180px;height:180px;border-radius:var(--radius);background:linear-gradient(135deg,#1e3a5f,#2563eb,#60a5fa);display:flex;align-items:center;justify-content:center;flex-shrink:0}.all-songs-icon-lg{font-size:4rem;color:#fff}.archived-songs-cover{width:100%;aspect-ratio:1;border-radius:var(--radius);background:linear-gradient(135deg,#4a3728,#78716c,#a8a29e);display:flex;align-items:center;justify-content:center}.archived-songs-icon{font-size:2.5rem;color:#fff}.archived-songs-cover-lg{width:180px;height:180px;border-radius:var(--radius);background:linear-gradient(135deg,#4a3728,#78716c,#a8a29e);display:flex;align-items:center;justify-content:center;flex-shrink:0}.archived-songs-icon-lg{font-size:4rem;color:#fff}.view-toggle{display:flex;gap:4px;margin-left:auto}.view-toggle-btn{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:var(--text-sub);padding:6px 8px;border-radius:6px;cursor:pointer;display:flex;align-items:center;transition:background .2s,color .2s}.view-toggle-btn:hover{background:#ffffff1a}.view-toggle-btn.active{background:#ffffff1f;color:var(--text);border-color:var(--accent)}.search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:var(--bg);display:flex;flex-direction:column;transition:opacity .2s,visibility .2s}.search-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}.search-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;padding-top:max(8px,env(safe-area-inset-top,0px));border-bottom:1px solid rgba(255,255,255,.06);background:#0a0a0af2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.search-bar #search-input{flex:1;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:var(--text);padding:10px 16px;border-radius:20px;font-size:1rem;outline:none;transition:border-color .2s,background .2s}.search-bar #search-input:focus{border-color:var(--accent);background:#ffffff1a}.search-bar #search-input::placeholder{color:#555}.search-results{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:8px 0}.search-result-item{display:flex;align-items:center;gap:12px;padding:8px 16px;cursor:pointer;transition:background .15s}.search-result-item:hover,.search-result-item:active{background:#ffffff0f}.search-result-item img{width:48px;height:48px;border-radius:4px;object-fit:cover;background:#1a1a1a;flex-shrink:0}.search-result-item .no-cover-sm{width:48px;height:48px;border-radius:4px;background:#1a1a1a;display:flex;align-items:center;justify-content:center;color:var(--text-sub);font-size:1.2rem;flex-shrink:0}.search-result-info{flex:1;min-width:0}.search-result-title{font-size:.95rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-result-sub{font-size:.8rem;color:var(--text-sub);margin-top:2px}.search-empty{text-align:center;color:var(--text-sub);padding:60px 20px;font-size:.95rem}.track-list-covers .track-item{display:flex;align-items:center;gap:12px;padding:8px 0}.track-list-covers .track-thumb{width:44px;height:44px;border-radius:4px;object-fit:cover;background:#1a1a1a;flex-shrink:0}.track-list-covers .track-thumb-none{width:44px;height:44px;border-radius:4px;background:#1a1a1a;display:flex;align-items:center;justify-content:center;color:var(--text-sub);font-size:1rem;flex-shrink:0}.track-list-covers .track-info{flex:1;min-width:0}.track-list-covers .track-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.95rem}.track-list-covers .track-item.playing .track-title{color:var(--accent)}.track-remove{background:none;border:none;color:var(--text-sub);font-size:1.2rem;cursor:pointer;padding:0 4px;line-height:1;opacity:0;transition:opacity .15s}.track-item:hover .track-remove{opacity:1}.pl-screen-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:1000;opacity:0;transform:translateY(30px);transition:opacity .25s ease,transform .25s ease;overflow-y:auto;-webkit-overflow-scrolling:touch}.pl-screen-overlay.open{opacity:1;transform:translateY(0)}.pl-screen{max-width:480px;margin:0 auto;padding:0 20px 40px}.pl-screen-header{display:flex;align-items:center;gap:12px;padding:16px 0;padding-top:max(16px,env(safe-area-inset-top,0px))}.pl-screen-header span{font-size:1.1rem;font-weight:700}.pl-screen-back{background:none;border:none;color:var(--text);cursor:pointer;padding:4px;display:flex;align-items:center}.pl-screen-new{display:block;margin:12px auto 24px;padding:10px 28px;border-radius:20px;border:1px solid rgba(255,255,255,.4);background:none;color:var(--text);font-size:.95rem;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s}.pl-screen-new:hover{border-color:#fff;background:#ffffff0f}.pl-screen-list{display:flex;flex-direction:column}.pl-screen-item{display:flex;align-items:center;gap:14px;padding:10px 4px;background:none;border:none;color:var(--text);width:100%;text-align:left;cursor:pointer;transition:background .12s;border-radius:8px}.pl-screen-item:hover{background:#ffffff0d}.pl-screen-thumb{width:48px;height:48px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.2rem}.pl-screen-thumb.liked{background:linear-gradient(135deg,#7b4dbd,#4a7dbd);color:#fff}.pl-screen-thumb.playlist{background:#333;color:var(--text-sub)}.pl-screen-thumb.album-pick-thumb{background:#222;overflow:hidden}.pl-screen-thumb.album-pick-thumb img{width:100%;height:100%;object-fit:cover}.pl-screen-info{flex:1;min-width:0}.pl-screen-name{font-size:.95rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pl-screen-count{font-size:.8rem;color:var(--text-sub);margin-top:2px}.pl-screen-circle{width:28px;height:28px;border-radius:50%;border:2px solid rgba(255,255,255,.35);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;color:transparent}.pl-screen-circle.checked{border-color:var(--accent);background:var(--accent);color:#000}.pl-screen-section-header{display:flex;align-items:center;justify-content:space-between;padding:18px 4px 8px}.pl-screen-section-header span{font-size:.85rem;font-weight:700;color:var(--text)}.pl-screen-done-wrap{position:sticky;bottom:0;padding:16px 0 max(16px,env(safe-area-inset-bottom,0px));display:flex;justify-content:center;background:linear-gradient(transparent,var(--bg) 30%);pointer-events:none}.pl-screen-done{pointer-events:auto;padding:14px 40px;border-radius:24px;border:none;background:var(--accent);color:#000;font-size:1rem;font-weight:700;cursor:pointer}.pl-screen-done:hover{filter:brightness(1.1)}.pl-create-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:1100;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease}.pl-create-overlay.open{opacity:1}.pl-create-modal{background:#282828;border-radius:14px;padding:32px 28px 24px;width:90%;max-width:360px;text-align:center}.pl-create-modal h3{font-size:1.1rem;font-weight:700;margin:0 0 20px}.pl-create-input{width:100%;background:none;border:none;border-bottom:2px solid rgba(255,255,255,.3);color:var(--text);font-size:1.3rem;font-weight:700;text-align:center;padding:8px 0;outline:none;transition:border-color .15s}.pl-create-input:focus{border-color:var(--accent)}.pl-create-buttons{display:flex;gap:12px;justify-content:center;margin-top:28px}.pl-create-cancel,.pl-create-submit{padding:12px 32px;border-radius:24px;border:none;font-size:.95rem;font-weight:700;cursor:pointer}.pl-create-cancel{background:none;color:var(--text)}.pl-create-cancel:hover{background:#ffffff0f}.pl-create-submit{background:var(--accent);color:#000}.pl-create-submit:hover{filter:brightness(1.1)}.play-album-btn{margin-top:12px;padding:8px 20px;background:var(--accent);color:#000;border:none;border-radius:20px;font-weight:600;font-size:.85rem;cursor:pointer;transition:opacity .2s}.play-album-btn:hover{opacity:.85}.track-list{list-style:none}.track-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:6px;cursor:pointer;transition:background .15s}.track-item:hover{background:#ffffff0f}.track-item.playing{color:var(--accent)}.track-item.playing .track-num{display:none}.track-item.playing .track-title{color:var(--accent)}.eq-bars{display:flex;align-items:flex-end;gap:2px;width:24px;height:16px;justify-content:center;flex-shrink:0}.eq-bars span{display:block;width:3px;background:var(--accent);border-radius:1px;animation:eq-bounce .6s ease-in-out infinite alternate}.eq-bars span:nth-child(1){height:60%;animation-delay:0s}.eq-bars span:nth-child(2){height:100%;animation-delay:.2s}.eq-bars span:nth-child(3){height:40%;animation-delay:.4s}@keyframes eq-bounce{0%{transform:scaleY(.3)}to{transform:scaleY(1)}}.track-num{color:var(--text-sub);font-size:.85rem;width:24px;text-align:right}.track-title{flex:1;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-fav{color:var(--fav-color);font-size:.75rem}.track-duration{color:var(--text-sub);font-size:.85rem}.fav-remove-btn{background:none;border:none;color:var(--fav-color);cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.7;transition:opacity .2s,transform .15s}.fav-remove-btn:hover{opacity:1;transform:scale(1.15)}@media(pointer:coarse){.fav-remove-btn{opacity:1;min-width:44px;min-height:44px}}#player-bar{position:fixed;bottom:0;left:0;right:0;height:var(--player-height);background:#111111eb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.06);z-index:200}#progress-bar-container{position:absolute;top:-3px;left:0;right:0;height:3px;background:#ffffff1a;cursor:pointer}#progress-bar{height:100%;background:var(--accent);width:0%;transition:width .3s linear}#progress-bar-container:hover{height:5px;top:-5px}#progress-bar-container:hover #progress-bar{transition:none}.player-inner{display:flex;align-items:center;height:100%;padding:0 16px;gap:12px}.player-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0;cursor:pointer}#player-cover{width:48px;height:48px;border-radius:4px;object-fit:cover;background:#1a1a1a}.player-info{min-width:0}.marquee-inner{display:inline-block;white-space:nowrap}.marquee-active .marquee-inner{animation:marquee-scroll var(--marquee-duration, 4s) linear 1.5s infinite}@keyframes marquee-scroll{0%,15%{transform:translate(0)}45%,60%{transform:translate(var(--marquee-dist, -100px))}75%,to{transform:translate(0)}}.marquee-active{text-overflow:clip}#player-title{font-size:.95rem;font-weight:500}#player-artist{font-size:.8rem}.player-controls{display:flex;align-items:center;gap:8px}.ctrl-btn{background:none;border:none;color:var(--text);cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.ctrl-btn:hover{background:#ffffff1a}.ctrl-btn.active{color:var(--accent)}.ctrl-btn.small{opacity:.7}.ctrl-btn.small:hover{opacity:1}#player-fullscreen{--fs-accent: 40, 40, 40;position:fixed;top:0;right:0;bottom:0;left:0;background-color:#121212;background-image:linear-gradient(to bottom,rgba(var(--fs-accent),.85),rgba(var(--fs-accent),.4) 35%,#121212);z-index:300;display:flex;flex-direction:column;overflow:hidden;overscroll-behavior:none}.fs-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;padding-top:max(12px,env(safe-area-inset-top,0px));flex-shrink:0;z-index:2}.fs-topbar-btn{background:none;border:none;color:#ffffffd9;font-size:1.3rem;cursor:pointer;padding:8px;min-width:36px;display:flex;align-items:center;justify-content:center}.fs-topbar-btn:hover{color:#fff}.fs-context{text-align:center;flex:1;min-width:0}.fs-context-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:#ffffffb3}.fs-context-name{font-size:.8rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fs-more-menu{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;background:#0009;display:flex;align-items:flex-end;justify-content:center}.fs-more-menu.hidden{display:none}.fs-more-menu-inner{width:100%;max-width:480px;background:#282828;border-radius:16px 16px 0 0;padding:16px;padding-bottom:max(16px,env(safe-area-inset-bottom,0px))}.fs-menu-header{display:flex;align-items:center;gap:12px;padding-bottom:12px}.fs-menu-thumb{width:48px;height:48px;border-radius:6px;object-fit:cover;background:#1a1a1a}.fs-menu-title{font-size:.95rem;font-weight:600;color:var(--text)}.fs-menu-artist{font-size:.8rem;color:var(--text-sub)}.fs-menu-divider{height:1px;background:#ffffff14;margin-bottom:8px}.fs-menu-item{display:flex;align-items:center;gap:14px;width:100%;padding:14px 8px;background:none;border:none;color:var(--text);font-size:.95rem;cursor:pointer;text-decoration:none;border-radius:6px}.fs-menu-item:hover{background:#ffffff0f}.fs-menu-item.active{color:var(--accent)}.fs-menu-toggle{justify-content:flex-start}.fs-menu-toggle span:nth-child(2){flex:1}.menu-toggle-switch{width:36px;height:20px;border-radius:10px;background:#ffffff26;position:relative;transition:background .2s;flex-shrink:0}.menu-toggle-switch.on{background:var(--accent)}.menu-toggle-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s}.menu-toggle-switch.on .menu-toggle-knob{transform:translate(16px)}.fs-cover-zoom{position:absolute;top:0;right:0;bottom:0;left:0;z-index:8;background:#000000e6;display:flex;align-items:center;justify-content:center;cursor:zoom-out}.fs-cover-zoom.hidden{display:none}.fs-cover-zoom img{max-width:95vw;max-height:95vh;border-radius:8px;object-fit:contain;user-select:none;-webkit-user-select:none}.fs-content{flex:1;display:flex;flex-direction:column;align-items:center;max-width:420px;width:100%;margin:0 auto;padding:0 24px;min-height:0;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.fs-content::-webkit-scrollbar{display:none}.fs-right-col{display:contents}.fs-cover-wrap{position:relative;flex:1 1 0;display:flex;align-items:center;justify-content:center;width:100%;min-height:0;max-height:55vh;cursor:pointer;padding:8px 0}.fs-cover-art{width:90%;max-width:380px;max-height:min(50vh,380px);aspect-ratio:1;border-radius:12px;object-fit:cover;background:#1a1a1a;box-shadow:0 20px 60px #00000080}.fs-song-row{display:flex;align-items:flex-start;justify-content:space-between;width:100%;margin-bottom:16px;gap:12px}.fs-song-info{flex:1;min-width:0;text-align:left}.fs-title{font-size:1.25rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fs-artist{text-align:left}.ctrl-btn.fav-btn{color:var(--text-sub);flex-shrink:0}.ctrl-btn.fav-btn:hover,.ctrl-btn.fav-btn.active{color:var(--fav-color)}.ctrl-btn.disabled{opacity:.25;pointer-events:none}.fs-progress{width:100%;margin-bottom:8px}.fs-progress input[type=range]{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:#ffffff26;border-radius:2px;outline:none;cursor:pointer}.fs-progress input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--text);cursor:pointer}.fs-times{display:flex;justify-content:space-between;margin-top:4px}.fs-times span{font-size:.72rem;color:var(--text-sub);font-variant-numeric:tabular-nums}.fs-controls{display:flex;align-items:center;justify-content:space-evenly;width:100%;margin-bottom:8px}.play-btn-lg{background:var(--text);color:var(--bg);width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center}.play-btn-lg:hover{background:#fff}.fs-bottom-bar{display:flex;align-items:center;justify-content:space-between;width:100%;padding-bottom:max(8px,env(safe-area-inset-bottom,0px))}.fs-bottom-right{display:flex;align-items:center;gap:8px}.lyrics-caption{width:100%;background:#ffffff14;border-radius:12px;padding:12px 16px;margin-bottom:8px;cursor:pointer;transition:background .2s}.lyrics-caption:hover{background:#ffffff1f}.lyrics-caption.hidden{display:none}.lyrics-caption-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.lyrics-caption-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-sub)}.lyrics-expand-btn{background:none;border:none;color:var(--text-sub);cursor:pointer;padding:4px;display:flex}.lyrics-expand-btn:hover{color:var(--text)}.lyrics-caption-text{font-size:1rem;font-weight:600;color:var(--text);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.lyrics-fullscreen{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;background-color:#121212;background-image:linear-gradient(to bottom,rgba(var(--fs-accent),.85),rgba(var(--fs-accent),.4) 35%,#121212);display:flex;flex-direction:column;overflow:hidden}.lyrics-fullscreen.hidden{display:none}.lyrics-fs-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;padding-top:max(12px,env(safe-area-inset-top,0px));flex-shrink:0}.lyrics-fs-info{text-align:center;flex:1;min-width:0}.lyrics-fs-title{font-size:.85rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lyrics-fs-artist{font-size:.72rem;color:#ffffffb3}.lyrics-fs-scroll{flex:1;overflow-y:auto;padding:20px 28px;display:flex;flex-direction:column;gap:6px;scrollbar-width:none;-ms-overflow-style:none}.lyrics-fs-scroll::-webkit-scrollbar{display:none}.lyric-line{font-size:1.3rem;line-height:1.35;font-weight:700;color:#ffffff59;transition:color .3s;cursor:pointer;padding:0}.lyric-line:hover{color:#fff9}.lyric-line.active{color:#fff}.lyric-line-static{color:#ffffffb3;cursor:default}.lyric-line-static:hover{color:#ffffffb3}.lyrics-caption-unsync .lyrics-caption-text{font-size:.85rem;font-weight:400;color:#ffffff80}.lyric-line-break{font-size:1.3rem;font-weight:700;line-height:1.35}.lyric-line-break:before{content:" "}.lyrics-unsync-note{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:#ffffff59;margin-bottom:12px}.share-lyric-line-static{cursor:default}.lyrics-fs-controls{padding:12px 24px;padding-bottom:max(12px,env(safe-area-inset-bottom,0px));flex-shrink:0}.lyrics-fs-progress{width:100%;margin-bottom:8px}.lyrics-fs-progress input[type=range]{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:3px;background:#ffffff40;border-radius:2px;outline:none;cursor:pointer}.lyrics-fs-progress input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:#fff;cursor:pointer}.lyrics-fs-transport{display:flex;align-items:center;justify-content:space-between}.lyrics-fs-transport .play-btn-lg{width:48px;height:48px}.visualizer-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:0}#player-fullscreen.viz-mode .fs-cover-wrap{display:none}#player-fullscreen.viz-mode .visualizer-canvas{display:block}#player-fullscreen.viz-mode .fs-topbar{position:relative;z-index:2;background:linear-gradient(to bottom,rgba(0,0,0,.6) 0%,transparent 100%);transition:opacity .3s ease,visibility .3s ease}#player-fullscreen.viz-mode .fs-content{position:relative;z-index:2;justify-content:flex-end;padding-bottom:max(24px,env(safe-area-inset-bottom,0px));background:linear-gradient(to top,rgba(0,0,0,.7) 0%,rgba(0,0,0,.3) 50%,transparent 100%);transition:opacity .3s ease,visibility .3s ease}#player-fullscreen.viz-controls-hidden .fs-topbar,#player-fullscreen.viz-controls-hidden .fs-content{opacity:0;visibility:hidden;pointer-events:none}.viz-preset-name{position:absolute;bottom:8px;left:8px;z-index:3;font-size:.65rem;color:#ffffff73;background:#00000059;padding:2px 6px;border-radius:4px;pointer-events:none;max-width:70%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loading{text-align:center;color:var(--text-sub);padding:20px;font-size:.9rem}.btn{display:block;margin:16px auto;padding:10px 24px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:var(--text);border-radius:20px;cursor:pointer;font-size:.9rem;transition:background .2s}.btn:hover{background:#ffffff1a}.no-cover{width:100%;aspect-ratio:1;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);display:flex;align-items:center;justify-content:center;color:#3a3a5a;font-size:2.5rem}@supports (padding-bottom: env(safe-area-inset-bottom)){#player-bar{padding-bottom:env(safe-area-inset-bottom);height:calc(var(--player-height) + env(safe-area-inset-bottom))}.fs-content{padding-bottom:calc(8px + env(safe-area-inset-bottom))}#header,#main{padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right))}}@media(pointer:coarse){.ctrl-btn{min-width:44px;min-height:44px}.track-item{min-height:48px}.card{min-height:44px}.filter-btn{min-height:40px;padding:8px 14px}.pager-btn{min-height:40px;min-width:40px}.admin-nav-link{min-height:40px;display:flex;align-items:center}}@media(orientation:landscape)and (max-height:600px)and (pointer:coarse){.fs-topbar{padding:4px 16px;padding-top:max(4px,env(safe-area-inset-top,0px))}.fs-content{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto auto auto;max-width:none;width:100%;padding:0 24px;gap:0 24px;align-content:center}.fs-cover-wrap{grid-column:1;grid-row:1 / -1;flex:none;padding:0;align-self:center}.fs-cover-art{width:auto;max-width:none;height:min(50vh,240px);aspect-ratio:1}.fs-song-row{grid-column:2;grid-row:1;margin-bottom:6px}.fs-progress{grid-column:2;grid-row:2;margin-bottom:2px}.fs-controls{grid-column:2;grid-row:3;margin-bottom:2px}.fs-bottom-bar{grid-column:2;grid-row:4}.lyrics-caption{display:none!important}.stems-panel{grid-column:1 / -1}.fs-title{font-size:1.05rem}.play-btn-lg{width:52px;height:52px}.fs-controls .ctrl-btn svg{width:22px;height:22px}.fs-bottom-bar{padding-bottom:max(4px,env(safe-area-inset-bottom,0px))}}@media(max-width:1024px)and (min-width:601px){.card-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}#main{padding:20px 16px}.admin-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}}@media(max-width:600px){#header{padding:0 12px}.logo{font-size:1.1rem}.header-actions{gap:8px}#main{padding:16px 12px}#main h2{font-size:1.05rem}.card-grid{grid-template-columns:repeat(3,1fr);gap:10px}.card-info{padding:6px}.card-title{font-size:.78rem}.card-sub{font-size:.68rem}#album-header{flex-direction:column;align-items:center;text-align:center}#album-header img,.album-no-cover{width:180px;height:180px}.album-meta h2{font-size:1.3rem}.player-right{display:none}.player-inner{padding:0 10px;gap:8px}#player-cover{width:40px;height:40px}#player-title{font-size:.85rem}#player-artist{font-size:.72rem}.player-controls{gap:4px}.fs-content{padding:0 16px}.fs-cover-art{max-width:300px}.fs-title{font-size:1.1rem}.play-btn-lg{width:58px;height:58px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.stat-value{font-size:1.4rem}.stat-card{padding:12px}.admin-toolbar{gap:8px}.admin-search{min-width:0;width:100%}.admin-filters{flex-wrap:wrap}.admin-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -12px;padding:0 12px}.col-hide-sm{display:none}.song-edit-top{flex-direction:column;align-items:center}.song-edit-cover{width:100px;height:100px}.album-detail-header{flex-direction:column;align-items:center;text-align:center}.album-detail-cover{width:120px;height:120px}.album-detail-actions{justify-content:center;flex-wrap:wrap}.modal{max-width:calc(100vw - 24px)}.track-item{padding:8px;gap:8px}.track-title{font-size:.88rem}}@media(max-width:380px){.card-grid{grid-template-columns:repeat(3,1fr);gap:6px}.fs-cover-art{max-width:240px}.fs-title{font-size:1rem}.play-btn-lg{width:52px;height:52px}.stats-grid{grid-template-columns:1fr 1fr}.admin-nav{gap:2px}.admin-nav-link{padding:6px 10px;font-size:.8rem}}#main::-webkit-scrollbar{width:6px}#main::-webkit-scrollbar-track{background:transparent}#main::-webkit-scrollbar-thumb{background:#2a2a2a;border-radius:3px}#main::-webkit-scrollbar-thumb:hover{background:#3a3a3a}.admin-nav{display:flex;gap:4px;padding-bottom:16px;margin-bottom:16px;border-bottom:1px solid rgba(255,255,255,.06)}.admin-nav-link{padding:6px 16px;border-radius:6px;font-size:.9rem;color:var(--text-sub);text-decoration:none;transition:all .2s}.admin-nav-link:hover{background:var(--bg-hover);color:var(--text)}.admin-nav-link.active{background:var(--accent-dim);color:#fff}.admin-loading,.admin-empty,.admin-error{text-align:center;padding:40px 0;color:var(--text-sub);font-size:.9rem}.admin-error{color:#ff6b6b}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:24px}.stat-card{background:var(--bg-card);border-radius:var(--radius);padding:16px;text-align:center}.stat-value{font-size:1.8rem;font-weight:700;color:var(--text)}.stat-label{font-size:.8rem;color:var(--text-sub);margin-top:2px;text-transform:uppercase;letter-spacing:.05em}.stat-sub{font-size:.75rem;color:var(--text-sub);margin-top:4px}.admin-section{margin-top:24px}.admin-section h3{font-size:.95rem;margin-bottom:10px;color:var(--text-sub)}.model-chips{display:flex;flex-wrap:wrap;gap:6px}.model-chip{font-size:.75rem;padding:4px 10px;background:var(--bg-card);border-radius:12px;color:var(--text-sub)}.model-chip strong{color:var(--text);margin-left:4px}.admin-toolbar{display:flex;gap:12px;align-items:center;margin-bottom:12px;flex-wrap:wrap}.admin-search{flex:1;min-width:200px;padding:8px 12px;background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text);font-size:.9rem;outline:none}.admin-search:focus{border-color:var(--accent)}.admin-filters{display:flex;gap:4px}.filter-btn{padding:6px 12px;background:transparent;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-sub);cursor:pointer;font-size:.8rem;transition:all .2s}.filter-btn:hover{background:var(--bg-hover);color:var(--text)}.filter-btn.active{background:var(--accent-dim);border-color:var(--accent-dim);color:#fff}.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-table th{text-align:left;padding:8px 10px;color:var(--text-sub);font-weight:500;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid rgba(255,255,255,.06);white-space:nowrap}.admin-table td{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle}.admin-table tbody tr{transition:background .15s}.admin-table tbody tr:hover{background:var(--bg-hover)}.col-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.col-sortable:hover{color:var(--text)}.col-num{text-align:right;font-variant-numeric:tabular-nums}.col-img{width:40px}.col-model{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-sub)}.col-date{white-space:nowrap;color:var(--text-sub)}.admin-thumb{width:36px;height:36px;border-radius:4px;object-fit:cover;background:#222}.admin-thumb-sm{width:28px;height:28px;border-radius:3px;object-fit:cover;background:#222}.admin-thumb-wrap{position:relative;width:36px;height:36px}.admin-play-btn{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#000000a6;border:none;border-radius:4px;color:#fff;font-size:.85rem;cursor:pointer;opacity:0;transition:opacity .15s}.admin-thumb-wrap:hover .admin-play-btn,.admin-play-btn:focus-visible{opacity:1}.track-thumb-wrap{position:relative;width:28px;height:28px;flex-shrink:0;cursor:pointer;border-radius:3px;overflow:hidden}.track-thumb-wrap .admin-thumb-sm{width:100%;height:100%}.track-thumb-play{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0009;color:#fff;font-size:.7rem;opacity:0;transition:opacity .15s;pointer-events:none}.track-thumb-wrap:hover .track-thumb-play,.track-thumb-wrap.is-playing .track-thumb-play{opacity:1}.modal-header-actions{display:flex;align-items:center;gap:8px}.btn-play-modal{padding:4px 12px;background:var(--accent);border:none;border-radius:16px;color:#000;font-size:.75rem;font-weight:600;cursor:pointer}.btn-play-modal:hover{filter:brightness(1.1)}.btn-share-modal{padding:4px 12px;background:#ffffff1a;border:none;border-radius:16px;color:var(--text);font-size:.75rem;font-weight:600;cursor:pointer}.btn-share-modal:hover{background:#ffffff26}.song-row{cursor:pointer}.song-title-cell{display:flex;flex-direction:column;gap:2px}.song-title-text{color:var(--text)}.song-tags{display:flex;flex-wrap:wrap;gap:3px}.tag{font-size:.65rem;padding:1px 6px;background:#4f9eff26;color:var(--accent);border-radius:8px}.vis-badge{font-size:.7rem;padding:2px 8px;border-radius:8px;font-weight:500;white-space:nowrap}.vis-private{background:#ffffff0f;color:var(--text-sub)}.vis-users{background:#4f9eff26;color:var(--accent)}.vis-public{background:#4caf5026;color:#66bb6a}.pager{display:flex;align-items:center;justify-content:center;gap:4px;padding:16px 0}.pager-btn{padding:4px 10px;background:var(--bg-card);border:1px solid rgba(255,255,255,.06);border-radius:4px;color:var(--text-sub);cursor:pointer;font-size:.8rem;transition:all .2s}.pager-btn:hover:not([disabled]){background:var(--bg-hover);color:var(--text)}.pager-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.pager-btn[disabled]{opacity:.3;cursor:default}.pager-info{font-size:.75rem;color:var(--text-sub);margin-left:12px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:500;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:#1a1a1a;border-radius:12px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.modal-lg{max-width:640px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.06)}.modal-header h3{font-size:1rem}.modal-close{background:none;border:none;color:var(--text-sub);font-size:1.4rem;cursor:pointer;padding:0 4px}.modal-close:hover{color:var(--text)}.modal-body{padding:16px 20px}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid rgba(255,255,255,.06)}.modal-loading{text-align:center;padding:40px;color:var(--text-sub)}.song-edit-top{display:flex;gap:16px;margin-bottom:16px}.song-edit-cover{width:120px;height:120px;border-radius:8px;object-fit:cover;flex-shrink:0;background:#222}.song-edit-meta{flex:1}.meta-row{display:flex;gap:8px;padding:3px 0;font-size:.8rem}.meta-label{color:var(--text-sub);min-width:70px;flex-shrink:0}.meta-value{color:var(--text);word-break:break-all}.mono{font-family:monospace;font-size:.7rem}.song-edit-prompt{margin-bottom:16px;padding:10px;background:#ffffff08;border-radius:6px}.prompt-text{font-size:.8rem;color:var(--text);margin-top:4px;line-height:1.5}.edit-fields{display:flex;flex-direction:column;gap:12px}.edit-label{display:flex;flex-direction:column;gap:4px;font-size:.8rem;color:var(--text-sub)}.edit-hint{font-size:.7rem;opacity:.6}.edit-input,.edit-select{padding:8px 10px;background:var(--bg);border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text);font-size:.9rem;outline:none}.edit-input:focus,.edit-select:focus{border-color:var(--accent)}.edit-textarea{resize:vertical;min-height:60px;font-family:inherit}.song-edit-albums{margin-top:16px}.edit-section-header{font-size:.8rem;color:var(--text-sub);margin-bottom:8px}.song-album-list{max-height:160px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.song-album-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:.85rem}.song-album-row:hover{background:#ffffff0a}.song-album-row input[type=checkbox]{accent-color:var(--accent);flex-shrink:0}.song-album-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.song-album-count{font-size:.75rem;color:var(--text-sub);flex-shrink:0}.btn{padding:8px 16px;border:none;border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .2s}.btn-small{padding:5px 12px;font-size:.8rem}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#3d8ae8}.btn-save{background:var(--accent);color:#fff}.btn-save:hover{background:#3d8ae8}.btn-save:disabled{opacity:.5;cursor:default}.btn-cancel{background:var(--bg-card);color:var(--text-sub)}.btn-cancel:hover{background:var(--bg-hover);color:var(--text)}.btn-danger{background:#ff4b4b26;color:#ff6b6b}.btn-danger:hover{background:#ff4b4b40}.album-list{display:flex;flex-direction:column;gap:2px}.album-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .15s}.album-row:hover{background:var(--bg-hover)}.album-row-info{flex:1}.album-row-title{font-size:.9rem;color:var(--text)}.album-row-sub{font-size:.75rem;color:var(--text-sub);margin-top:2px}.album-detail-header{display:flex;gap:20px;margin-bottom:24px}.album-detail-cover{width:160px;height:160px;border-radius:8px;object-fit:cover;flex-shrink:0;background:#222}.album-detail-info{flex:1;display:flex;flex-direction:column;justify-content:center}.album-detail-info h2{font-size:1.3rem;margin-bottom:4px}.album-detail-sub{font-size:.85rem;color:var(--text-sub);display:flex;align-items:center;gap:4px}.album-detail-desc{font-size:.85rem;color:var(--text-sub);margin-top:8px}.album-detail-actions{display:flex;gap:8px;margin-top:12px}.album-tracks-section{margin-top:8px}.album-tracks-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.album-tracks-header h3{font-size:1rem}.track-list{display:flex;flex-direction:column;gap:2px}.track-row{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--bg-card);border-radius:6px;transition:background .15s,opacity .2s}.track-row:hover{background:var(--bg-hover)}.track-row.dragging{opacity:.4}.track-handle{cursor:grab;color:var(--text-sub);font-size:.9rem;padding:0 2px}.track-num{color:var(--text-sub);font-size:.8rem;width:20px;text-align:right;font-variant-numeric:tabular-nums}.track-info{flex:1;display:flex;justify-content:space-between;align-items:center;gap:8px;min-width:0}.track-title{color:var(--text);font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-dur{color:var(--text-sub);font-size:.8rem;flex-shrink:0}.track-remove{background:none;border:none;color:var(--text-sub);font-size:1.2rem;cursor:pointer;padding:0 4px;opacity:0;transition:all .2s}.track-row:hover .track-remove{opacity:1}.track-remove:hover{color:#ff6b6b}.add-track-results{max-height:300px;overflow-y:auto;margin-top:12px}.add-track-row{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:6px;cursor:pointer;transition:background .15s}.add-track-row:hover{background:var(--bg-hover)}.add-track-row.already-added{opacity:.4}.add-track-row input[type=checkbox]{accent-color:var(--accent);flex-shrink:0}.add-track-title{flex:1;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.add-track-dur{font-size:.75rem;color:var(--text-sub);flex-shrink:0}.add-track-already{font-size:.7rem;color:var(--text-sub);flex-shrink:0}.stems-panel{width:100%;max-width:400px;margin:0 auto;padding:12px 0 0}.stems-channels{display:flex;justify-content:center;gap:20px}.stem-channel{display:flex;flex-direction:column;align-items:center;gap:8px;transition:opacity .2s}.stem-channel.stem-silent{opacity:.35}.stem-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-sub);font-weight:600}.stem-volume{-webkit-appearance:none;-moz-appearance:none;appearance:none;writing-mode:vertical-lr;direction:rtl;width:6px;height:100px;background:#ffffff1f;border-radius:3px;outline:none;cursor:pointer}.stem-volume::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent, #fff);cursor:pointer;border:2px solid rgba(0,0,0,.3)}.stem-volume::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent, #fff);cursor:pointer;border:2px solid rgba(0,0,0,.3)}.stem-volume::-webkit-slider-runnable-track{background:transparent}.stem-buttons{display:flex;gap:4px}.stem-mute,.stem-solo{width:28px;height:24px;border:1px solid rgba(255,255,255,.2);border-radius:4px;background:transparent;color:var(--text-sub);font-size:.65rem;font-weight:700;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.stem-mute:hover,.stem-solo:hover{border-color:#fff6;color:#fff}.stem-mute.active{background:#c0392b;border-color:#c0392b;color:#fff}.stem-solo.active{background:#f39c12;border-color:#f39c12;color:#000}@media(max-width:480px){.stems-channels{gap:14px}.stem-volume{height:80px}.stem-mute,.stem-solo{width:24px;height:22px;font-size:.6rem}}#toast{position:fixed;bottom:calc(env(safe-area-inset-bottom,0px) + 90px);left:50%;transform:translate(-50%) translateY(20px);background:#fff;color:#121212;padding:10px 24px;border-radius:8px;font-size:.875rem;font-weight:600;pointer-events:none;opacity:0;transition:opacity .25s ease,transform .25s ease;z-index:10000;white-space:nowrap;box-shadow:0 4px 12px #0006}#toast.show{opacity:1;transform:translate(-50%) translateY(0)}.admin-sub-info{font-size:.82rem;color:var(--text-sub);margin-bottom:10px}.admin-count{font-weight:400;color:var(--text-sub);font-size:.85em}.user-avatar-sm{width:32px;height:32px;border-radius:50%;object-fit:cover;background:#222}.user-avatar-lg{width:80px;height:80px;border-radius:50%;object-fit:cover;background:#222;flex-shrink:0}.clickable-row{cursor:pointer}.clickable-row:hover td{background:#ffffff0a}.badge-active{background:#1db95426;color:#1db954;padding:2px 10px;border-radius:12px;font-size:.8em;font-weight:600}.badge-banned{background:#ef444426;color:#ef4444;padding:2px 10px;border-radius:12px;font-size:.8em;font-weight:600}.user-profile-header{display:flex;gap:20px;align-items:flex-start;padding:16px 0;flex-wrap:wrap}.user-profile-info{flex:1;min-width:200px}.user-profile-info h2{margin-bottom:4px}.user-meta{color:var(--text-sub);font-size:.85rem;margin-bottom:2px}.user-stats-row{display:flex;gap:16px;margin-top:10px}.user-stat{font-size:.85rem;color:var(--text-sub)}.user-stat strong{color:var(--text)}.user-actions{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.btn-ban{background:#ef44441f;color:#ef4444;border:1px solid rgba(239,68,68,.3);padding:8px 20px;border-radius:8px;cursor:pointer;font-size:.85rem;font-weight:600;transition:background .2s}.btn-ban:hover{background:#ef444440}.btn-ban.banned{background:#1db9541f;color:#1db954;border-color:#1db9544d}.btn-ban.banned:hover{background:#1db95440}.ban-info{font-size:.78rem;color:#ef4444}.user-detail-list{display:flex;flex-direction:column;gap:4px}.user-detail-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.04)}.user-detail-title{font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.user-detail-sub{font-size:.8rem;color:var(--text-sub);flex-shrink:0;margin-left:12px}.ud-playlist{background:#ffffff08;border-radius:8px;margin-bottom:8px;overflow:hidden}.ud-playlist-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px}.ud-playlist-title{font-weight:500;font-size:.9rem}.ud-playlist-meta{font-size:.78rem;color:var(--text-sub);white-space:nowrap}.ud-playlist-songs{padding:0 14px 10px;display:flex;flex-direction:column;gap:2px}.ud-playlist-song{display:flex;align-items:center;gap:10px;padding:3px 0;font-size:.82rem}.ud-ps-num{color:var(--text-sub);width:20px;text-align:right;flex-shrink:0;font-variant-numeric:tabular-nums}.ud-ps-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ud-playlist-empty{padding:4px 14px 10px;font-size:.8rem;color:var(--text-sub)}.admin-users-table{table-layout:fixed}.ut-col-avatar{width:40px}.ut-col-name{width:auto}.ut-col-last{width:110px;white-space:nowrap}.ut-col-num{width:60px;text-align:right;font-variant-numeric:tabular-nums}.ut-col-status{width:70px;text-align:center}.ut-name{color:var(--text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ut-email{color:var(--text-sub);font-size:.78rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:768px){.ut-col-last{display:none}.user-profile-header{flex-direction:column;align-items:center;text-align:center}.user-actions{align-items:center}.user-stats-row{justify-content:center}}.share-overview{display:flex;gap:12px;margin-bottom:20px}.stat-card.compact{padding:14px 20px;min-width:100px}.share-summary-stats{display:flex;gap:16px;margin-bottom:12px;font-size:.9rem}.share-stat{color:var(--text-sub)}.share-stat strong{color:var(--text);margin-right:4px}.share-thumb{width:32px;height:32px;border-radius:4px;object-fit:cover;background:#222}.event-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.event-view{background:#60a5fa26;color:#60a5fa}.event-play{background:#1db95426;color:#1db954}.share-user{display:inline-flex;align-items:center;gap:6px;font-weight:500}.share-user-avatar{width:20px;height:20px;border-radius:50%;object-fit:cover;background:#222}.share-anon{color:var(--text-sub);font-style:italic;font-size:.82rem}.admin-link-more{display:inline-block;margin-top:12px;color:var(--accent);font-size:.85rem;text-decoration:none}.admin-link-more:hover{text-decoration:underline}.truncate-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.no-wrap{white-space:nowrap}.se-row{cursor:pointer}.se-detail td{padding:0!important;border-bottom:1px solid rgba(255,255,255,.06)}.se-detail-inner{padding:10px 14px 12px;background:#ffffff05;display:flex;flex-direction:column;gap:4px}.se-detail-row{display:flex;gap:10px;font-size:.8rem;line-height:1.5}.se-label{color:var(--text-sub);flex-shrink:0;min-width:80px}.se-value{color:var(--text);word-break:break-all}.se-value.mono{font-family:monospace;font-size:.78rem}@media(max-width:600px){.share-overview{flex-direction:column}.admin-shares .admin-table th:nth-child(4),.admin-shares .admin-table td:nth-child(4),.admin-shares .admin-table th:nth-child(5),.admin-shares .admin-table td:nth-child(5){display:none}}@media(min-width:768px)and (max-width:1023px){.fs-content{max-width:480px;padding:0 32px}.fs-cover-art{max-width:400px}.fs-title{font-size:1.3rem}}@media(min-width:1024px){.fs-content{flex-direction:row;align-items:center;justify-content:center;max-width:1100px;padding:0 48px;gap:0 56px;overflow:visible}.fs-cover-wrap{flex:0 1 50%;max-width:500px;padding:0;min-height:0}.fs-cover-art{width:100%;max-height:min(60vh,500px);aspect-ratio:1;object-fit:cover}.fs-right-col{flex:1 1 0;min-width:280px;display:flex;flex-direction:column}.fs-song-row{margin-bottom:20px}.fs-progress,.fs-controls{margin-bottom:12px}.lyrics-caption{margin-top:12px}.stems-panel{flex:0 0 100%}.fs-title{font-size:1.6rem}.fs-artist{font-size:1.05rem}.play-btn-lg{width:76px;height:76px}.fs-controls .ctrl-btn svg{width:28px;height:28px}}.share-view{--share-accent: 40, 40, 40;position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#121212;overflow:hidden;overscroll-behavior:none}.share-bg{position:absolute;top:-40px;right:-40px;bottom:-40px;left:-40px;background-size:cover;background-position:center;filter:blur(60px) saturate(1.4) brightness(.35);z-index:0}.share-bg-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#0000004d,#0009,#000000d9);z-index:1}.share-loading{color:var(--text-sub);font-size:.9rem;position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:2}.share-content{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:center;height:100%;max-width:480px;width:100%;margin:0 auto;padding:0 24px;padding-top:max(12px,env(safe-area-inset-top,0px));padding-bottom:max(16px,env(safe-area-inset-bottom,0px));overflow:hidden}.share-content-center{justify-content:center;align-items:center}.share-header{display:flex;align-items:center;justify-content:space-between;padding:4px 0 12px;flex-shrink:0}.share-brand{font-size:.9rem;font-weight:700;color:#fff;text-decoration:none;letter-spacing:-.01em}.share-brand:hover{opacity:.85}.share-expires-badge{font-size:.65rem;color:#ffffff80;background:#ffffff14;padding:4px 10px;border-radius:12px;white-space:nowrap}.share-cover-wrap{display:flex;align-items:center;justify-content:center;padding:8px 0 16px;flex-shrink:0}.share-cover{width:85%;max-width:340px;aspect-ratio:1;border-radius:12px;object-fit:cover;background:#1a1a1a;box-shadow:0 20px 60px #00000080}.share-cover-empty{width:85%;max-width:340px;aspect-ratio:1;border-radius:12px;background:linear-gradient(135deg,#1a1a2e,#16213e)}.share-info{text-align:center;padding-bottom:8px;flex-shrink:0}.share-title{font-size:1.25rem;font-weight:700;color:var(--text);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-artist{font-size:.85rem;color:var(--text-sub)}.share-lyrics-scroll{flex:1;min-height:0;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;padding:12px 4px;display:flex;flex-direction:column;gap:14px;mask-image:linear-gradient(to bottom,transparent 0%,black 8%,black 85%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 8%,black 85%,transparent 100%)}.share-lyrics-scroll::-webkit-scrollbar{display:none}.share-lyrics-scroll:not(.has-lyrics){display:none}.share-lyric-line{font-size:1.25rem;line-height:1.4;font-weight:700;color:#ffffff4d;transition:color .3s;cursor:pointer;padding:2px 0}.share-lyric-line:hover{color:#ffffff8c}.share-lyric-line.active{color:#fff}.share-player-controls{flex-shrink:0;padding:8px 0}.share-progress-wrap{display:flex;align-items:center;gap:10px;width:100%;margin-bottom:8px}.share-time{font-size:.7rem;color:var(--text-sub);font-variant-numeric:tabular-nums;min-width:32px}.share-time:last-child{text-align:right}.share-progress{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:3px;border-radius:2px;background:#fff3;outline:none;cursor:pointer}.share-progress::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:#fff;cursor:pointer}.share-buttons{display:flex;align-items:center;justify-content:center}.share-play-btn{width:64px;height:64px;border-radius:50%;border:none;background:#fff;color:#000;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .1s}.share-play-btn:active{transform:scale(.95)}.share-footer{display:flex;flex-direction:column;align-items:center;gap:10px;padding:12px 0 4px;flex-shrink:0}.share-private-badge{font-size:.7rem;color:#fff6;letter-spacing:.02em}.share-explore-btn{font-size:.85rem;font-weight:600;color:#fff;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:8px 24px;text-decoration:none;transition:background .15s}.share-explore-btn:hover{background:#ffffff2e}.share-expired{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;padding:40px 0}.share-expired-title{font-size:1.1rem;font-weight:600;color:var(--text)}.share-expired-sub{font-size:.85rem;color:var(--text-sub)}.share-content.has-lyrics{justify-content:flex-start}.share-content.has-lyrics .share-cover-wrap{padding:4px 0 8px}.share-content.has-lyrics .share-cover,.share-content.has-lyrics .share-cover-empty{max-width:220px}@media(min-width:768px){.share-content{max-width:560px}.share-cover,.share-cover-empty{max-width:400px}.share-title{font-size:1.5rem}.share-artist{font-size:1rem}.share-play-btn{width:76px;height:76px}.share-play-btn svg{width:38px;height:38px}.share-brand{font-size:1.05rem}.share-explore-btn{font-size:.95rem;padding:10px 28px}.share-lyric-line{font-size:1.4rem}}@media(min-width:1200px){.share-content{max-width:640px}.share-cover,.share-cover-empty{max-width:440px}.share-title{font-size:1.7rem}.share-play-btn{width:84px;height:84px}.share-play-btn svg{width:42px;height:42px}}.share-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#0009;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .15s ease}.share-picker-sheet{background:var(--surface, #282828);border-radius:16px 16px 0 0;width:100%;max-width:420px;padding:20px 16px max(16px,env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:4px}.share-picker-title{font-size:.85rem;font-weight:600;color:var(--text-sub);text-transform:uppercase;letter-spacing:.5px;padding:0 4px 8px;text-align:center}.share-picker-opt{background:none;border:none;color:var(--text);font-size:1rem;padding:14px 12px;border-radius:10px;text-align:left;cursor:pointer;transition:background .15s}.share-picker-opt:hover{background:#ffffff14}.share-picker-opt:disabled{opacity:.5;cursor:default}.share-picker-cancel{background:none;border:none;color:var(--text-sub);font-size:.9rem;padding:14px 12px;border-radius:10px;text-align:center;cursor:pointer;margin-top:4px}.share-picker-cancel:hover{background:#ffffff0d}.share-dropdown-wrap{position:relative;display:inline-block}.share-dropdown{position:absolute;top:100%;right:0;z-index:100;background:var(--surface, #282828);border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:4px 0;min-width:150px;box-shadow:0 8px 24px #0006}.share-opt{display:block;width:100%;background:none;border:none;color:var(--text);font-size:.85rem;padding:8px 14px;text-align:left;cursor:pointer;white-space:nowrap}.share-opt:hover{background:#ffffff14}.install-banner{position:fixed;bottom:calc(var(--player-height) + 8px);left:12px;right:12px;z-index:500;background:var(--accent);color:#fff;border-radius:12px;display:flex;align-items:center;gap:10px;padding:12px 14px;box-shadow:0 4px 20px #0006;transform:translateY(120%);transition:transform .3s ease}.install-banner.show{transform:translateY(0)}.install-banner-text{flex:1;display:flex;flex-direction:column;gap:2px}.install-banner-text strong{font-size:.9rem}.install-banner-text span{font-size:.75rem;opacity:.85}.install-banner-btn{background:#fff;color:var(--accent);border:none;border-radius:8px;padding:8px 16px;font-weight:600;font-size:.85rem;cursor:pointer;white-space:nowrap}.install-banner-dismiss{background:none;border:none;color:#ffffffb3;font-size:1.2rem;cursor:pointer;padding:4px;line-height:1}.fs-admin-actions{display:flex;align-items:center;gap:8px}.song-edit-share-stats{margin-top:16px}.share-stats-content{min-height:40px}.share-stats-loading,.share-stats-empty{font-size:.8rem;color:var(--text-sub);padding:8px 0}.share-stats-summary{display:flex;gap:12px;margin-bottom:12px}.share-stat-box{background:#ffffff0f;border-radius:8px;padding:10px 16px;display:flex;flex-direction:column;align-items:center;gap:2px;min-width:72px}.share-stat-num{font-size:1.3rem;font-weight:700;color:var(--text)}.share-stat-label{font-size:.7rem;color:var(--text-sub);text-transform:uppercase;letter-spacing:.5px}.share-stats-recent-label{font-size:.75rem;color:var(--text-sub);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.share-stats-recent{max-height:180px;overflow-y:auto}.share-event-row{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:.8rem;color:var(--text);border-bottom:1px solid rgba(255,255,255,.05)}.share-event-icon{font-size:.7rem;width:16px;text-align:center}.share-event-type{width:36px}.share-event-device{color:var(--text-sub);flex:1}.share-event-country{width:24px;text-align:center}.share-event-time{color:var(--text-sub);white-space:nowrap;margin-left:auto}.settings-page{max-width:520px;margin:0 auto;padding:8px 0 40px}.settings-heading{font-size:1.5rem;font-weight:700;margin-bottom:24px}.settings-section{margin-bottom:28px}.settings-section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-sub);margin-bottom:8px;padding:0 4px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 12px;background:#ffffff0a;border-radius:10px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.settings-row:hover{background:#ffffff12}.settings-row-label{font-size:.95rem;color:var(--text)}.settings-row-desc{font-size:.78rem;color:var(--text-sub);margin-top:2px}.settings-row .toggle-switch.disabled{opacity:.35;pointer-events:none}.settings-about{padding:24px 16px;background:#ffffff0a;border-radius:10px;text-align:center}.settings-about-avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;margin-bottom:12px}.settings-about-name{font-size:1.3rem;font-weight:700;margin-bottom:12px}.settings-about-bio{text-align:left;font-size:.85rem;color:var(--text-sub);line-height:1.55;margin-bottom:16px}.settings-about-bio p{margin:0 0 10px}.settings-about-bio p:last-child{margin-bottom:0}.settings-about-links-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-sub);opacity:.6;margin-bottom:8px}.settings-about-links{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}.settings-social-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:#ffffff14;color:var(--text-sub);transition:background .2s,color .2s}.settings-social-link:hover{background:#ffffff26;color:var(--text)}.settings-row-info-only{cursor:default}.settings-row-info-only:hover{background:#ffffff0a}.settings-row+.settings-row{margin-top:4px}.settings-techstack{background:#ffffff0a;border-radius:10px;padding:16px 14px}.settings-techstack-header{font-size:.9rem;color:var(--text-sub);text-align:center;margin-bottom:12px}.settings-techstack-header a{color:var(--text);font-weight:600;text-decoration:none}.settings-techstack-header a:hover{text-decoration:underline}.settings-techstack-grid{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}.settings-techstack-item{font-size:.8rem;font-weight:500;color:var(--accent);background:#4f9eff1a;padding:5px 12px;border-radius:6px;text-decoration:none;transition:background .2s}.settings-techstack-item:hover{background:#4f9eff33}.settings-techstack-divider{height:1px;background:#ffffff0f;margin-bottom:14px}.settings-techstack-oss{font-size:.8rem;color:var(--text-sub);text-align:center;margin-bottom:10px}.settings-techstack-version{font-size:.7rem;color:var(--text-sub);opacity:.5;text-align:center;margin-top:14px}.settings-licenses{border-radius:8px;overflow:hidden}.settings-license{padding:12px 14px}.settings-license+.settings-license{border-top:1px solid rgba(255,255,255,.06)}.settings-license-name{font-size:.9rem;font-weight:600;color:var(--text);margin-bottom:2px}.settings-license-desc{font-size:.78rem;color:var(--text-sub)}.img-control{position:relative;width:120px;height:120px;flex-shrink:0;border-radius:8px;overflow:hidden;cursor:pointer}.img-control-lg{width:160px;height:160px}.img-control .img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;gap:8px;opacity:0;transition:opacity .2s}.img-control:hover .img-overlay{opacity:1}.img-btn{width:36px;height:36px;border-radius:50%;border:none;background:#ffffff26;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.img-btn:hover{background:#ffffff4d}.img-file-input{display:none}.img-empty{background:#222!important;display:flex!important;align-items:center;justify-content:center;color:#555;font-size:2rem}img.img-empty{object-position:-9999px -9999px}.img-placeholder{width:100%;height:100%;border-radius:8px}.img-loading:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;border-radius:8px}.img-loading .img-overlay{opacity:0!important}@keyframes img-spin{to{transform:rotate(360deg)}}.img-loading:before{content:"";position:absolute;top:50%;left:50%;width:24px;height:24px;margin:-12px 0 0 -12px;border:3px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:img-spin .6s linear infinite;z-index:2}.album-edit-top{display:flex;justify-content:center;margin-bottom:16px}.filter-btn-archived{border-color:#664!important;color:#aa8!important}.filter-btn-archived.active{background:#540!important;border-color:#886!important;color:#dda!important}.btn-archive{font-size:.8rem;padding:6px 12px}.modal-footer-right{display:flex;gap:8px;margin-left:auto}.rename-dialog{background:var(--card);border-radius:12px;padding:20px;width:90%;max-width:360px;margin:auto}.rename-dialog-title{font-size:1rem;font-weight:600;margin-bottom:12px}.rename-input{width:100%;padding:10px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:#ffffff0f;color:var(--text);font-size:.95rem;outline:none;box-sizing:border-box}.rename-input:focus{border-color:var(--accent)}.rename-dialog-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}
