:root{--bg: #0d0d1a;--surface: #13132a;--surface2: #1a1a35;--surface3: #252550;--accent: #a855f7;--accent-2: #ec4899;--accent-glow: rgba(168, 85, 247, .3);--accent-subtle: rgba(168, 85, 247, .08);--accent-bg: rgba(168, 85, 247, .25);--accent-glow-strong: rgba(168, 85, 247, .8);--text: #ffffff;--text-sec: #a0a0c0;--text-muted: #5a5a7a;--divider: #1e1e3a;--top-h: 52px;--mini-h: 68px;--nav-h: 60px}[data-theme=night]{--bg: #0d0d1a;--surface: #13132a;--surface2: #1a1a35;--surface3: #252550;--accent: #a855f7;--accent-2: #ec4899;--accent-glow: rgba(168, 85, 247, .3);--accent-subtle: rgba(168, 85, 247, .08);--accent-bg: rgba(168, 85, 247, .25);--accent-glow-strong: rgba(168, 85, 247, .8);--text: #ffffff;--text-sec: #a0a0c0;--text-muted: #5a5a7a;--divider: #1e1e3a}[data-theme=sand]{--bg: #1a1816;--surface: #221f1b;--surface2: #2c2822;--surface3: #38322a;--accent: #c9a050;--accent-2: #d4885a;--accent-glow: rgba(201, 160, 80, .3);--accent-subtle: rgba(201, 160, 80, .08);--accent-bg: rgba(201, 160, 80, .25);--accent-glow-strong: rgba(201, 160, 80, .8);--text: #f0ece0;--text-sec: #b0a090;--text-muted: #706858;--divider: #2c2822}[data-theme=forest]{--bg: #101612;--surface: #161e18;--surface2: #1e281f;--surface3: #273329;--accent: #4caf72;--accent-2: #22c897;--accent-glow: rgba(76, 175, 114, .3);--accent-subtle: rgba(76, 175, 114, .08);--accent-bg: rgba(76, 175, 114, .25);--accent-glow-strong: rgba(76, 175, 114, .8);--text: #f0f5f0;--text-sec: #9ab8a2;--text-muted: #566858;--divider: #1e281f}*{box-sizing:border-box;margin:0;padding:0;font-family:Roboto,system-ui,-apple-system,sans-serif}html,body,#root{height:100%;background:var(--bg);color:var(--text);overflow:hidden}.app{position:relative;display:flex;flex-direction:column;height:100vh;height:100dvh;background:var(--bg);overflow:hidden}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100vh;background:var(--bg);color:var(--text-sec);font-size:1.1rem}.ios-install-sheet{position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--surface);border-top:1px solid var(--divider);border-radius:18px 18px 0 0;padding:20px 20px 32px;display:flex;flex-direction:column;align-items:center;gap:10px;box-shadow:0 -4px 32px #00000080;animation:ios-sheet-up .35s cubic-bezier(.32,.72,0,1) both}@keyframes ios-sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.ios-install-close{position:absolute;top:12px;right:14px;background:var(--surface2);border:none;color:var(--text-muted);font-size:.85rem;width:28px;height:28px;border-radius:50%;cursor:pointer;display:grid;place-items:center}.ios-install-icon{font-size:2rem;line-height:1}.ios-install-title{font-size:1.05rem;font-weight:700;color:var(--text)}.ios-install-subtitle{font-size:.8rem;color:var(--text-sec);text-align:center;max-width:280px}.ios-install-steps{display:flex;flex-direction:column;gap:10px;width:100%;max-width:320px;margin-top:4px}.ios-install-step{display:flex;align-items:center;gap:12px;font-size:.85rem;color:var(--text-sec);background:var(--surface2);border-radius:10px;padding:10px 14px}.ios-install-step strong{color:var(--text)}.ios-install-num{width:24px;height:24px;border-radius:50%;background:var(--accent);color:#000;font-size:.78rem;font-weight:700;display:grid;place-items:center;flex-shrink:0}.ios-share-glyph{font-size:1rem;color:var(--accent)}.ios-install-arrow{font-size:1.2rem;color:var(--accent);animation:ios-arrow-bounce 1.2s ease-in-out infinite}@keyframes ios-arrow-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}.splash-screen{position:fixed;inset:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;background:var(--bg, #1a1816);opacity:1;transition:opacity .6s ease;overflow:hidden}.splash-screen.splash-fading{opacity:0;pointer-events:none}.splash-bg-glow{position:absolute;width:min(340px,85vw);height:min(340px,85vw);border-radius:50%;background:radial-gradient(circle,var(--accent-glow, rgba(201,160,80,.25)) 0%,transparent 70%);animation:splash-pulse-glow 2.5s ease-in-out infinite;pointer-events:none}@keyframes splash-pulse-glow{0%,to{transform:scale(.9);opacity:.5}50%{transform:scale(1.2);opacity:1}}.splash-waves{position:relative;width:110px;height:110px;display:flex;align-items:center;justify-content:center}.splash-wave{position:absolute;border-radius:50%;border:2px solid var(--accent, #c9a050);opacity:0;animation:splash-ripple 2.4s ease-out infinite}.splash-wave-1{width:60px;height:60px;animation-delay:0s}.splash-wave-2{width:90px;height:90px;animation-delay:.6s}.splash-wave-3{width:120px;height:120px;animation-delay:1.2s}@keyframes splash-ripple{0%{transform:scale(.6);opacity:.9}to{transform:scale(1.4);opacity:0}}.splash-icon{font-size:2.8rem;color:var(--accent, #c9a050);animation:splash-icon-bounce 1.8s ease-in-out infinite;z-index:1;text-shadow:0 0 20px var(--accent-glow-strong, rgba(201,160,80,.8))}@keyframes splash-icon-bounce{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-6px) scale(1.08)}}.splash-brand{display:flex;flex-direction:column;align-items:center;gap:6px;animation:splash-fade-up .9s ease both;animation-delay:.3s}@keyframes splash-fade-up{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.splash-title{font-size:2.2rem;font-weight:700;letter-spacing:.04em;color:var(--text, #f0ece0);background:linear-gradient(135deg,var(--accent, #c9a050),var(--accent-2, #d4885a));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.splash-url{font-size:1rem;font-weight:500;color:var(--accent, #c9a050);letter-spacing:.06em;opacity:.85}.splash-tagline{font-size:.78rem;color:var(--text-sec, #b0a090);letter-spacing:.05em;opacity:.7}.splash-bars{display:flex;align-items:flex-end;gap:5px;height:28px;animation:splash-fade-up .9s ease both;animation-delay:.6s}.splash-bar{width:5px;border-radius:3px;background:var(--accent, #c9a050);opacity:.8}.splash-bar-1{animation:splash-soundbar 1.1s ease-in-out infinite;animation-delay:0s}.splash-bar-2{animation:splash-soundbar 1.1s ease-in-out infinite;animation-delay:.18s}.splash-bar-3{animation:splash-soundbar 1.1s ease-in-out infinite;animation-delay:.36s}.splash-bar-4{animation:splash-soundbar 1.1s ease-in-out infinite;animation-delay:.54s}.splash-bar-5{animation:splash-soundbar 1.1s ease-in-out infinite;animation-delay:.72s}@keyframes splash-soundbar{0%,to{height:6px}50%{height:26px}}.offline-banner{background:#b45309;color:#fff;text-align:center;font-size:.82rem;padding:6px 12px;z-index:100}.install-banner{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface2);border-bottom:1px solid var(--accent-glow);flex-shrink:0;z-index:50}.install-banner-icon{font-size:1.4rem;flex-shrink:0}.install-banner-text{display:flex;flex-direction:column;flex:1;min-width:0}.install-banner-title{font-size:.85rem;font-weight:600;color:var(--text)}.install-banner-sub{font-size:.75rem;color:var(--text-sec);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.install-banner-btn{flex-shrink:0;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border:none;border-radius:20px;padding:10px 16px;min-height:44px;font-size:.82rem;font-weight:600;cursor:pointer}.install-banner-close{flex-shrink:0;background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:10px;min-width:44px;min-height:44px;display:grid;place-items:center;line-height:1}.top-bar{height:var(--top-h);background:var(--surface);display:flex;align-items:center;padding:0 16px;gap:12px;border-bottom:1px solid var(--divider);flex-shrink:0;z-index:10}.top-bar-logo{width:32px;height:32px;background:linear-gradient(135deg,var(--accent),var(--accent-2));border-radius:8px;display:grid;place-items:center;font-size:18px;color:#fff;flex-shrink:0}.top-bar-title{font-size:1.1rem;font-weight:600;color:var(--text)}.top-bar-info-btn{background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;color:#fff;font-size:1.1rem;cursor:pointer;width:34px;height:34px;display:grid;place-items:center;border-radius:50%;transition:box-shadow .15s ease,transform .1s ease,opacity .15s ease;flex-shrink:0}.top-bar-info-btn:hover{box-shadow:0 0 10px var(--accent-glow);opacity:.9;transform:scale(1.08)}.top-bar-info-btn:active{transform:scale(.95);opacity:.8}.tab-content{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.song-list{padding-bottom:8px}.song-list-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 10px}.section-title{font-size:1.05rem;font-weight:700;color:var(--text)}.song-count{font-size:.82rem;color:var(--text-muted)}.search-bar{display:flex;align-items:center;gap:8px;margin:0 16px 10px;background:var(--surface2);border-radius:24px;padding:8px 14px}.search-icon{color:var(--text-muted);font-size:.9rem;flex-shrink:0}.search-input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:.9rem}.search-clear{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px 4px;font-size:.85rem}.scroll-top-btn{position:fixed;bottom:90px;right:16px;width:40px;height:40px;border-radius:50%;border:none;background:var(--accent, #7c3aed);color:#fff;font-size:1.2rem;line-height:1;cursor:pointer;display:grid;place-items:center;box-shadow:0 2px 8px #00000059;z-index:50;transition:opacity .2s,transform .2s}.scroll-top-btn:hover{opacity:.85;transform:translateY(-2px)}.search-highlight{background:#facc1559;color:inherit;border-radius:2px;padding:0 1px}.song-number{font-size:.72rem;color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:22px;text-align:right;flex-shrink:0}.song-item.active .song-number{color:var(--accent)}.song-item{display:flex;align-items:center;gap:12px;padding:9px 16px;cursor:pointer;border-bottom:1px solid var(--divider);transition:background .12s ease;-webkit-user-select:none;user-select:none}.song-item:active,.song-item:hover{background:var(--surface2)}.song-item.active{background:linear-gradient(90deg,var(--accent-subtle),transparent);border-left:2px solid var(--accent)}.song-item.active .song-title{color:var(--accent)}.song-thumb{width:46px;height:46px;border-radius:6px;background:var(--surface3);background-size:cover;background-position:center;flex-shrink:0;display:grid;place-items:center;font-size:12px;color:var(--text-muted);font-family:monospace;overflow:hidden}.song-item.active .song-thumb{border:2px solid var(--accent);box-shadow:0 0 10px var(--accent-glow)}.song-thumb-playing{display:flex;align-items:flex-end;gap:2px;height:18px}.eq-bar{width:3px;border-radius:2px;background:var(--accent);animation:eq-bounce .7s ease-in-out infinite alternate}.eq-bar:nth-child(1){height:8px;animation-delay:0s}.eq-bar:nth-child(2){height:14px;animation-delay:.2s}.eq-bar:nth-child(3){height:10px;animation-delay:.4s}@keyframes eq-bounce{0%{transform:scaleY(.4)}to{transform:scaleY(1)}}.song-info{flex:1;min-width:0}.song-title{font-size:.92rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-meta{font-size:.78rem;color:var(--text-sec);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-duration{font-size:.78rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.song-play-count{display:flex;align-items:center;gap:3px;flex-shrink:0;color:var(--accent);opacity:.75;font-size:.72rem;font-variant-numeric:tabular-nums}.song-play-count-icon{font-size:.6rem;opacity:.8}.song-play-count-num{font-weight:600;letter-spacing:.01em}.song-number.rank-top{font-weight:700;font-size:.85rem;min-width:20px}.song-number.rank-1{color:#f5c542}.song-number.rank-2{color:silver}.song-number.rank-3{color:#cd7f32}.help-overlay{position:absolute;inset:0;z-index:120;background:var(--bg);display:flex;flex-direction:column;overflow:hidden}.help-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--divider);flex-shrink:0}.help-overlay-title{font-size:1.05rem;font-weight:700;color:var(--text)}.help-overlay-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:14px;-webkit-overflow-scrolling:touch}.help-section{background:var(--surface);border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:8px}.help-section-icon{font-size:1.8rem;line-height:1}.help-section-title{font-size:.98rem;font-weight:700;color:var(--text)}.help-section-desc{font-size:.83rem;color:var(--text-sec);line-height:1.55;margin:0}.help-graphic{margin-top:4px;display:flex;flex-direction:column;gap:10px}.help-tabs-demo{display:flex;background:var(--surface2);border-radius:10px;overflow:hidden}.help-tab-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;opacity:.45}.help-tab-item.help-tab-active{opacity:1;border-bottom:2px solid var(--accent)}.help-tab-icon{font-size:1rem}.help-tab-label{font-size:.6rem;color:var(--text-sec)}.help-tab-item.help-tab-active .help-tab-label{color:var(--accent)}.help-tabs-descriptions{display:flex;flex-direction:column;gap:6px}.help-tabs-row{display:flex;align-items:baseline;gap:8px;font-size:.8rem}.help-tabs-row-name{font-weight:700;color:var(--accent);white-space:nowrap;min-width:80px}.help-tabs-row-desc{color:var(--text-sec)}.help-controls-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.help-control-card{background:var(--surface2);border-radius:10px;padding:10px 6px;display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center}.help-control-icon{font-size:1.3rem}.help-control-name{font-size:.68rem;font-weight:700;color:var(--text)}.help-control-desc{font-size:.6rem;color:var(--text-muted);line-height:1.3}.help-miniplayer-demo{display:flex;align-items:center;gap:10px;background:var(--surface2);border-radius:10px;padding:10px 14px}.help-mini-art{width:36px;height:36px;border-radius:6px;background:var(--accent-bg);display:grid;place-items:center;font-size:1rem;color:var(--accent);flex-shrink:0}.help-mini-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.help-mini-title{font-size:.78rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.help-mini-sub{font-size:.68rem;color:var(--text-muted)}.help-mini-btn{font-size:1.1rem;color:var(--text-sec);flex-shrink:0}.help-mini-play{color:var(--text);font-size:1.3rem}.help-graphic-caption{font-size:.78rem;color:var(--text-sec);margin:0;line-height:1.5}.help-themes-row{display:flex;gap:10px}.help-theme-chip{flex:1;border-radius:10px;border:1.5px solid;padding:10px 8px;display:flex;flex-direction:column;align-items:center;gap:6px}.help-theme-dot{width:22px;height:22px;border-radius:50%}.help-theme-name{font-size:.72rem;font-weight:700}.popular-tab{display:flex;flex-direction:column}.popular-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 8px;flex-shrink:0}.now-playing{display:flex;flex-direction:column;align-items:center;padding:16px 20px 12px;gap:0;height:100%;overflow-y:auto}.np-ring-wrapper{position:relative;width:240px;height:240px;flex-shrink:0;margin-bottom:6px;cursor:pointer;-webkit-tap-highlight-color:transparent}.np-ring-svg{position:absolute;inset:0;width:240px;height:240px;transform:rotate(-90deg)}.np-ring-track{fill:none;stroke:var(--surface3);stroke-width:4}.np-ring-fill{fill:none;stroke:url(#ringGradient);stroke-width:4;stroke-linecap:round;transition:stroke-dashoffset .3s linear}.np-ring-thumb{fill:#fff;filter:drop-shadow(0 0 4px var(--accent-glow-strong));cursor:pointer}.np-artwork-circle{position:absolute;inset:18px;border-radius:50%;background-size:cover;background-position:center;background-color:var(--surface3);overflow:hidden;pointer-events:none;user-select:none;-webkit-user-select:none}.np-artwork-circle:before{content:"";position:absolute;inset:0;border-radius:50%;background-image:conic-gradient(from 0deg,#ff505059,#ffc83252,#50ff7852,#32c8ff59,#7850ff52,#ff3cc852,#ff505059 360deg);mix-blend-mode:screen;pointer-events:none}.np-artwork-circle:after{content:"";position:absolute;width:8%;height:8%;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;background:#111;box-shadow:0 0 0 1.5px #ffffff40,inset 0 0 4px #000000e6}.np-artwork-circle.playing{animation:spin-slow 15s linear infinite}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.np-ring-time-left,.np-ring-time-right{position:absolute;bottom:2px;font-size:.72rem;color:var(--text-sec);pointer-events:none}.np-ring-time-left{left:8px}.np-ring-time-right{right:8px}.np-actions{display:flex;align-items:center;justify-content:center;gap:10px;margin:8px 0;width:100%}.np-action-btn{width:44px;height:44px;border-radius:50%;border:none;background:var(--surface2);color:var(--text-sec);font-size:1.2rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background .15s,color .15s;position:relative;flex-shrink:0}.np-action-btn:hover{background:var(--surface3)}.np-action-btn.active{color:#ec4899}.np-fav-count{position:absolute;top:2px;right:2px;font-size:9px;background:var(--accent);color:#fff;border-radius:50%;width:14px;height:14px;display:grid;place-items:center;pointer-events:none}.np-viz{position:relative;width:100%;max-width:320px;height:60px;margin:4px 0;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:8px;-webkit-tap-highlight-color:transparent}.viz-mode-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--accent-glow-strong);color:#fff;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 14px;border-radius:20px;pointer-events:none;z-index:10;animation:viz-label-pop 1.6s ease forwards}@keyframes viz-label-pop{0%{opacity:0;transform:translate(-50%,-50%) scale(.7)}15%{opacity:1;transform:translate(-50%,-50%) scale(1)}70%{opacity:1}to{opacity:0}}.viz{width:100%;height:100%;display:flex;align-items:flex-end;justify-content:center;gap:2px}.viz-bars{align-items:flex-end}.viz-bar{flex:1;border-radius:2px 2px 0 0;transform:scaleY(.12);transform-origin:bottom;opacity:.7}.viz-bar.playing{animation:viz-bar-bounce .65s ease-in-out infinite alternate;opacity:1}@keyframes viz-bar-bounce{0%{transform:scaleY(.12)}to{transform:scaleY(1)}}.viz-wave{align-items:center;overflow:hidden}.viz-dots{display:grid;grid-template-columns:repeat(12,8px);grid-template-rows:repeat(4,8px);gap:4px;align-items:center;justify-content:center}.viz-dot{width:8px;height:8px;border-radius:50%;transform:scale(.25);opacity:.4}.viz-dot.playing{animation:viz-dot-pulse .75s ease-in-out infinite alternate}@keyframes viz-dot-pulse{to{transform:scale(1);opacity:1}}.viz-mirror{align-items:center;gap:2px}.viz-mirror-col{display:flex;flex-direction:column;align-items:center;height:100%;justify-content:center}.viz-mirror-top{width:5px;border-radius:3px 3px 0 0;transform:scaleY(.12);transform-origin:bottom center;opacity:.7}.viz-mirror-bot{width:5px;border-radius:0 0 3px 3px;transform:scaleY(.12);transform-origin:top center;opacity:.7}.viz-mirror-top.playing,.viz-mirror-bot.playing{animation:viz-bar-bounce .65s ease-in-out infinite alternate;opacity:1}.viz-rings{position:relative;overflow:hidden}.viz-ring{position:absolute;top:50%;left:50%;width:24px;height:24px;border-radius:50%;border:2px solid;transform:translate(-50%,-50%) scale(0);opacity:0}.viz-ring.playing{animation:viz-ring-expand 2.4s ease-out infinite}@keyframes viz-ring-expand{0%{transform:translate(-50%,-50%) scale(.1);opacity:.9}to{transform:translate(-50%,-50%) scale(5);opacity:0}}.np-info{text-align:center;width:100%;max-width:300px;margin:6px 0 4px}.np-title{font-size:.8rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.np-artist{font-size:.85rem;color:var(--text-sec);margin-top:3px}.np-error{background:#ef444426;color:#fca5a5;font-size:.78rem;padding:6px 12px;border-radius:8px;text-align:center;width:100%;max-width:300px}.np-controls{display:flex;align-items:center;justify-content:center;gap:14px;margin:6px 0}.np-btn{background:none;border:none;color:var(--text-sec);cursor:pointer;display:grid;place-items:center;border-radius:50%;transition:color .15s,background .15s}.np-btn:hover{color:var(--text)}.np-prev,.np-next{width:44px;height:44px;font-size:1.6rem}.np-extra-sm{width:36px;height:36px;font-size:1.6rem}.np-extra-sm.active{color:var(--accent)}.np-play{width:64px;height:64px;font-size:1.6rem;color:var(--text);position:relative;isolation:isolate;border-radius:50%;background:var(--surface2)}.np-play:before{content:"";position:absolute;inset:-3px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));z-index:-1}.np-play:hover{background:var(--surface3)}.np-bottom-row{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;max-width:340px;margin:6px 0 4px}.np-bottom-btn{background:var(--surface2);border:none;border-radius:20px;color:var(--text-sec);font-size:.78rem;padding:5px 10px;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s;flex-shrink:0}.np-bottom-btn.active{background:var(--accent-bg);color:var(--accent)}.np-bottom-btn:hover{background:var(--surface3);color:var(--text)}.np-volume-slider{flex:1;accent-color:var(--accent);height:4px;cursor:pointer;min-width:0}.fav-select{position:relative;flex-shrink:0}.fav-select-btn{display:flex;align-items:center;gap:6px;background:var(--surface2);border:1px solid var(--divider);border-radius:10px;color:var(--text-sec);font-size:.82rem;padding:7px 12px;cursor:pointer;white-space:nowrap;max-width:160px;min-width:90px;transition:border-color .15s,background .15s;overflow:hidden}.fav-select-btn span:first-child{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.fav-select-btn.open,.fav-select-btn:hover{border-color:var(--accent);background:var(--surface3);color:var(--text)}.fav-select-arrow{font-size:.65rem;opacity:.7;flex-shrink:0}.fav-select-list{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--surface2);border:1px solid var(--accent);border-radius:10px;padding:4px 0;list-style:none;z-index:200;box-shadow:0 8px 24px #00000080;min-width:140px}.fav-select-option{padding:9px 14px;font-size:.85rem;color:var(--text-sec);cursor:pointer;transition:background .1s,color .1s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fav-select-option:hover{background:var(--surface3);color:var(--text)}.fav-select-option.active{color:var(--accent);font-weight:600}.mini-player{position:relative;height:var(--mini-h);background:var(--surface);border-top:1px solid var(--divider);cursor:pointer;flex-shrink:0;z-index:20}.mini-progress{position:absolute;top:0;left:0;right:0;height:2px;background:var(--divider)}.mini-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .5s linear}.mini-content{display:flex;align-items:center;gap:10px;padding:0 16px;height:100%}.mini-artwork{width:42px;height:42px;border-radius:50%;background:var(--surface3);background-size:cover;background-position:center;flex-shrink:0;border:1.5px solid var(--accent)}.mini-info{flex:1;min-width:0}.mini-title{font-size:.88rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-artist{font-size:.75rem;color:var(--text-sec);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-controls{display:flex;align-items:center;gap:4px}.mini-btn{background:none;border:none;color:var(--text-sec);font-size:1.15rem;cursor:pointer;width:44px;height:44px;display:grid;place-items:center;border-radius:50%;transition:color .15s}.mini-btn:hover{color:var(--text)}.mini-play{font-size:1.3rem;color:var(--text)}.mini-spinner{width:18px;height:18px;border:2px solid var(--surface3);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.bottom-nav{height:var(--nav-h);background:var(--surface);display:flex;align-items:center;border-top:1px solid var(--divider);flex-shrink:0;z-index:20}.nav-tab{flex:1;background:none;border:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--text-muted);cursor:pointer;height:100%;transition:color .15s;padding:0}.nav-tab.active{color:var(--accent)}.nav-tab-icon{font-size:1.25rem;line-height:1}.nav-tab-label{font-size:.68rem;letter-spacing:.02em}.nav-back-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;height:100%;padding:0 14px;font-size:1.7rem;line-height:1;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .15s,opacity .15s}.nav-back-btn:not(:disabled):active{color:var(--accent)}.nav-back-btn:disabled{opacity:.2;cursor:default}.genres-grid{padding:16px;display:flex;flex-direction:column;gap:8px}.genres-actions{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.genre-card{display:flex;align-items:center;gap:14px;background:var(--surface);border-radius:12px;padding:12px 16px;cursor:pointer;border:1px solid var(--divider);transition:border-color .15s,background .15s}.genre-card:hover,.genre-card.active{border-color:var(--accent);background:var(--accent-subtle)}.genre-card-icon{width:48px;height:48px;border-radius:10px;background:var(--surface2);background-size:cover;background-position:center;display:grid;place-items:center;font-size:1.4rem;color:var(--accent);flex-shrink:0}.genre-card-info{flex:1}.genre-card-name{font-size:.95rem;font-weight:600;color:var(--text)}.genre-card-count{font-size:.78rem;color:var(--text-muted);margin-top:2px}.groups-grid{padding:16px;display:grid;grid-template-columns:1fr 1fr;gap:12px}.groups-grid-header{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between}.group-card{display:flex;flex-direction:column;align-items:stretch;background:var(--surface);border-radius:16px;border:1px solid var(--divider);overflow:hidden;cursor:pointer;transition:border-color .15s,background .15s}.group-card:hover{border-color:var(--accent);background:var(--accent-subtle)}.group-card-artwork{width:100%;aspect-ratio:1 / 1;background:linear-gradient(135deg,var(--surface3),var(--surface2));background-size:cover;background-position:center;display:grid;place-items:center}.group-card-artwork-icon{font-size:2.4rem;color:var(--accent);opacity:.6}.group-card-name{font-size:.92rem;font-weight:700;color:var(--text);padding:8px 8px 2px;text-align:center}.group-card-meta{font-size:.72rem;color:var(--text-muted);padding:0 8px 10px;text-align:center}.back-btn{background:none;border:none;color:var(--accent);font-size:.9rem;font-weight:600;cursor:pointer;padding:4px 0;flex-shrink:0}.favorites-tab{height:100%;display:flex;flex-direction:column}.favorites-header{padding:16px 16px 12px;border-bottom:1px solid var(--divider);display:flex;flex-direction:column;gap:10px;flex-shrink:0}.favorites-header-top{display:flex;align-items:center;justify-content:space-between}.favorites-header-bottom{display:flex;align-items:center;gap:10px}.fav-manage-icon-btn{background:var(--surface2);border:none;border-radius:8px;color:var(--text-muted);font-size:.78rem;padding:6px 12px;cursor:pointer;display:flex;align-items:center;gap:5px;transition:background .15s,color .15s}.fav-manage-icon-btn:hover{background:var(--surface3);color:var(--accent)}.fav-track-count{font-size:.78rem;color:var(--text-muted);margin-left:auto}.empty-state-hint{font-size:.8rem;color:var(--text-muted);text-align:center;max-width:220px;line-height:1.4}.manage-btn{background:var(--surface2);border:none;border-radius:8px;color:var(--text-sec);font-size:1rem;width:44px;height:44px;cursor:pointer;display:grid;place-items:center;transition:background .15s,color .15s}.manage-btn:hover{background:var(--surface3);color:var(--accent)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:200px;color:var(--text-muted)}.empty-state-icon{font-size:2.5rem;opacity:.4}.empty-state-text{font-size:.95rem}.about-overlay{position:absolute;inset:0;z-index:100;background:var(--bg);display:flex;flex-direction:column;animation:slide-up .2s ease}.about-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--divider)}.about-overlay-title{font-size:1.05rem;font-weight:700;color:var(--text)}.about-overlay-close{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;width:36px;height:36px;display:grid;place-items:center;border-radius:50%}.about-overlay-close:hover{background:var(--surface2);color:var(--text)}.about-overlay-body{flex:1;overflow-y:auto;padding:24px 20px;display:flex;flex-direction:column;align-items:center;gap:12px}.about-app-logo{font-size:3rem;color:var(--accent)}.about-app-name{font-size:1.3rem;font-weight:700;color:var(--text)}.about-app-desc{font-size:.9rem;color:var(--text-sec);text-align:center}.about-card{width:100%;max-width:320px;background:var(--surface);border-radius:12px;overflow:hidden;margin-top:8px;border:1px solid var(--divider)}.about-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--divider)}.about-row:last-child{border-bottom:none}.about-label{font-size:.85rem;color:var(--text-muted)}.about-value{font-size:.85rem;color:var(--text);font-weight:500}.about-link{font-size:.85rem;color:var(--accent);text-decoration:none}.manage-overlay{position:absolute;inset:0;z-index:100;background:var(--bg);display:flex;flex-direction:column;animation:slide-up .2s ease}.manage-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--divider)}.manage-overlay-title{font-size:1.05rem;font-weight:700;color:var(--text)}.manage-overlay-close{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;width:36px;height:36px;display:grid;place-items:center;border-radius:50%}.manage-overlay-close:hover{background:var(--surface2);color:var(--text)}.manage-overlay-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}.manage-overlay-actions{display:flex;gap:10px;margin-bottom:4px;flex-wrap:wrap}.manage-new-btn{background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;border-radius:8px;color:#fff;font-size:.85rem;padding:8px 14px;cursor:pointer;font-weight:600}.manage-list-item{background:var(--surface);border-radius:10px;padding:10px 14px;display:flex;align-items:center;gap:10px;border:1px solid var(--divider)}.manage-list-name{flex:1;font-size:.92rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.manage-list-count{font-size:.78rem;color:var(--text-muted);flex-shrink:0}.manage-list-btn{background:var(--surface2);border:none;border-radius:6px;color:var(--text-sec);font-size:.78rem;padding:4px 8px;cursor:pointer;flex-shrink:0}.manage-list-btn:hover{background:var(--surface3);color:var(--text)}.manage-list-btn.danger:hover{background:#ef444433;color:#f87171}.manage-rename-input{flex:1;background:var(--surface2);border:1px solid var(--accent);border-radius:6px;color:var(--text);font-size:.88rem;padding:4px 8px;outline:none}.delete-confirm-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#ef44441f;border-bottom:1px solid rgba(239,68,68,.25);flex-shrink:0}.delete-confirm-msg{flex:1;font-size:.88rem;color:#fca5a5}.manage-favs-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}.manage-fav-row{background:var(--surface);border:1px solid var(--divider);border-radius:14px;padding:14px 16px;display:flex;align-items:center;gap:10px;transition:border-color .15s}.manage-fav-row.active{border-color:var(--accent);background:var(--accent-subtle)}.manage-fav-info{flex:1;min-width:0;cursor:pointer}.manage-fav-name{display:block;font-size:.95rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.manage-fav-row.active .manage-fav-name{color:var(--accent)}.manage-fav-count{display:inline-block;margin-top:4px;font-size:.75rem;color:var(--text-muted);background:var(--surface2);border-radius:20px;padding:2px 8px}.manage-fav-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.manage-fav-action{width:36px;height:36px;border-radius:10px;border:none;background:var(--surface2);color:var(--text-sec);font-size:1rem;cursor:pointer;display:grid;place-items:center;transition:background .15s,color .15s;flex-shrink:0}.manage-fav-action:hover{background:var(--surface3);color:var(--text)}.manage-fav-action:disabled{opacity:.3;cursor:not-allowed}.manage-fav-action.danger:hover{background:#ef444433;color:#f87171}.manage-fav-rename{flex:1;display:flex;align-items:center;gap:8px}.manage-fav-input{flex:1;background:var(--surface2);border:1px solid var(--accent);border-radius:10px;color:var(--text);font-size:.9rem;padding:8px 12px;outline:none;min-width:0}.manage-fav-input::placeholder{color:var(--text-muted)}.manage-fav-create{display:flex;align-items:center;gap:10px;margin-top:4px;padding:14px 16px;background:var(--surface);border:1px dashed var(--divider);border-radius:14px}.manage-fav-create-btn{background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;border-radius:10px;color:#fff;font-size:.85rem;font-weight:600;padding:8px 16px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:opacity .15s}.manage-fav-create-btn:disabled{opacity:.4;cursor:not-allowed}.loading-spinner{width:40px;height:40px;border:3px solid var(--surface2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.np-spinner{width:22px;height:22px;border:2px solid var(--surface3);border-top-color:var(--text);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.refresh-btn{background:var(--surface2);border:none;border-radius:8px;color:var(--text-sec);font-size:.82rem;padding:6px 12px;cursor:pointer;transition:background .15s,color .15s}.refresh-btn:hover{background:var(--surface3);color:var(--text)}@keyframes slide-up{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.share-toast{position:fixed;bottom:calc(var(--mini-h) + var(--nav-h) + 16px);left:50%;transform:translate(-50%);background:var(--surface3);color:var(--text);font-size:.82rem;font-weight:500;padding:9px 20px;border-radius:24px;white-space:nowrap;z-index:300;box-shadow:0 4px 16px #0006;animation:toast-pop .2s ease;pointer-events:none}@keyframes toast-pop{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.settings-body{flex:1;overflow-y:auto;padding:20px 16px;display:flex;flex-direction:column;gap:24px}.settings-section-label{font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px}.settings-theme-row{display:flex;gap:12px}.settings-theme-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;background:none;border:2px solid var(--divider);border-radius:14px;padding:10px 8px;cursor:pointer;transition:border-color .15s,background .15s;position:relative}.settings-theme-card:hover,.settings-theme-card.active{border-color:var(--accent);background:var(--surface2)}.settings-theme-preview{width:100%;height:60px;border-radius:8px;overflow:hidden;display:flex;align-items:flex-end;padding:8px;gap:4px;flex-direction:column;justify-content:flex-end}.stp-bar{height:6px;border-radius:3px;width:70%}.stp-bar-2{width:45%}.settings-theme-name{font-size:.8rem;font-weight:600;color:var(--text-sec)}.settings-theme-card.active .settings-theme-name{color:var(--accent)}.settings-quit-section{margin-top:8px;display:flex;flex-direction:column;align-items:center;gap:8px}.settings-quit-btn{width:100%;padding:13px;background:none;border:1.5px solid rgba(239,68,68,.45);border-radius:10px;color:#f87171;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s;letter-spacing:.03em}.settings-quit-btn:hover,.settings-quit-btn:active{background:#ef44441f;border-color:#f87171}.settings-quit-hint{font-size:.72rem;color:var(--text-muted);text-align:center;margin:0}.settings-theme-tick{position:absolute;top:7px;right:9px;font-size:.75rem;color:var(--accent);font-weight:700}@media(max-width:390px){.top-bar{padding:0 8px;gap:6px}.top-bar-title{font-size:1rem}.top-bar-subtitle{font-size:.7rem}.np-ring-wrapper,.np-ring-svg{width:200px;height:200px}.nav-tab-label{font-size:.62rem}.viz-dots{grid-template-columns:repeat(8,8px)}.splash-title{font-size:1.8rem}.manage-list-btn{padding:6px 10px;min-height:32px}}@media(max-width:480px){.np-ring-wrapper,.np-ring-svg{width:min(220px,58vw);height:min(220px,58vw)}.install-banner{flex-wrap:wrap}.song-item{padding:8px 12px;gap:10px}.fav-select-btn{max-width:140px}}.top-bar-quit-btn{color:#f87171;border-color:transparent;background:transparent}.top-bar-quit-btn:hover{background:#ef44441f;border-color:#f87171;color:#f87171}.top-bar-login-btn{color:var(--text-muted);border-color:transparent;background:transparent}.top-bar-login-btn--active{color:var(--accent);border-color:var(--accent-bg);background:var(--accent-subtle)}.login-overlay{position:fixed;top:var(--top-h);right:12px;width:260px;background:var(--surface2);border:1px solid var(--divider);border-radius:16px;box-shadow:0 8px 32px #00000073;z-index:200;overflow:hidden}.login-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--divider)}.login-overlay-title{font-size:.95rem;font-weight:700;color:var(--text)}.login-overlay-close{background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;line-height:1;padding:2px 4px}.login-overlay-close:hover{color:var(--text)}.login-overlay-body{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px 20px 24px}.login-avatar{width:64px;height:64px;border-radius:50%;background:var(--accent-subtle);border:2px solid var(--accent-bg);display:grid;place-items:center;color:var(--accent);margin-bottom:4px}.login-welcome{font-size:.9rem;color:var(--text-sec);text-align:center}.login-input{width:100%;background:var(--surface3);border:1px solid var(--divider);border-radius:8px;color:var(--text);font-size:.9rem;padding:9px 12px;outline:none;transition:border-color .15s;box-sizing:border-box}.login-input:focus{border-color:var(--accent)}.login-input::placeholder{color:var(--text-muted)}.login-error{font-size:.78rem;color:#f44336;text-align:center}.login-submit-btn{width:100%;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;padding:10px;cursor:pointer;transition:opacity .15s}.login-submit-btn:hover{opacity:.88}.login-logout-btn{background:var(--surface3);color:var(--text-sec);border:1px solid var(--divider)}.login-logout-btn:hover{background:var(--divider);opacity:1}@media(max-height:500px)and (orientation:landscape){:root{--top-h: 44px;--mini-h: 56px;--nav-h: 50px}.np-ring-wrapper,.np-ring-svg{width:160px;height:160px}.nav-tab-label{display:none}.nav-tab{gap:0}}
