.auth-page[data-v-6b161333]{display:flex;align-items:center;justify-content:center;height:100%;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-tertiary) 100%);padding:20px}.auth-container[data-v-6b161333]{width:100%;max-width:400px}.logo[data-v-6b161333]{text-align:center;margin-bottom:40px}.logo h1[data-v-6b161333]{font-size:36px;margin:0;color:var(--text-primary);display:flex;align-items:center;justify-content:center;gap:10px}.logo-icon[data-v-6b161333]{width:40px;height:40px;border-radius:8px}.form[data-v-6b161333]{background:var(--card-bg);padding:30px;border-radius:12px;box-shadow:0 8px 24px var(--shadow-color)}.form h2[data-v-6b161333]{margin-top:0;margin-bottom:20px;font-size:24px;color:var(--text-primary)}.form-group[data-v-6b161333]{margin-bottom:16px}.input[data-v-6b161333]{width:100%;padding:12px 16px;border:none;border-radius:8px;background:var(--input-bg);color:var(--text-primary);font-size:14px;box-sizing:border-box;transition:background-color .2s}.input[data-v-6b161333]:focus{outline:none;background:var(--input-bg-focus)}.input[data-v-6b161333]::placeholder{color:var(--text-secondary)}.error-text[data-v-6b161333]{display:block;color:#f44;font-size:12px;margin-top:4px}.success-text[data-v-6b161333]{display:block;color:#1db954;font-size:12px;margin-top:4px}.btn[data-v-6b161333]{width:100%;padding:12px 16px;border:none;border-radius:24px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary[data-v-6b161333]{background:var(--text-primary);color:var(--bg-primary)}.btn-primary[data-v-6b161333]:hover:not(:disabled){background:#e0e0e0;transform:scale(1.02)}.btn[data-v-6b161333]:disabled{opacity:.5;cursor:not-allowed}.error[data-v-6b161333]{color:#f44;font-size:14px;margin:16px 0 0;text-align:center}.toggle-text[data-v-6b161333]{text-align:center;margin-top:20px;color:var(--text-secondary);font-size:14px}.link-btn[data-v-6b161333]{background:none;border:none;color:var(--text-primary);cursor:pointer;font-weight:600;padding:0}.link-btn[data-v-6b161333]:hover{text-decoration:underline}.modal-overlay[data-v-6b161333]{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--modal-overlay);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content[data-v-6b161333]{background:var(--card-bg);padding:30px;border-radius:12px;max-width:400px;text-align:center}.code-input-wrapper[data-v-6b161333]{margin:16px 0 8px}.code-input[data-v-6b161333]{text-align:center;font-size:24px;letter-spacing:8px;font-weight:600}.modal-content h3[data-v-6b161333]{margin-top:0;margin-bottom:16px;color:var(--text-primary)}.modal-content p[data-v-6b161333]{margin:12px 0;color:var(--text-secondary);line-height:1.5}.modal-content strong[data-v-6b161333]{color:var(--text-primary)}.recommendations[data-v-a4ec15be]{width:100%;height:100%;overflow-y:auto}.content[data-v-a4ec15be]{padding:16px}.recommendation-block[data-v-a4ec15be]{background:var(--bg-tertiary);border-radius:12px;padding:20px;margin-bottom:16px;text-align:center}.recommendation-block h2[data-v-a4ec15be]{margin:0 0 16px;font-size:20px;color:var(--text-primary)}.categories[data-v-a4ec15be]{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:20px}.category-chip[data-v-a4ec15be]{padding:6px 16px;border-radius:20px;border:1.5px solid var(--border-color, rgba(255,255,255,.15));background:transparent;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .18s;outline:none}.category-chip[data-v-a4ec15be]:hover{border-color:var(--text-primary);color:var(--text-primary)}.category-chip.active[data-v-a4ec15be]{background:var(--text-primary);border-color:var(--text-primary);color:var(--bg-primary);font-weight:600}.description[data-v-a4ec15be]{margin:12px 0 0;color:var(--text-secondary);font-size:14px}.description.hint[data-v-a4ec15be]{font-style:italic;opacity:.7}.play-btn[data-v-a4ec15be]{width:56px;height:56px;border-radius:50%;background:var(--text-primary);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;margin:0 auto;transition:all .2s;outline:none;color:var(--bg-primary)}.play-btn[data-v-a4ec15be]:hover{background:var(--btn-contrast-hover);transform:scale(1.05)}.play-btn[data-v-a4ec15be]:active,.play-btn[data-v-a4ec15be]:focus{outline:none!important}.play-btn[data-v-a4ec15be]:disabled{opacity:.7;cursor:wait}@keyframes spin-a4ec15be{to{transform:rotate(360deg)}}.spin[data-v-a4ec15be]{animation:spin-a4ec15be 1s linear infinite}.track-menu-overlay[data-v-79576543]{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200}.track-menu[data-v-79576543]{position:fixed;min-width:220px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 18px 40px #00000059;overflow:hidden}.track-menu-item[data-v-79576543]{width:100%;display:flex;align-items:center;gap:10px;padding:12px 14px;border:none;background:transparent;color:var(--text-primary);cursor:pointer;font-size:14px}.track-menu-item[data-v-79576543]:hover{background:var(--overlay-light)}.track-menu-item-danger[data-v-79576543]{color:#e05252}.track-menu-item-danger[data-v-79576543]:hover{background:#e052521f}.submenu-arrow[data-v-79576543]{margin-left:auto;transition:transform .2s;flex-shrink:0}.submenu-arrow.open[data-v-79576543]{transform:rotate(180deg)}.playlist-picker[data-v-79576543]{border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);max-height:200px;overflow-y:auto;background:var(--bg-primary)}.playlist-picker-loading[data-v-79576543],.playlist-picker-empty[data-v-79576543]{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 14px;font-size:13px;color:var(--text-secondary)}.playlist-picker-item[data-v-79576543]{padding-left:24px;font-size:13px;color:var(--text-secondary)}.playlist-picker-item[data-v-79576543]:hover{color:var(--text-primary)}.spin[data-v-79576543]{animation:spin-79576543 .8s linear infinite}@keyframes spin-79576543{to{transform:rotate(360deg)}}.track-row[data-v-9c4dfc7c]{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;cursor:pointer;transition:background .15s,color .15s;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;touch-action:pan-y;content-visibility:auto;contain-intrinsic-size:0 56px}.track-row[data-v-9c4dfc7c]:focus,.track-row[data-v-9c4dfc7c]:focus-visible,.track-row[data-v-9c4dfc7c]:active{outline:none}.track-row[data-v-9c4dfc7c]:hover{background:var(--overlay-light)}.track-row.current[data-v-9c4dfc7c]{background:color-mix(in srgb,var(--accent-color) 16%,transparent)}.track-row.context-open[data-v-9c4dfc7c]{background:var(--overlay-light);outline:1px solid color-mix(in srgb,var(--accent-color) 40%,transparent);outline-offset:-1px}.track-row.compact[data-v-9c4dfc7c]{padding:8px 10px}.track-cover[data-v-9c4dfc7c]{flex-shrink:0;border-radius:8px;overflow:hidden;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center}.track-cover-img[data-v-9c4dfc7c]{width:100%;height:100%;object-fit:cover}.track-cover-placeholder[data-v-9c4dfc7c]{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--text-secondary)}.track-info[data-v-9c4dfc7c]{flex:1;min-width:0}.track-title[data-v-9c4dfc7c]{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-artist[data-v-9c4dfc7c]{margin-top:2px;font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-meta[data-v-9c4dfc7c]{display:flex;align-items:center;gap:8px;flex-shrink:0;color:var(--text-secondary)}.track-quality-inline[data-v-9c4dfc7c],.track-duration[data-v-9c4dfc7c]{font-size:12px}.meta-icon[data-v-9c4dfc7c]{opacity:.9}.spin[data-v-9c4dfc7c]{animation:track-item-spin-9c4dfc7c 1s linear infinite}@keyframes track-item-spin-9c4dfc7c{to{transform:rotate(360deg)}}@media (max-width: 375px){.track-quality-inline[data-v-9c4dfc7c]{display:none}}@media (max-width: 768px){.track-row[data-v-9c4dfc7c]{gap:14px;padding:14px 16px;border-radius:14px;contain-intrinsic-size:0 72px}.track-title[data-v-9c4dfc7c]{font-size:15px}.track-artist[data-v-9c4dfc7c],.track-quality-inline[data-v-9c4dfc7c],.track-duration[data-v-9c4dfc7c]{font-size:13px}}.search-tab[data-v-7b36e164]{width:100%;overflow-y:auto;padding:0}.search-container[data-v-7b36e164]{display:flex;gap:8px;padding:16px;background:var(--bg-secondary);position:sticky;top:0;z-index:10;border-bottom:1px solid var(--border-color)}.search-input[data-v-7b36e164]{flex:1;padding:12px 16px;border:1px solid var(--border-color);border-radius:24px;background:var(--bg-tertiary);color:var(--text-primary);font-size:14px;outline:none;transition:border-color .2s}.search-input[data-v-7b36e164]::placeholder{color:var(--text-secondary)}.search-input[data-v-7b36e164]:focus{border-color:var(--text-primary)}.search-btn[data-v-7b36e164]{width:44px;height:44px;border:none;background:var(--text-primary);border-radius:50%;color:var(--bg-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0;flex-shrink:0;outline:none}.search-btn[data-v-7b36e164]:hover{background:var(--btn-contrast-hover);transform:scale(1.05)}.search-btn[data-v-7b36e164]:active,.search-btn[data-v-7b36e164]:focus{outline:none!important}.filter-buttons[data-v-7b36e164]{display:flex;gap:8px;padding:12px 16px;background:var(--bg-primary);border-bottom:1px solid var(--border-color);overflow-x:auto;scroll-behavior:smooth}.filter-buttons[data-v-7b36e164]::-webkit-scrollbar{height:4px}.filter-buttons[data-v-7b36e164]::-webkit-scrollbar-thumb{background:var(--text-secondary);border-radius:2px}.filter-btn[data-v-7b36e164]{padding:8px 16px;border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0;outline:none}.filter-btn[data-v-7b36e164]:hover{border-color:var(--text-primary);color:var(--text-primary)}.filter-btn[data-v-7b36e164]:active,.filter-btn[data-v-7b36e164]:focus{outline:none!important}.filter-btn.active[data-v-7b36e164]{background:var(--text-primary);color:var(--bg-primary);border-color:var(--text-primary)}.recent-searches[data-v-7b36e164],.search-results[data-v-7b36e164]{padding:16px 16px 20px}.recent-searches h3[data-v-7b36e164]{margin:0 0 16px}section[data-v-7b36e164]{margin-bottom:24px}section h3[data-v-7b36e164]{margin:0 0 12px;font-size:16px;color:var(--text-primary);font-weight:600}.results-list[data-v-7b36e164]{display:flex;flex-direction:column;gap:8px}.tracks-list[data-v-7b36e164]{gap:4px}.result-item[data-v-7b36e164]{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-secondary);border-radius:8px;transition:background .2s;cursor:pointer}.result-item[data-v-7b36e164]:hover{background:var(--bg-tertiary)}.result-icon[data-v-7b36e164]{width:48px;height:48px;background:var(--bg-tertiary);border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0;overflow:hidden}.album-thumb[data-v-7b36e164]{width:100%;height:100%;object-fit:cover}.result-info[data-v-7b36e164]{flex:1;min-width:0}.result-name[data-v-7b36e164]{color:var(--text-primary);font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-meta[data-v-7b36e164]{color:var(--text-secondary);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:4px;display:flex;gap:8px;align-items:center}.result-meta span[data-v-7b36e164]:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis}.track-duration[data-v-7b36e164]{flex-shrink:0;font-weight:600;opacity:.9}.track-quality[data-v-7b36e164]{flex-shrink:0;font-size:11px;opacity:.7}.play-btn[data-v-7b36e164]{width:36px;height:36px;border:none;background:var(--text-primary);color:var(--bg-primary);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;padding:0;outline:none}.play-btn[data-v-7b36e164]:hover{background:var(--btn-contrast-hover);transform:scale(1.05)}.play-btn[data-v-7b36e164]:active,.play-btn[data-v-7b36e164]:focus{outline:none!important}.search-list[data-v-7b36e164]{display:flex;flex-wrap:wrap;gap:8px}.search-item[data-v-7b36e164]{padding:8px 16px;background:var(--bg-tertiary);border:none;border-radius:20px;color:var(--text-primary);font-size:13px;cursor:pointer;transition:background .2s;outline:none}.search-item[data-v-7b36e164]:hover{background:var(--bg-hover)}.search-item[data-v-7b36e164]:active,.search-item[data-v-7b36e164]:focus{outline:none!important}.empty-state[data-v-7b36e164],.loading[data-v-7b36e164],.no-results[data-v-7b36e164]{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;color:var(--text-secondary);padding:40px 20px;text-align:center}.empty-state svg[data-v-7b36e164],.loading svg[data-v-7b36e164]{color:var(--text-secondary);margin-bottom:16px}.empty-state p[data-v-7b36e164],.no-results p[data-v-7b36e164]{margin:0;font-size:16px}.search-loader[data-v-7b36e164]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 20px;color:var(--text-secondary)}.loading .spinner[data-v-7b36e164],.search-loader .spinner[data-v-7b36e164]{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin-7b36e164 1s linear infinite}@keyframes spin-7b36e164{to{transform:rotate(360deg)}}@media (max-width: 480px){.search-container[data-v-7b36e164],.filter-buttons[data-v-7b36e164],.recent-searches[data-v-7b36e164],.search-results[data-v-7b36e164]{padding-left:12px;padding-right:12px}.result-item[data-v-7b36e164]{padding:10px}.result-icon[data-v-7b36e164]{width:40px;height:40px}}.spin[data-v-05b36fa8]{animation:spin-05b36fa8 .8s linear infinite}@keyframes spin-05b36fa8{to{transform:rotate(360deg)}}.liked-tracks-header[data-v-05b36fa8]{display:flex;align-items:center;justify-content:space-between}.liked-tracks-header h3[data-v-05b36fa8]{margin:0}.tracks-toolbar[data-v-05b36fa8]{display:flex;justify-content:flex-end;padding:0}.btn-cache-all[data-v-05b36fa8]{display:flex;align-items:center;gap:6px;background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);border-radius:20px;padding:5px 12px;font-size:13px;cursor:pointer;transition:color .15s,border-color .15s}.btn-cache-all[data-v-05b36fa8]:hover:not(:disabled){color:var(--text-primary);border-color:var(--text-primary)}.btn-cache-all[data-v-05b36fa8]:disabled{opacity:.5;cursor:default}.library-tab[data-v-05b36fa8]{width:100%;height:100%;padding:0;display:flex;flex-direction:column;overflow:hidden}.tab-switcher[data-v-05b36fa8]{display:flex;gap:12px;border-bottom:1px solid var(--border-color);background:var(--bg-primary);padding:0 20px;z-index:10;flex-shrink:0}.swipe-viewport[data-v-05b36fa8]{flex:1;overflow:hidden;position:relative;min-height:0}.swipe-container[data-v-05b36fa8]{display:flex;flex-direction:row;width:300%;height:100%;will-change:transform}.tab-slide[data-v-05b36fa8]{width:33.333%;flex-shrink:0;height:100%;overflow-y:auto;padding:0 16px 20px;box-sizing:border-box}.tab-slide h3[data-v-05b36fa8]{margin:20px 0 12px;color:var(--text-primary);font-size:18px;font-weight:600}.sub-tab-btn[data-v-05b36fa8]{padding:12px 16px;background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:500;transition:color .2s;border-bottom:2px solid transparent;margin-bottom:-1px;outline:none;-webkit-tap-highlight-color:transparent}.sub-tab-btn[data-v-05b36fa8]:hover{color:var(--text-primary)}.sub-tab-btn.active[data-v-05b36fa8]{color:var(--text-primary);border-bottom-color:var(--text-primary)}.playlists-section[data-v-05b36fa8]{margin-bottom:8px}.playlists-scroll[data-v-05b36fa8]{display:flex;gap:12px;overflow-x:auto;overflow-y:hidden;padding-bottom:8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.playlists-scroll[data-v-05b36fa8]::-webkit-scrollbar{display:none}.playlist-card[data-v-05b36fa8]{flex-shrink:0;width:140px;cursor:pointer;scroll-snap-align:start;transition:transform .2s}.playlist-card[data-v-05b36fa8]:active{transform:scale(.96)}.playlist-cover[data-v-05b36fa8]{width:140px;height:140px;border-radius:8px;overflow:hidden;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);margin-bottom:8px}.playlist-cover-img[data-v-05b36fa8]{width:100%;height:100%;object-fit:cover}.playlist-card-name[data-v-05b36fa8]{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-card-meta[data-v-05b36fa8]{font-size:11px;color:var(--text-secondary);margin-top:2px}.tracks-list[data-v-05b36fa8]{overflow:visible}.empty-message[data-v-05b36fa8]{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:14px}.playlists-header[data-v-05b36fa8]{display:flex;align-items:center;justify-content:space-between}.playlists-header h3[data-v-05b36fa8]{margin:20px 0 12px}.btn-create-playlist[data-v-05b36fa8]{background:transparent;border:1px solid var(--border-color);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:pointer;transition:color .15s,border-color .15s;flex-shrink:0}.btn-create-playlist[data-v-05b36fa8]:hover{color:var(--text-primary);border-color:var(--text-primary)}.empty-playlists[data-v-05b36fa8]{font-size:13px;color:var(--text-secondary);margin:0 0 16px}.playlist-cover[data-v-05b36fa8]{position:relative}.playlist-delete-btn[data-v-05b36fa8]{position:absolute;top:6px;right:6px;width:26px;height:26px;border-radius:50%;border:none;background:#0000008c;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .15s}.playlist-card:hover .playlist-delete-btn[data-v-05b36fa8]{opacity:1}@media (hover: none){.playlist-delete-btn[data-v-05b36fa8]{opacity:1}}.pl-modal-overlay[data-v-05b36fa8]{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10001;background:#00000080;display:flex;align-items:center;justify-content:center;padding:20px}.pl-modal[data-v-05b36fa8]{background:var(--bg-primary);border-radius:16px;padding:24px;width:100%;max-width:360px}.pl-modal h3[data-v-05b36fa8]{margin:0 0 16px;font-size:17px;color:var(--text-primary)}.pl-modal-desc[data-v-05b36fa8]{color:var(--text-secondary);font-size:14px;margin:0 0 20px}.pl-modal-input[data-v-05b36fa8]{width:100%;box-sizing:border-box;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;padding:10px 14px;color:var(--text-primary);font-size:15px;outline:none;margin-bottom:16px}.pl-modal-input[data-v-05b36fa8]:focus{border-color:var(--text-primary)}.pl-modal-actions[data-v-05b36fa8]{display:flex;gap:10px}.pl-modal-btn[data-v-05b36fa8]{flex:1;padding:10px;border-radius:10px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:background .15s}.pl-modal-btn[data-v-05b36fa8]:hover:not(:disabled){background:var(--overlay-light)}.pl-modal-btn[data-v-05b36fa8]:disabled{opacity:.5;cursor:default}.pl-modal-btn.primary[data-v-05b36fa8]{background:var(--text-primary);color:var(--bg-primary);border-color:transparent}.pl-modal-btn.primary[data-v-05b36fa8]:hover:not(:disabled){opacity:.85}.pl-modal-btn.danger[data-v-05b36fa8]{background:#e53935;color:#fff;border-color:transparent}.pl-modal-btn.danger[data-v-05b36fa8]:hover:not(:disabled){opacity:.85}.modal-enter-active[data-v-05b36fa8],.modal-leave-active[data-v-05b36fa8]{transition:opacity .2s}.modal-enter-from[data-v-05b36fa8],.modal-leave-to[data-v-05b36fa8]{opacity:0}.profile-tab[data-v-9c9cda44]{width:100%;padding:20px 0}.profile-update-progress[data-v-9c9cda44]{display:flex;align-items:center;gap:8px;margin-top:10px}.profile-update-progress-bar[data-v-9c9cda44]{flex:1;height:8px;border-radius:999px;overflow:hidden;background:#ffffff38}.profile-update-progress-fill[data-v-9c9cda44]{height:100%;border-radius:inherit;background:#ffffffeb;transition:width .2s ease}.profile-update-progress-label[data-v-9c9cda44]{min-width:42px;font-size:13px;font-weight:600}.profile-header[data-v-9c9cda44]{display:flex;align-items:center;gap:20px;padding:20px;background:linear-gradient(135deg,var(--overlay-light),var(--overlay-lighter));border-radius:12px;margin:0 20px 24px}.change-password-form[data-v-9c9cda44]{display:flex;flex-direction:column;gap:8px;padding:4px 0}.password-input[data-v-9c9cda44]{width:100%;padding:10px 14px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-size:14px;outline:none;box-sizing:border-box;transition:border-color .15s}.password-input[data-v-9c9cda44]:focus{border-color:var(--accent-color, #1db954)}.password-msg[data-v-9c9cda44]{margin:0;font-size:13px}.password-msg.error[data-v-9c9cda44]{color:#f44}.password-msg.success[data-v-9c9cda44]{color:#1db954}.invite-result[data-v-9c9cda44]{display:flex;flex-direction:column;gap:4px;padding:8px 12px}.invite-link-input[data-v-9c9cda44]{width:100%;box-sizing:border-box;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;padding:7px 10px;font-size:13px;color:var(--text-primary);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.invite-hint[data-v-9c9cda44]{font-size:12px;color:var(--text-secondary)}.profile-avatar[data-v-9c9cda44]{width:80px;height:80px;background:var(--bg-tertiary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-primary);flex-shrink:0}.profile-info[data-v-9c9cda44]{flex:1;min-width:0}.profile-info h1[data-v-9c9cda44]{margin:0 0 4px;font-size:24px;color:var(--text-primary)}.email[data-v-9c9cda44]{margin:0;color:var(--text-secondary);font-size:14px}.settings-section[data-v-9c9cda44]{padding:0 20px 20px}.settings-group[data-v-9c9cda44]{margin-bottom:8px}.settings-group-label[data-v-9c9cda44]{margin:0 0 10px 2px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);padding-top:16px}.about-section[data-v-9c9cda44]{padding:0 20px 30px}.update-check-row[data-v-9c9cda44]{margin-top:12px}.update-banner[data-v-9c9cda44]{margin-top:10px;padding:10px 14px;background:var(--accent, #1db954);color:#fff;border-radius:8px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.update-reload-btn[data-v-9c9cda44]{background:#ffffff40;border:none;border-radius:6px;padding:4px 12px;color:#fff;cursor:pointer;font-weight:600}.update-current[data-v-9c9cda44]{margin-top:8px;font-size:13px;color:var(--text-secondary)}@keyframes spin-9c9cda44{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinning[data-v-9c9cda44]{animation:spin-9c9cda44 1s linear infinite}.account-section[data-v-9c9cda44]{padding:0 0 20px}h2[data-v-9c9cda44]{margin:0 0 12px;font-size:18px;color:var(--text-primary);font-weight:600}.import-modal-overlay[data-v-9c9cda44]{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.import-modal[data-v-9c9cda44]{width:min(640px,100% - 32px);max-height:90vh;background:var(--bg-primary);border-radius:12px;padding:20px 20px 16px;box-shadow:0 20px 50px #0006;position:relative;display:flex;flex-direction:column;overflow:hidden}.import-modal h3[data-v-9c9cda44]{margin:0 0 12px;font-size:18px;color:var(--text-primary)}.import-modal-close[data-v-9c9cda44]{position:absolute;top:10px;right:10px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer}.import-label[data-v-9c9cda44]{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text-secondary);margin-bottom:12px}.toggle-switch[data-v-9c9cda44]{position:relative;display:inline-block;width:40px;height:20px}.toggle-switch input[data-v-9c9cda44]{opacity:0;width:0;height:0}.toggle-slider[data-v-9c9cda44]{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--bg-secondary);transition:.2s;border-radius:999px}.toggle-slider[data-v-9c9cda44]:before{position:absolute;content:"";height:14px;width:14px;left:3px;top:3px;background-color:var(--text-primary);transition:.2s;border-radius:50%}.toggle-switch input:checked+.toggle-slider[data-v-9c9cda44]{background-color:var(--accent-primary)}.toggle-switch input:checked+.toggle-slider[data-v-9c9cda44]:before{transform:translate(18px)}.import-input[data-v-9c9cda44]{width:100%;padding:8px 10px;border-radius:8px;border:1px solid var(--border-subtle);background:var(--bg-secondary);color:var(--text-primary);font-size:14px}.import-textarea[data-v-9c9cda44]{width:100%;min-height:200px;padding:10px;border-radius:8px;border:1px solid var(--border-subtle);background:var(--bg-secondary);color:var(--text-primary);font-size:13px;resize:vertical;font-family:inherit;line-height:1.4}.import-actions[data-v-9c9cda44]{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}.import-primary[data-v-9c9cda44]{background:var(--accent-primary);color:#fff}.import-primary[data-v-9c9cda44]:disabled{opacity:.6;cursor:default}.import-result[data-v-9c9cda44]{margin-top:4px;margin-bottom:8px;font-size:12px}.import-result-added[data-v-9c9cda44]{color:#4caf50}.import-result-failed[data-v-9c9cda44]{color:#ff9800}.import-failed-toggle[data-v-9c9cda44]{margin-left:8px;padding:2px 8px;font-size:11px;border-radius:999px;border:1px solid var(--border-subtle);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer}.import-failed-toggle[data-v-9c9cda44]:hover{background:var(--overlay-light)}.import-failed-list[data-v-9c9cda44]{margin-top:6px;padding:8px 10px;border-radius:8px;background:var(--bg-tertiary);color:var(--text-primary);list-style:none;max-height:180px;overflow-y:auto;font-size:12px}.import-failed-list li+li[data-v-9c9cda44]{margin-top:4px}.control-row[data-v-9c9cda44]{position:relative;display:flex;align-items:center;margin-bottom:12px}.control-icon[data-v-9c9cda44]{position:absolute;left:16px;color:var(--text-primary);pointer-events:none;z-index:1;flex-shrink:0}.select-control[data-v-9c9cda44]{width:100%;background-color:var(--bg-tertiary);border:none;border-radius:12px;color:var(--text-primary);padding:14px 44px 14px 48px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:16px;outline:none}.select-control[data-v-9c9cda44]:hover{background-color:var(--bg-secondary)}.select-control[data-v-9c9cda44]{transition:background-color .2s}.select-control[data-v-9c9cda44]:focus{transition:background-color .2s}.bitrate-input[data-v-9c9cda44]{width:80px;background:var(--input-bg, #404040);border:1px solid var(--border-color, #282828);border-radius:8px;color:var(--text-primary);padding:8px 10px;font-size:15px;font-weight:600;outline:none;transition:border .2s,background .2s}.bitrate-input[data-v-9c9cda44]:focus{background:var(--input-bg-focus, #535353);border-color:var(--accent-color, #1db954)}.select-control[data-v-9c9cda44]:focus{outline:none}.control-btn[data-v-9c9cda44]{width:100%;background:var(--bg-tertiary);border:none;border-radius:12px;color:var(--text-primary);padding:14px 16px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:12px;transition:all .2s;outline:none;margin-bottom:12px}.control-btn[data-v-9c9cda44]:hover{background:var(--bg-secondary)}.control-btn[data-v-9c9cda44]:active,.control-btn[data-v-9c9cda44]:focus{outline:none!important}.control-btn-text[data-v-9c9cda44]{flex:1;text-align:left}.control-btn-value[data-v-9c9cda44]{color:var(--text-secondary);font-weight:500}.control-btn.active .control-btn-value[data-v-9c9cda44]{color:var(--accent-color, #ffffff)}.control-btn.install[data-v-9c9cda44]{background:#1db954;color:#fff;justify-content:center}.control-btn.install[data-v-9c9cda44]:hover{opacity:.9}.control-btn.logout[data-v-9c9cda44]{background:#f44;color:var(--text-primary);justify-content:center}.control-btn.logout[data-v-9c9cda44]:hover{background:#f55}.about-section p[data-v-9c9cda44]{margin:8px 0;color:var(--text-secondary);font-size:14px}@media (max-width: 480px){.profile-header[data-v-9c9cda44]{flex-direction:column;text-align:center}.profile-info h1[data-v-9c9cda44]{font-size:20px}.setting-item[data-v-9c9cda44]{flex-direction:column;align-items:flex-start;gap:8px}.setting-control[data-v-9c9cda44],.select-control[data-v-9c9cda44],.toggle-btn[data-v-9c9cda44]{width:100%}}.install-btn[data-v-9c9cda44]{background:#1db954;border:1px solid #1db954;border-radius:6px;color:#fff;padding:8px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;outline:none}.install-btn[data-v-9c9cda44]:hover{background:#1ed760;border-color:#1ed760}.install-btn[data-v-9c9cda44]:active,.install-btn[data-v-9c9cda44]:focus{outline:none!important}.install-hint-banner[data-v-9c9cda44]{margin-bottom:12px;padding:12px 16px;background:var(--bg-tertiary);border-radius:12px;font-size:13px;color:var(--text-secondary);line-height:1.5}.install-modal-overlay[data-v-9c9cda44]{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.install-modal[data-v-9c9cda44]{background:var(--bg-primary);border-radius:16px;padding:24px;width:min(90vw,340px);display:flex;flex-direction:column;gap:12px;position:relative}.install-modal h3[data-v-9c9cda44]{margin:0 0 4px;font-size:18px;color:var(--text-primary);text-align:center;font-weight:600}.install-modal-close[data-v-9c9cda44]{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .2s}.install-modal-close[data-v-9c9cda44]:hover{background:var(--overlay-light)}.install-choice-btn[data-v-9c9cda44]{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s;outline:none}.install-choice-btn.apk[data-v-9c9cda44]{background:#1db954;color:#fff}.install-choice-btn.pwa[data-v-9c9cda44]{background:var(--bg-tertiary);color:var(--text-primary)}.install-choice-btn[data-v-9c9cda44]:hover{opacity:.9}.modal-enter-active[data-v-9c9cda44],.modal-leave-active[data-v-9c9cda44]{transition:opacity .2s ease}.modal-enter-active .install-modal[data-v-9c9cda44],.modal-leave-active .install-modal[data-v-9c9cda44]{transition:transform .2s ease}.modal-enter-from[data-v-9c9cda44],.modal-leave-to[data-v-9c9cda44]{opacity:0}.modal-enter-from .install-modal[data-v-9c9cda44],.modal-leave-to .install-modal[data-v-9c9cda44]{transform:scale(.95)}.spin[data-v-3139ce6f]{animation:spin-3139ce6f .8s linear infinite}.artist-page[data-v-3139ce6f]{width:100%;max-width:1200px;margin:0 auto;padding:0;color:var(--text-primary)}.artist-header[data-v-3139ce6f]{display:flex;align-items:center;justify-content:center;padding:24px 24px 20px;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);border-bottom:1px solid var(--border-color);position:relative}.back-btn[data-v-3139ce6f]{background:none;border:none;color:var(--text-primary);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;position:absolute;top:18px;z-index:2}.back-btn-mobile[data-v-3139ce6f]{left:16px}.back-btn-desktop[data-v-3139ce6f]{right:16px}.artist-header-main[data-v-3139ce6f]{flex:1;display:flex;flex-direction:column;align-items:center;gap:16px}.artist-cover[data-v-3139ce6f]{width:180px;height:180px;border-radius:999px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 16px var(--shadow-color)}.artist-info[data-v-3139ce6f]{flex:1;text-align:center}.artist-info h1[data-v-3139ce6f]{margin:0;font-size:28px;font-weight:700}.artist-meta[data-v-3139ce6f]{margin:8px 0 0;color:var(--text-secondary);font-size:14px}.artist-actions[data-v-3139ce6f]{margin-top:16px;display:flex;gap:12px;justify-content:center}.btn-circle[data-v-3139ce6f]{width:52px;height:52px;border-radius:50%;border:1px solid var(--overlay-medium);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,border-color .2s,transform .1s}.btn-circle.primary[data-v-3139ce6f]{background:var(--accent-color);color:var(--bg-primary);border-color:transparent}.btn-circle.secondary[data-v-3139ce6f]{background:transparent;color:var(--text-primary)}.btn-circle[data-v-3139ce6f]:hover{transform:scale(1.05);border-color:var(--overlay-strong)}.artist-content[data-v-3139ce6f]{padding:24px}.albums-section[data-v-3139ce6f],.tracks-section[data-v-3139ce6f]{margin-bottom:24px}.albums-section h2[data-v-3139ce6f],.tracks-section h2[data-v-3139ce6f]{margin:0 0 16px;font-size:18px;font-weight:600;color:var(--text-primary)}.albums-scroll[data-v-3139ce6f]{display:flex;gap:12px;overflow-x:auto;overflow-y:hidden;padding-bottom:8px}.albums-scroll[data-v-3139ce6f]::-webkit-scrollbar{height:4px}.albums-scroll[data-v-3139ce6f]::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:2px}.albums-scroll[data-v-3139ce6f]::-webkit-scrollbar-thumb{background:var(--text-secondary);border-radius:2px}.albums-scroll[data-v-3139ce6f]::-webkit-scrollbar-thumb:hover{background:var(--text-primary)}.album-card[data-v-3139ce6f]{cursor:pointer;flex-shrink:0;width:130px}.album-cover-small[data-v-3139ce6f]{width:100%;aspect-ratio:1;background:var(--bg-secondary);border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;margin-bottom:8px}.album-cover-img[data-v-3139ce6f]{width:100%;height:100%;object-fit:cover}.album-card-name[data-v-3139ce6f]{font-size:14px;font-weight:500;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.album-card-meta[data-v-3139ce6f]{font-size:12px;color:var(--text-secondary)}.tracks-list[data-v-3139ce6f]{display:flex;flex-direction:column;gap:2px}@media (max-width: 768px){.artist-header[data-v-3139ce6f]{padding:16px 16px 14px}.artist-cover[data-v-3139ce6f]{width:150px;height:150px}.artist-info h1[data-v-3139ce6f]{font-size:22px}.artist-content[data-v-3139ce6f]{padding:16px}.back-btn-desktop[data-v-3139ce6f]{display:none}}@media (min-width: 769px){.back-btn-mobile[data-v-3139ce6f]{display:none}}.section-loader[data-v-3139ce6f]{display:flex;justify-content:center;align-items:center;gap:12px;padding:20px;color:var(--text-secondary);font-size:12px}.section-loader-inline[data-v-3139ce6f]{display:flex;align-items:center;gap:8px}.spinner[data-v-3139ce6f]{width:32px;height:32px;border:3px solid var(--bg-secondary);border-top-color:var(--text-primary);border-radius:50%;animation:spin-3139ce6f 1s linear infinite}.spinner-small[data-v-3139ce6f]{width:16px;height:16px;border:2px solid var(--bg-secondary);border-top-color:var(--text-primary);border-radius:50%;animation:spin-3139ce6f 1s linear infinite}.load-more-btn[data-v-3139ce6f]{width:100%;padding:12px;margin-top:16px;background:var(--text-primary);color:var(--bg-primary);border:none;border-radius:24px;font-weight:600;font-size:14px;cursor:pointer;transition:background .2s}.load-more-btn[data-v-3139ce6f]:hover{background:var(--btn-contrast-hover)}.loading[data-v-3139ce6f],.error[data-v-3139ce6f]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:64px 16px;text-align:center}.spinner[data-v-3139ce6f]{width:40px;height:40px;border:4px solid var(--bg-secondary);border-top-color:#fff;border-radius:50%;animation:spin-3139ce6f 1s linear infinite}@keyframes spin-3139ce6f{to{transform:rotate(360deg)}}.btn-primary[data-v-3139ce6f]{background:#fff;border:none;color:var(--bg-primary);padding:12px 24px;border-radius:24px;cursor:pointer;font-weight:600;transition:background .2s}.btn-primary[data-v-3139ce6f]:hover{background:#e0e0e0}.bottom-nav[data-v-3139ce6f]{position:fixed;bottom:0;left:0;right:0;height:60px;background:var(--bg-secondary);border-top:1px solid var(--border-color);display:flex;justify-content:space-around;align-items:center;z-index:100}.nav-btn[data-v-3139ce6f]{display:flex;align-items:center;justify-content:center;width:60px;height:60px;background:none;border:none;cursor:pointer;color:var(--text-secondary);transition:color .2s,transform .2s;outline:none}.nav-btn[data-v-3139ce6f]:hover{color:var(--text-primary);transform:scale(1.1)}.nav-btn[data-v-3139ce6f]:active,.nav-btn[data-v-3139ce6f]:focus{outline:none!important}.nav-btn.active[data-v-3139ce6f]{color:var(--text-primary)}@media (max-width: 768px){.albums-grid[data-v-3139ce6f]{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.artist-info h1[data-v-3139ce6f]{font-size:20px}}.spin[data-v-d5044f83]{animation:spin-d5044f83 .8s linear infinite}.album-page[data-v-d5044f83]{width:100%;max-width:1200px;margin:0 auto;padding:0;color:var(--text-primary)}.album-header[data-v-d5044f83]{display:flex;align-items:center;justify-content:center;padding:24px 24px 20px;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);border-bottom:1px solid var(--border-color);position:relative}.back-btn[data-v-d5044f83]{background:none;border:none;color:var(--text-primary);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;position:absolute;top:18px;z-index:2}.back-btn-mobile[data-v-d5044f83]{left:16px}.back-btn-desktop[data-v-d5044f83]{right:16px}.album-header-main[data-v-d5044f83]{flex:1;display:flex;flex-direction:column;align-items:center;gap:16px}.album-cover[data-v-d5044f83]{width:260px;height:260px;border-radius:12px;overflow:hidden;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 8px 16px var(--shadow-color)}.album-cover-img[data-v-d5044f83]{width:100%;height:100%;object-fit:cover}.album-cover-placeholder[data-v-d5044f83]{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.album-info[data-v-d5044f83]{flex:1;text-align:center}.album-info h1[data-v-d5044f83]{margin:0;font-size:32px;font-weight:700}.album-meta[data-v-d5044f83]{margin:8px 0 0;color:var(--text-secondary);font-size:14px}.album-actions[data-v-d5044f83]{margin-top:16px;display:flex;gap:12px;justify-content:center}.btn-circle[data-v-d5044f83]{width:52px;height:52px;border-radius:50%;border:1px solid var(--overlay-medium);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,border-color .2s,transform .1s}.btn-circle.primary[data-v-d5044f83]{background:var(--accent-color);color:var(--bg-primary);border-color:transparent}.btn-circle.secondary[data-v-d5044f83]{background:transparent;color:var(--text-primary)}.btn-circle[data-v-d5044f83]:hover{transform:scale(1.05);border-color:var(--overlay-strong)}.tracks-list[data-v-d5044f83]{overflow:visible}.album-content[data-v-d5044f83]{padding:24px}@media (max-width: 768px){.album-header[data-v-d5044f83]{padding:16px 16px 14px}.album-cover[data-v-d5044f83]{width:210px;height:210px}.album-info h1[data-v-d5044f83]{font-size:24px}.album-content[data-v-d5044f83]{padding:16px}.back-btn-desktop[data-v-d5044f83]{display:none}}@media (min-width: 769px){.back-btn-mobile[data-v-d5044f83]{display:none}}.loading[data-v-d5044f83],.error[data-v-d5044f83]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:64px 16px;text-align:center}.spinner[data-v-d5044f83]{width:40px;height:40px;border:4px solid var(--bg-secondary);border-top-color:#fff;border-radius:50%;animation:spin-d5044f83 1s linear infinite}@keyframes spin-d5044f83{to{transform:rotate(360deg)}}.btn-primary[data-v-d5044f83]{background:#fff;border:none;color:var(--bg-primary);padding:12px 24px;border-radius:24px;cursor:pointer;font-weight:600;transition:background .2s}.btn-primary[data-v-d5044f83]:hover{background:#e0e0e0}.spin[data-v-431ad165]{animation:spin-431ad165 .8s linear infinite}.playlist-page[data-v-431ad165]{width:100%;max-width:1200px;margin:0 auto;padding:0 0 90px;color:var(--text-primary)}.playlist-header[data-v-431ad165]{display:flex;align-items:center;justify-content:center;padding:24px 24px 20px;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);border-bottom:1px solid var(--border-color);position:relative}.back-btn[data-v-431ad165]{background:none;border:none;color:var(--text-primary);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;position:absolute;top:18px;z-index:2}.back-btn-mobile[data-v-431ad165]{left:16px}.back-btn-desktop[data-v-431ad165]{right:56px}.edit-btn[data-v-431ad165]{position:absolute;top:18px;right:16px;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;z-index:2;border-radius:50%;transition:color .2s,background .2s}.edit-btn[data-v-431ad165]:hover{color:var(--text-primary);background:var(--overlay-light)}.save-btn[data-v-431ad165]{color:#1db954}.save-btn[data-v-431ad165]:hover{color:#1db954;background:#1db9541f}.edit-name-input[data-v-431ad165]{background:transparent;border:none;border-bottom:2px solid var(--accent-color, #1db954);color:var(--text-primary);font-size:28px;font-weight:700;text-align:center;width:100%;outline:none;padding:4px 8px;margin:0}.edit-hint[data-v-431ad165]{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary);margin-top:10px;justify-content:center}.edit-list[data-v-431ad165]{display:flex;flex-direction:column;gap:4px}.edit-track-row[data-v-431ad165]{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:10px;background:var(--bg-secondary);cursor:grab;-webkit-user-select:none;user-select:none;border:2px solid transparent;transition:transform .15s cubic-bezier(.2,.9,.3,1),background .15s,opacity .15s;will-change:transform}.edit-track-row[data-v-431ad165]:active{cursor:grabbing}.edit-track-row.drag-source[data-v-431ad165]{opacity:.25}.drag-handle[data-v-431ad165]{color:var(--text-secondary);flex-shrink:0;display:flex;align-items:center;cursor:grab;touch-action:none}.drag-handle[data-v-431ad165]:active{cursor:grabbing}.playlist-drag-ghost{position:fixed;z-index:9999;pointer-events:none;display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:10px;background:var(--bg-secondary);border:2px solid var(--accent-color, #1db954);box-shadow:0 12px 40px #00000080;opacity:.96;-webkit-user-select:none;user-select:none}.playlist-drag-ghost{width:40px;height:40px;border-radius:6px;overflow:hidden;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.playlist-drag-ghost{width:100%;height:100%;object-fit:cover}.playlist-drag-ghost{flex:1;min-width:0}.playlist-drag-ghost{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.playlist-drag-ghost{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.edit-track-cover[data-v-431ad165]{width:40px;height:40px;border-radius:6px;overflow:hidden;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.edit-track-img[data-v-431ad165]{width:100%;height:100%;object-fit:cover}.edit-track-info[data-v-431ad165]{flex:1;min-width:0}.edit-track-title[data-v-431ad165]{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.edit-track-artist[data-v-431ad165]{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.edit-track-remove[data-v-431ad165]{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;display:flex;border-radius:50%;flex-shrink:0;transition:color .15s,background .15s}.edit-track-remove[data-v-431ad165]:hover{color:#f44;background:#ff44441a}.playlist-header-main[data-v-431ad165]{flex:1;display:flex;flex-direction:column;align-items:center;gap:16px}.playlist-cover[data-v-431ad165]{width:260px;height:260px;border-radius:12px;overflow:hidden;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 8px 16px var(--shadow-color)}.playlist-cover-img[data-v-431ad165]{width:100%;height:100%;object-fit:cover}.playlist-cover-placeholder[data-v-431ad165]{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.playlist-info[data-v-431ad165]{flex:1;text-align:center}.playlist-info h1[data-v-431ad165]{margin:0;font-size:32px;font-weight:700}.playlist-meta[data-v-431ad165]{margin:8px 0 0;color:var(--text-secondary);font-size:14px}.btn-play-all[data-v-431ad165]{margin-top:16px;background:var(--text-primary);border:none;color:var(--bg-primary);padding:12px 32px;border-radius:24px;cursor:pointer;font-weight:600;font-size:14px;display:flex;align-items:center;gap:8px;transition:background .2s}.btn-play-all[data-v-431ad165]:hover{background:var(--btn-contrast-hover)}.playlist-actions[data-v-431ad165]{margin-top:16px;display:flex;gap:12px;justify-content:center}.btn-circle[data-v-431ad165]{width:52px;height:52px;border-radius:50%;border:1px solid var(--overlay-medium);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,border-color .2s,transform .1s}.btn-circle.primary[data-v-431ad165]{background:var(--accent-color);color:var(--bg-primary);border-color:transparent}.btn-circle.secondary[data-v-431ad165]{background:transparent;color:var(--text-primary)}.btn-circle[data-v-431ad165]:hover{transform:scale(1.05);border-color:var(--overlay-strong)}.playlist-content[data-v-431ad165]{padding:24px}.tracks-list[data-v-431ad165]{overflow:visible}.loading[data-v-431ad165],.error[data-v-431ad165]{padding:24px;text-align:center}.spinner[data-v-431ad165]{width:32px;height:32px;border-radius:50%;border:3px solid var(--overlay-light);border-top-color:var(--text-primary);margin:0 auto 12px;animation:spin-431ad165 1s linear infinite}@keyframes spin-431ad165{to{transform:rotate(360deg)}}@media (max-width: 768px){.playlist-header[data-v-431ad165]{padding:16px 16px 14px}.playlist-cover[data-v-431ad165]{width:210px;height:210px}.playlist-info h1[data-v-431ad165]{font-size:24px}.playlist-content[data-v-431ad165]{padding:16px}.back-btn-desktop[data-v-431ad165]{display:none}}@media (min-width: 769px){.back-btn-mobile[data-v-431ad165]{display:none}}@media (max-width: 425px){.btn-play-all-text[data-v-431ad165]{display:none}}@media (max-width: 375px){.track-quality-inline[data-v-431ad165]{display:none}}.main-page[data-v-095f0a39]{display:flex;flex-direction:column;height:100%;overflow:hidden}.content-area[data-v-095f0a39]{flex:1;overflow-y:auto;padding:10px}.content-area[data-v-095f0a39]::-webkit-scrollbar{width:8px}.content-area[data-v-095f0a39]::-webkit-scrollbar-track{background:transparent}.content-area[data-v-095f0a39]::-webkit-scrollbar-thumb{background:var(--text-secondary);border-radius:4px}.content-area[data-v-095f0a39]::-webkit-scrollbar-thumb:hover{background:var(--text-primary)}.bottom-nav[data-v-095f0a39]{position:fixed;bottom:0;left:0;right:0;height:calc(60px + var(--sab, 0px));padding-bottom:var(--sab, 0px);background:var(--bg-secondary);border-top:1px solid var(--border-color);display:flex;justify-content:space-around;align-items:center;z-index:100}.nav-btn[data-v-095f0a39]{display:flex;align-items:center;justify-content:center;width:60px;height:60px;background:none;border:none;cursor:pointer;color:var(--text-secondary);transition:color .2s,transform .2s;outline:none;-webkit-tap-highlight-color:transparent}.nav-btn[data-v-095f0a39]:hover{color:var(--text-primary);transform:scale(1.1)}.nav-btn[data-v-095f0a39]:active,.nav-btn[data-v-095f0a39]:focus{outline:none!important}.nav-btn.active[data-v-095f0a39]{color:var(--text-primary)}.tab-content[data-v-095f0a39]{width:100%;max-width:100%}.tab-fade-enter-active[data-v-095f0a39]{transition:opacity .15s ease}.tab-fade-leave-active[data-v-095f0a39]{display:none}.tab-fade-enter-from[data-v-095f0a39],.tab-fade-leave-to[data-v-095f0a39]{opacity:0}.detail-overlay[data-v-095f0a39]{position:fixed;top:0;right:0;bottom:0;left:0;padding-bottom:70px;display:flex;justify-content:center;align-items:flex-start;background:var(--bg-primary);overflow-y:auto;z-index:90}.detail-fade-enter-active[data-v-095f0a39],.detail-fade-leave-active[data-v-095f0a39]{transition:opacity .2s ease}.detail-fade-enter-from[data-v-095f0a39],.detail-fade-leave-to[data-v-095f0a39]{opacity:0}@media (min-width: 768px){.main-page[data-v-095f0a39]{flex-direction:row}.content-area[data-v-095f0a39]{flex:1;padding:10px 10px 70px;overflow-y:auto;overflow-x:hidden}.bottom-nav[data-v-095f0a39]{position:relative;bottom:auto;right:auto;width:70px;height:100%;flex-direction:column;justify-content:flex-start;align-items:center;padding-top:20px;border-top:none;border-right:1px solid var(--border-color);background:var(--bg-secondary);gap:0;order:-1}.nav-btn[data-v-095f0a39]{width:70px;height:70px;border-radius:8px;margin:5px 0}.nav-btn[data-v-095f0a39]:hover{background:var(--overlay-light)}.detail-overlay[data-v-095f0a39]{left:70px}}@media (min-width: 1024px){.content-area[data-v-095f0a39]{padding:20px 20px 90px;max-width:100%}.bottom-nav[data-v-095f0a39]{width:90px;padding-top:30px}.nav-btn[data-v-095f0a39]{width:80px;height:80px;margin:10px auto}.detail-overlay[data-v-095f0a39]{left:90px}}.session-overlay[data-v-ee85dc7e]{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:#00000080;display:flex;align-items:flex-end;justify-content:center}.session-panel[data-v-ee85dc7e]{background:var(--bg-primary);border-radius:20px 20px 0 0;width:100%;max-width:520px;padding:20px 20px 32px;position:relative;display:flex;flex-direction:column;gap:16px}.session-header[data-v-ee85dc7e]{display:flex;align-items:center;justify-content:space-between}.session-title-row[data-v-ee85dc7e]{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700;color:var(--text-primary)}.session-close[data-v-ee85dc7e]{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;display:flex}.room-info[data-v-ee85dc7e]{background:var(--bg-secondary);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:4px}.room-code-label[data-v-ee85dc7e]{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.room-code[data-v-ee85dc7e]{font-size:28px;font-weight:800;letter-spacing:6px;color:var(--text-primary);font-family:monospace}.room-role[data-v-ee85dc7e]{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.invite-section[data-v-ee85dc7e]{display:flex;align-items:center;gap:10px;background:var(--bg-tertiary);border-radius:10px;padding:10px 14px}.invite-url[data-v-ee85dc7e]{flex:1;font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-copy[data-v-ee85dc7e]{display:flex;align-items:center;gap:6px;background:var(--overlay-light);border:none;border-radius:20px;color:var(--text-primary);font-size:13px;padding:6px 12px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s}.btn-copy.copied[data-v-ee85dc7e]{color:#1db954}.members-label[data-v-ee85dc7e]{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:6px}.members-list[data-v-ee85dc7e]{display:flex;flex-direction:column;gap:8px}.member-row[data-v-ee85dc7e]{display:flex;align-items:center;gap:10px}.member-avatar[data-v-ee85dc7e]{width:32px;height:32px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--text-primary);flex-shrink:0}.member-name[data-v-ee85dc7e]{font-size:14px;color:var(--text-primary);flex:1}.host-badge[data-v-ee85dc7e]{color:#f5a623}.no-members[data-v-ee85dc7e]{font-size:13px;color:var(--text-secondary)}.now-playing[data-v-ee85dc7e]{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);background:var(--bg-secondary);padding:10px 14px;border-radius:10px}.btn-leave[data-v-ee85dc7e]{display:flex;align-items:center;justify-content:center;gap:8px;background:transparent;border:1px solid #ff4444;color:#f44;border-radius:12px;padding:12px;font-size:15px;font-weight:600;cursor:pointer;width:100%;transition:background .15s}.btn-leave[data-v-ee85dc7e]:hover:not(:disabled){background:#ff44441a}.btn-create[data-v-ee85dc7e]{display:flex;align-items:center;justify-content:center;gap:10px;background:var(--accent-primary, #1db954);color:#fff;border:none;border-radius:12px;padding:14px;font-size:16px;font-weight:700;cursor:pointer;width:100%;transition:opacity .15s}.btn-create[data-v-ee85dc7e]:hover:not(:disabled){opacity:.9}.btn-create[data-v-ee85dc7e]:disabled{opacity:.6;cursor:default}.divider[data-v-ee85dc7e]{display:flex;align-items:center;gap:12px;color:var(--text-secondary);font-size:13px}.divider[data-v-ee85dc7e]:before,.divider[data-v-ee85dc7e]:after{content:"";flex:1;height:1px;background:var(--border-color, #333)}.join-label[data-v-ee85dc7e]{font-size:13px;color:var(--text-secondary);margin-bottom:8px}.join-input-row[data-v-ee85dc7e]{display:flex;gap:10px}.join-input[data-v-ee85dc7e]{flex:1;background:var(--bg-tertiary);border:1px solid var(--border-color, #333);border-radius:10px;color:var(--text-primary);font-size:20px;font-weight:700;letter-spacing:6px;text-align:center;padding:10px;text-transform:uppercase;font-family:monospace;outline:none;user-select:text;-webkit-user-select:text}.btn-join[data-v-ee85dc7e]{background:var(--bg-tertiary);border:1px solid var(--border-color, #333);border-radius:10px;color:var(--text-primary);font-size:15px;font-weight:600;padding:10px 20px;cursor:pointer;transition:background .15s}.btn-join[data-v-ee85dc7e]:hover:not(:disabled){background:var(--bg-secondary)}.btn-join[data-v-ee85dc7e]:disabled{opacity:.4;cursor:default}.session-error[data-v-ee85dc7e]{font-size:13px;color:#f44;text-align:center}.session-loading[data-v-ee85dc7e]{display:flex;justify-content:center;color:var(--text-secondary)}.spin[data-v-ee85dc7e]{animation:spin-ee85dc7e .8s linear infinite}@keyframes spin-ee85dc7e{to{transform:rotate(360deg)}}.session-slide-enter-active[data-v-ee85dc7e],.session-slide-leave-active[data-v-ee85dc7e]{transition:transform .35s cubic-bezier(.2,.9,.3,1),opacity .25s}.session-slide-enter-from[data-v-ee85dc7e],.session-slide-leave-to[data-v-ee85dc7e]{transform:translateY(100%);opacity:0}.eq-overlay[data-v-c8dc76ef]{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:1000;display:flex;align-items:flex-end;justify-content:center}.eq-panel[data-v-c8dc76ef]{background:var(--bg-secondary, #181818);border-radius:20px 20px 0 0;padding:20px 20px 36px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;gap:18px;border-top:1px solid var(--border-color, #282828)}.eq-panel[data-v-c8dc76ef]:before{content:"";display:block;width:36px;height:4px;border-radius:2px;background:var(--overlay-medium, rgba(255,255,255,.2));margin:-6px auto 2px;flex-shrink:0}.eq-header[data-v-c8dc76ef]{display:flex;align-items:center;justify-content:space-between}.eq-title-row[data-v-c8dc76ef]{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--text-primary, #fff)}.eq-header-actions[data-v-c8dc76ef]{display:flex;align-items:center;gap:12px}.eq-toggle[data-v-c8dc76ef]{display:flex;align-items:center;gap:6px;cursor:pointer}.eq-toggle input[type=checkbox][data-v-c8dc76ef]{width:16px;height:16px;accent-color:var(--accent-color, #ffffff);cursor:pointer}.eq-toggle-label[data-v-c8dc76ef]{font-size:13px;color:var(--text-secondary, #aaa)}.eq-close[data-v-c8dc76ef]{background:none;border:none;color:var(--text-secondary, #aaa);cursor:pointer;padding:4px;display:flex;align-items:center;border-radius:6px;transition:background .15s}.eq-close[data-v-c8dc76ef]:hover{background:var(--overlay-light, rgba(255,255,255,.08));color:var(--text-primary, #fff)}.eq-presets-wrapper[data-v-c8dc76ef]{position:relative}.eq-presets-wrapper[data-v-c8dc76ef]:before,.eq-presets-wrapper[data-v-c8dc76ef]:after{content:"";position:absolute;top:0;bottom:8px;width:56px;pointer-events:none;z-index:1;opacity:0;transition:opacity .25s ease}.eq-presets-wrapper[data-v-c8dc76ef]:before{left:0;background:linear-gradient(to left,transparent,var(--bg-secondary, #181818))}.eq-presets-wrapper[data-v-c8dc76ef]:after{right:0;background:linear-gradient(to right,transparent,var(--bg-secondary, #181818))}.eq-presets-wrapper.fade-left[data-v-c8dc76ef]:before{opacity:1}.eq-presets-wrapper.fade-right[data-v-c8dc76ef]:after{opacity:1}.eq-presets-scroll[data-v-c8dc76ef]{display:flex;gap:8px;overflow-x:auto;overflow-y:hidden;padding:2px 0 8px;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;scrollbar-width:none}@media (min-width: 768px){.eq-presets-scroll[data-v-c8dc76ef]{flex-wrap:wrap;overflow-x:visible;scroll-snap-type:none}.eq-presets-wrapper[data-v-c8dc76ef]:before,.eq-presets-wrapper[data-v-c8dc76ef]:after{display:none}}.eq-presets-scroll[data-v-c8dc76ef]::-webkit-scrollbar{display:none}.eq-preset-btn[data-v-c8dc76ef]{flex-shrink:0;scroll-snap-align:start;background:var(--bg-tertiary, #282828);border:1px solid transparent;color:var(--text-secondary, #aaa);font-size:14px;height:44px;padding:0 20px;border-radius:22px;cursor:pointer;white-space:nowrap;transition:all .15s;display:flex;align-items:center;outline:none}.eq-preset-btn[data-v-c8dc76ef]:hover{background:var(--bg-hover, #333);color:var(--text-primary, #fff)}.eq-preset-btn.active[data-v-c8dc76ef]{background:var(--text-primary, #fff);border-color:var(--text-primary, #fff);color:var(--bg-primary, #121212);font-weight:600}.eq-bands[data-v-c8dc76ef]{display:flex;gap:2px;justify-content:space-between;align-items:center;padding:8px 0}.eq-bands.disabled[data-v-c8dc76ef]{opacity:.35;pointer-events:none}.eq-band[data-v-c8dc76ef]{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1}.eq-gain-label[data-v-c8dc76ef]{font-size:10px;font-weight:600;color:var(--text-secondary, #aaa);min-width:28px;text-align:center;letter-spacing:.02em;height:16px;line-height:16px}.eq-slider-track[data-v-c8dc76ef]{position:relative;display:flex;align-items:center;justify-content:center;height:150px;width:28px}.eq-slider-track[data-v-c8dc76ef]:after{content:"";position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:1px;background:var(--overlay-light, rgba(255,255,255,.08));border-radius:1px;pointer-events:none}.eq-slider[data-v-c8dc76ef]{-webkit-appearance:none;-moz-appearance:none;appearance:none;position:absolute;width:150px;height:28px;transform:rotate(-90deg);cursor:pointer;background:transparent;outline:none;z-index:1}.eq-slider[data-v-c8dc76ef]::-webkit-slider-runnable-track{height:3px;border-radius:2px;background:var(--overlay-light, rgba(255,255,255,.12))}.eq-slider[data-v-c8dc76ef]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--text-primary, #ffffff);cursor:grab;margin-top:-8.5px;box-shadow:0 0 0 3px var(--overlay-light, rgba(255,255,255,.12)),0 2px 10px #0009;border:2px solid var(--bg-secondary, #181818);transition:box-shadow .15s,transform .15s}.eq-slider[data-v-c8dc76ef]::-webkit-slider-thumb:hover{box-shadow:0 0 0 5px var(--overlay-medium, rgba(255,255,255,.2)),0 2px 14px #000000b3}.eq-slider[data-v-c8dc76ef]::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.15)}.eq-slider[data-v-c8dc76ef]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--text-primary, #ffffff);cursor:grab;border:2px solid var(--bg-secondary, #181818);box-shadow:0 2px 10px #0009}.eq-slider[data-v-c8dc76ef]::-moz-range-track{height:3px;border-radius:2px;background:var(--overlay-light, rgba(255,255,255,.12))}.eq-freq-label[data-v-c8dc76ef]{font-size:10px;color:var(--text-secondary, #999);text-align:center;min-width:28px;letter-spacing:.01em}.eq-reset-btn[data-v-c8dc76ef]{align-self:center;background:none;border:1px solid var(--border-color, rgba(255,255,255,.12));color:var(--text-secondary, #aaa);font-size:13px;padding:8px 24px;border-radius:20px;cursor:pointer;transition:all .15s}.eq-reset-btn[data-v-c8dc76ef]:hover{background:var(--overlay-light, rgba(255,255,255,.06));border-color:var(--text-secondary, #aaa);color:var(--text-primary, #fff)}.eq-slide-enter-active[data-v-c8dc76ef],.eq-slide-leave-active[data-v-c8dc76ef]{transition:transform .3s cubic-bezier(.2,.9,.3,1),opacity .3s ease}.eq-slide-enter-from[data-v-c8dc76ef],.eq-slide-leave-to[data-v-c8dc76ef]{transform:translateY(100%);opacity:0}.player-wrapper[data-v-d49cf0a0]{width:100%}.drag-indicator[data-v-d49cf0a0]{position:absolute;top:8px;left:50%;transform:translate(-50%);width:40px;height:4px;background:var(--overlay-strong);border-radius:2px;z-index:1}.player-mini[data-v-d49cf0a0]{position:fixed;bottom:calc(60px + var(--sab, 0px));left:0;right:0;background:var(--player-bg);border-top:1px solid var(--border-color);padding:8px 12px;z-index:90;cursor:pointer;-webkit-user-select:none;user-select:none;overflow:hidden}.mini-carousel[data-v-d49cf0a0]{display:flex;width:300%;transform:translate(-33.333%);will-change:transform}.mini-carousel.mini-carousel-animating[data-v-d49cf0a0]{transition:transform .3s cubic-bezier(.2,.9,.3,1)}.mini-carousel-panel[data-v-d49cf0a0]{width:33.333%;flex-shrink:0;min-width:0}.player-expanded[data-v-d49cf0a0]{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);display:flex;flex-direction:column;z-index:200;overflow:hidden;transform:translateY(100%);will-change:transform}.player-header[data-v-d49cf0a0]{display:flex;justify-content:space-between;align-items:center;padding:calc(16px + var(--sat, 0px)) 16px 16px 16px;color:var(--text-primary);font-weight:600;position:relative;flex-shrink:0}.mini-player-row[data-v-d49cf0a0]{display:flex;align-items:center;height:56px;gap:8px}.mini-carousel-viewport[data-v-d49cf0a0]{flex:1;min-width:0;overflow:hidden;height:100%;position:relative}.mini-slide-content[data-v-d49cf0a0]{display:flex;align-items:center;gap:12px;height:100%}.mini-art[data-v-d49cf0a0]{width:50px;height:50px;border-radius:6px;overflow:hidden;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.mini-image[data-v-d49cf0a0]{width:100%;height:100%;object-fit:cover}.mini-placeholder[data-v-d49cf0a0]{color:var(--text-secondary)}.mini-info[data-v-d49cf0a0]{flex:1;min-width:0;padding-right:8px}.mini-title[data-v-d49cf0a0]{color:var(--text-primary);font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-artist[data-v-d49cf0a0]{color:var(--text-secondary);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-controls[data-v-d49cf0a0]{display:flex;gap:8px;align-items:center}.mini-btn[data-v-d49cf0a0]{width:36px;height:36px;border:none;background:var(--text-primary);border-radius:50%;color:var(--bg-primary);font-size:16px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0}.mini-btn[data-v-d49cf0a0]:hover{background:var(--btn-contrast-hover);transform:scale(1.05)}.mini-btn[data-v-d49cf0a0]:active{outline:none}.mini-btn-small[data-v-d49cf0a0]{width:32px;height:32px;border:none;background:var(--overlay-light);border-radius:50%;color:var(--text-secondary);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0}.mini-btn-small[data-v-d49cf0a0]:hover{background:var(--overlay-medium);color:var(--text-primary)}.mini-btn-small[data-v-d49cf0a0]:active{outline:none}.mini-btn-small.active[data-v-d49cf0a0]{color:var(--text-primary)}.nonstop-spinner[data-v-d49cf0a0]{display:inline-block;width:20px;height:20px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:nonstop-spin-d49cf0a0 .75s linear infinite;opacity:.7;flex-shrink:0}.nonstop-spinner--sm[data-v-d49cf0a0]{width:14px;height:14px}@keyframes nonstop-spin-d49cf0a0{to{transform:rotate(360deg)}}.icon-fade-enter-active[data-v-d49cf0a0]{transition:opacity .15s ease}.icon-fade-leave-active[data-v-d49cf0a0]{transition:opacity .05s ease}.icon-fade-enter-from[data-v-d49cf0a0],.icon-fade-leave-to[data-v-d49cf0a0]{opacity:0}.progress-mini[data-v-d49cf0a0]{height:3px;background:var(--border-color);margin-top:8px;border-radius:2px;overflow:hidden}.progress-mini-fill[data-v-d49cf0a0]{height:100%;background:var(--text-primary);transition:width .1s linear}.mini-volume-control[data-v-d49cf0a0]{display:flex;align-items:center;gap:6px;padding:4px 0;color:var(--text-secondary)}.mini-mute-btn[data-v-d49cf0a0]{background:none;border:none;padding:0;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;opacity:.7;transition:opacity .15s}.mini-mute-btn[data-v-d49cf0a0]:hover{opacity:1}.mini-volume-slider[data-v-d49cf0a0]{width:60px;height:3px;border-radius:2px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--overlay-medium);outline:none;cursor:pointer}.mini-volume-slider[data-v-d49cf0a0]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:10px;height:10px;border-radius:50%;background:var(--text-primary);cursor:pointer}.mini-volume-slider[data-v-d49cf0a0]::-moz-range-thumb{width:10px;height:10px;border-radius:50%;background:var(--text-primary);cursor:pointer;border:none}.mini-container[data-v-d49cf0a0]{display:flex;justify-content:space-between;align-items:center;padding:16px;color:var(--text-primary);font-weight:600;position:relative;flex-shrink:0}.close-btn[data-v-d49cf0a0]{background:none;border:none;color:var(--text-primary);font-size:24px;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:color .2s,transform .2s;padding:0}.close-btn[data-v-d49cf0a0]:hover{color:var(--text-secondary);transform:scale(1.1)}.close-btn[data-v-d49cf0a0]:active{outline:none}.close-btn-desktop[data-v-d49cf0a0]{position:absolute;right:16px;top:16px;z-index:210}.player-content[data-v-d49cf0a0]{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:normal;padding:20px;overflow-y:auto;min-height:0;width:100%;box-sizing:border-box}.album-section[data-v-d49cf0a0]{position:relative;align-self:stretch;flex-shrink:0;margin-bottom:16px;justify-items:center}.track-quality-badge[data-v-d49cf0a0]{position:absolute;top:10px;right:10px;font-size:11px;font-weight:600;color:var(--text-primary);background:#0000008c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:3px 8px;border-radius:6px;pointer-events:none;z-index:1}.album-art-swipe[data-v-d49cf0a0]{position:relative;width:100%;aspect-ratio:1;overflow:hidden;border-radius:16px}.album-carousel[data-v-d49cf0a0]{display:flex;width:300%;height:100%;transform:translate(-33.333%);will-change:transform;overflow:hidden}.album-carousel.album-carousel-animating[data-v-d49cf0a0]{transition:transform .3s cubic-bezier(.2,.9,.3,1)}.album-carousel-panel[data-v-d49cf0a0]{width:33.333%;flex-shrink:0;display:flex;align-items:center;justify-content:center}.album-art-large[data-v-d49cf0a0]{width:100%;height:100%;overflow:hidden;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px var(--shadow-color)}.album-image-large[data-v-d49cf0a0]{width:100%;height:100%;object-fit:cover}.album-placeholder-large[data-v-d49cf0a0]{color:var(--text-secondary)}.track-info-row[data-v-d49cf0a0]{display:flex;align-items:flex-start;justify-content:space-between;align-self:stretch;margin-bottom:16px;gap:8px}.track-info-large[data-v-d49cf0a0]{text-align:left;flex:1;min-width:0}.track-title-large[data-v-d49cf0a0]{font-size:22px;font-weight:700;color:var(--text-primary);margin:0 0 6px;word-wrap:break-word;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.track-artist-large[data-v-d49cf0a0]{font-size:15px;color:var(--text-secondary);margin:0}.track-artist-large.clickable[data-v-d49cf0a0]{cursor:pointer;transition:color .15s}.track-artist-large.clickable[data-v-d49cf0a0]:hover{color:var(--text-primary)}.track-album-large[data-v-d49cf0a0]{display:none}.progress-container-large[data-v-d49cf0a0]{display:flex;align-items:center;gap:12px;align-self:stretch;margin-bottom:16px}.time-large[data-v-d49cf0a0]{color:var(--text-primary);font-size:12px;font-weight:600;min-width:35px;text-align:center}.progress-bar-large[data-v-d49cf0a0]{flex:1;height:6px;background:var(--overlay-medium);border-radius:3px;cursor:pointer;overflow:visible;position:relative}.progress-fill-large[data-v-d49cf0a0]{height:100%;background:var(--text-primary);transition:width .1s linear;border-radius:3px;position:relative}.scrubber[data-v-d49cf0a0]{position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:12px;height:12px;background:var(--text-primary);border-radius:50%;cursor:grab}.scrubber[data-v-d49cf0a0]:active{cursor:grabbing}.volume-control[data-v-d49cf0a0]{display:flex;align-items:center;gap:12px;justify-content:center;align-self:stretch;margin-bottom:16px;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:8px;padding:8px 12px}.expanded-mute-btn[data-v-d49cf0a0]{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;margin:0;border:none;background:transparent;color:inherit;cursor:pointer;border-radius:8px;-moz-appearance:none;appearance:none;-webkit-appearance:none;outline:none;flex-shrink:0}.expanded-mute-btn[data-v-d49cf0a0]:hover{background:var(--overlay-light);color:var(--text-primary)}.expanded-mute-btn[data-v-d49cf0a0]:focus,.expanded-mute-btn[data-v-d49cf0a0]:focus-visible,.expanded-mute-btn[data-v-d49cf0a0]:active{outline:none}.volume-number-input[data-v-d49cf0a0]{width:43px;background:var(--overlay-light);border:1px solid var(--overlay-medium);border-radius:6px;color:var(--text-primary);font-size:13px;padding:2px 4px;text-align:right;-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.volume-number-input[data-v-d49cf0a0]::-webkit-inner-spin-button,.volume-number-input[data-v-d49cf0a0]::-webkit-outer-spin-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:none}.volume-slider[data-v-d49cf0a0]{flex:1;height:4px;border-radius:2px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--overlay-medium);outline:none;cursor:pointer}.volume-slider[data-v-d49cf0a0]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--text-primary);cursor:pointer}.volume-slider[data-v-d49cf0a0]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--text-primary);cursor:pointer;border:none}.controls-large[data-v-d49cf0a0]{display:flex;justify-content:center;align-items:center;gap:24px;margin-bottom:16px;width:100%}.control-btn-large[data-v-d49cf0a0]{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;background:none;color:var(--text-secondary);cursor:pointer;font-size:24px;transition:all .2s;border-radius:50%;padding:0;outline:none}.control-btn-large[data-v-d49cf0a0]:hover:not(.play-pause-btn-large){background:var(--overlay-light);color:var(--text-primary);transform:scale(1.1)}.control-btn-large[data-v-d49cf0a0]:active,.control-btn-large[data-v-d49cf0a0]:focus{outline:none!important}.control-btn-large.active[data-v-d49cf0a0]{color:var(--text-primary)}.play-pause-btn-large[data-v-d49cf0a0]{width:60px;height:60px;background:var(--text-primary);color:var(--bg-primary);font-size:28px;border-radius:50%;outline:none;border:none;cursor:pointer;display:flex;flex-wrap:nowrap;justify-content:center;align-items:center}.play-pause-btn-large[data-v-d49cf0a0]:hover{transform:scale(1.05);box-shadow:0 5px 20px var(--overlay-medium)}.play-pause-btn-large[data-v-d49cf0a0]:active,.play-pause-btn-large[data-v-d49cf0a0]:focus{outline:none!important}.like-section[data-v-d49cf0a0]{display:none}.like-btn[data-v-d49cf0a0]{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:24px;transition:all .2s;padding:8px 0;display:flex;align-items:center;justify-content:center;outline:none}.like-btn[data-v-d49cf0a0]:hover{color:var(--text-primary);transform:scale(1.1)}.like-btn[data-v-d49cf0a0]:active,.like-btn[data-v-d49cf0a0]:focus{outline:none!important}.like-btn.liked[data-v-d49cf0a0]{color:#f44}.queue-section[data-v-d49cf0a0]{margin-bottom:calc(20px + var(--sab, 0px));display:flex;flex-wrap:wrap;gap:10px}.queue-btn[data-v-d49cf0a0]{background:none;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;padding:10px 16px;font-size:13px;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;font-weight:600;outline:none;width:100%}.queue-btn[data-v-d49cf0a0]:hover{border-color:var(--text-primary);color:var(--text-primary)}.queue-btn[data-v-d49cf0a0]:active,.queue-btn[data-v-d49cf0a0]:focus{outline:none!important}.session-btn.active[data-v-d49cf0a0]{border-color:var(--accent-primary, #1db954);color:var(--accent-primary, #1db954)}.queue-display[data-v-d49cf0a0]{background:var(--shadow-color);border-radius:12px;padding:16px;margin-bottom:20px;max-height:400px;overflow-y:auto}.queue-header[data-v-d49cf0a0]{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.queue-header h3[data-v-d49cf0a0]{margin:0;font-size:14px;color:var(--text-primary)}.close-queue[data-v-d49cf0a0]{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;outline:none}.close-queue[data-v-d49cf0a0]:hover{color:var(--text-primary)}.close-queue[data-v-d49cf0a0]:active,.close-queue[data-v-d49cf0a0]:focus{outline:none!important}.queue-list[data-v-d49cf0a0]{display:flex;flex-direction:column;gap:8px}.queue-item[data-v-d49cf0a0]{display:flex;align-items:center;gap:8px;padding:8px;background:var(--overlay-lighter);border-radius:6px;cursor:pointer;transition:all .2s}.queue-item[data-v-d49cf0a0]:hover{background:var(--overlay-light)}.queue-item.current[data-v-d49cf0a0]{background:var(--overlay-medium);border-left:3px solid var(--text-primary)}.queue-num[data-v-d49cf0a0]{color:var(--text-secondary);font-size:12px;font-weight:600;min-width:20px}.queue-track-info[data-v-d49cf0a0]{flex:1;min-width:0}.queue-track-title[data-v-d49cf0a0]{color:var(--text-primary);font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-track-artist[data-v-d49cf0a0]{color:var(--text-secondary);font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-track-meta[data-v-d49cf0a0]{display:flex;gap:8px;margin-top:2px;font-size:9px;color:var(--text-secondary)}.track-duration[data-v-d49cf0a0]{font-weight:600}.track-quality[data-v-d49cf0a0]{opacity:.8}.queue-thumb[data-v-d49cf0a0]{width:36px;height:36px;border-radius:4px;object-fit:cover;flex-shrink:0}.player-empty[data-v-d49cf0a0]{text-align:center;padding:12px;color:var(--text-secondary);font-size:14px}.tabs-section[data-v-d49cf0a0]{display:flex;gap:8px;margin-bottom:16px;border-bottom:1px solid var(--border-color);padding-bottom:12px}.tab-btn[data-v-d49cf0a0]{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;padding:8px 12px;border-bottom:2px solid transparent;margin-bottom:-14px;transition:all .2s;outline:none}.tab-btn[data-v-d49cf0a0]:hover{color:var(--text-primary)}.tab-btn.active[data-v-d49cf0a0]{color:var(--text-primary);border-bottom-color:var(--text-primary)}@media (min-width: 768px) and (max-width: 1023px){.player-mini[data-v-d49cf0a0]{bottom:0;left:70px;height:70px;border-top:1px solid var(--border-color);border-right:1px solid var(--border-color);border-left:none;padding:6px 8px}.mini-player-row[data-v-d49cf0a0]{height:58px;gap:8px}.mini-art[data-v-d49cf0a0]{width:56px;height:56px}.mini-title[data-v-d49cf0a0]{font-size:12px}.mini-artist[data-v-d49cf0a0]{font-size:10px}.mini-controls[data-v-d49cf0a0]{gap:6px}.mini-btn[data-v-d49cf0a0]{width:32px;height:32px}.mini-btn-small[data-v-d49cf0a0]{width:28px;height:28px}.mini-volume-control[data-v-d49cf0a0]{display:none}.progress-mini[data-v-d49cf0a0]{height:3px;margin-top:8px}}@media (min-width: 1024px){.player-mini[data-v-d49cf0a0]{bottom:0;left:90px;height:90px;border-top:1px solid var(--border-color);border-right:1px solid var(--border-color);border-left:none;padding:8px 12px}.mini-player-row[data-v-d49cf0a0]{height:74px;gap:12px}.mini-art[data-v-d49cf0a0]{width:70px;height:70px}.mini-title[data-v-d49cf0a0]{font-size:13px}.mini-artist[data-v-d49cf0a0]{font-size:11px}.mini-controls[data-v-d49cf0a0]{gap:8px}.mini-btn[data-v-d49cf0a0]{width:36px;height:36px}.mini-btn-small[data-v-d49cf0a0]{width:32px;height:32px}.mini-volume-control[data-v-d49cf0a0]{display:flex;gap:8px;padding:4px 0}.mini-volume-slider[data-v-d49cf0a0]{width:80px}.progress-mini[data-v-d49cf0a0]{height:4px;margin-top:8px}}@media (max-width: 767px){.player-expanded.mobile .album-art-swipe[data-v-d49cf0a0]{width:100%;height:auto;max-width:500px}.player-expanded.mobile .track-title-large[data-v-d49cf0a0]{font-size:20px}.player-expanded.mobile .track-artist-large[data-v-d49cf0a0]{font-size:14px}.player-expanded.mobile .controls-large[data-v-d49cf0a0]{gap:16px}.player-expanded.mobile .control-btn-large[data-v-d49cf0a0]{width:40px;height:40px;font-size:20px}.player-expanded.mobile .play-pause-btn-large[data-v-d49cf0a0]{width:56px;height:56px;font-size:24px}.player-expanded.mobile .queue-btn-label[data-v-d49cf0a0]{display:none}.player-expanded.mobile .queue-btn[data-v-d49cf0a0]{flex:1;padding:10px 8px;min-width:44px}}@media (min-width: 768px) and (max-width: 1023px){.player-expanded.tablet[data-v-d49cf0a0]{flex-direction:row}.player-expanded.tablet .player-header[data-v-d49cf0a0]{display:none}.player-expanded.tablet .close-btn[data-v-d49cf0a0]{width:32px;height:32px}.player-expanded.tablet .player-content[data-v-d49cf0a0]{flex:1;justify-content:normal;align-items:center;padding:30px 14.8vw}.player-expanded.tablet .album-art-swipe[data-v-d49cf0a0]{width:100%;max-width:540px;height:auto}.player-expanded.tablet .track-title-large[data-v-d49cf0a0]{font-size:22px}.player-expanded.tablet .controls-large[data-v-d49cf0a0]{gap:20px}.player-expanded.tablet .queue-display[data-v-d49cf0a0]{max-width:300px}}@media (min-width: 1024px){.player-expanded.desktop[data-v-d49cf0a0]{flex-direction:row}.player-expanded.desktop .player-header[data-v-d49cf0a0]{display:none}.player-expanded.desktop .close-btn[data-v-d49cf0a0]{width:36px;height:36px}.player-expanded.desktop .player-content[data-v-d49cf0a0]{flex:1;justify-content:center;align-items:center;padding:20px 160px;max-width:900px;margin:0 auto;overflow:hidden}.player-expanded.desktop .album-art-swipe[data-v-d49cf0a0]{width:min(320px,35vh);height:min(320px,35vh);margin-bottom:20px}.player-expanded.desktop .track-title-large[data-v-d49cf0a0]{font-size:28px}.player-expanded.desktop .track-info-large[data-v-d49cf0a0]{max-width:600px;margin-bottom:15px}.player-expanded.desktop .progress-container-large[data-v-d49cf0a0]{margin-bottom:25px}.player-expanded.desktop .volume-control[data-v-d49cf0a0]{margin-bottom:15px}.player-expanded.desktop .controls-large[data-v-d49cf0a0]{gap:28px;margin-bottom:25px}.player-expanded.desktop .control-btn-large[data-v-d49cf0a0]{width:48px;height:48px}.player-expanded.desktop .play-pause-btn-large[data-v-d49cf0a0]{width:70px;height:70px;font-size:32px}.player-expanded.desktop .queue-display[data-v-d49cf0a0]{max-width:500px;max-height:450px}}.queue-panel[data-v-d49cf0a0]{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:420px;background:var(--bg-primary);display:flex;flex-direction:column;z-index:201;border-left:1px solid var(--border-color)}.queue-panel-header[data-v-d49cf0a0]{display:flex;justify-content:space-between;align-items:center;padding:calc(18px + var(--sat, 0px)) 20px 18px 20px;border-bottom:1px solid var(--border-color);flex-shrink:0}.queue-panel-header h2[data-v-d49cf0a0]{margin:0;font-size:18px;font-weight:700;color:var(--text-primary)}.queue-panel-list[data-v-d49cf0a0]{flex:1;overflow-y:auto;padding:8px 4px;position:relative}.queue-row[data-v-d49cf0a0]{display:flex;align-items:center;gap:4px;cursor:default;transition:transform .15s cubic-bezier(.2,.9,.3,1),opacity .15s;will-change:transform;-webkit-user-select:none;user-select:none}.queue-drag-source[data-v-d49cf0a0]{opacity:.25}.queue-row-track[data-v-d49cf0a0]{flex:1;min-width:0;cursor:pointer}.queue-drag-handle[data-v-d49cf0a0]{display:flex;align-items:center;padding:0 4px;cursor:grab;color:var(--text-secondary);flex-shrink:0;touch-action:none}.queue-drag-handle[data-v-d49cf0a0]:active{cursor:grabbing}.queue-drag-ghost{position:fixed;z-index:9999;pointer-events:none;display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:10px;background:var(--bg-secondary);border:2px solid var(--accent-color, #1db954);box-shadow:0 12px 40px #00000080;opacity:.96;-webkit-user-select:none;user-select:none;min-width:0}.queue-drag-ghost{flex:1;min-width:0}.queue-drag-ghost{width:40px;height:40px;border-radius:8px;overflow:hidden;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.queue-drag-ghost{width:100%;height:100%;object-fit:cover}.queue-drag-ghost{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--text-secondary)}.queue-drag-ghost{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.queue-drag-ghost{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-panel-slide-enter-active[data-v-d49cf0a0],.queue-panel-slide-leave-active[data-v-d49cf0a0]{transition:transform .3s cubic-bezier(.2,.9,.3,1)}.queue-panel-slide-enter-from[data-v-d49cf0a0],.queue-panel-slide-leave-to[data-v-d49cf0a0]{transform:translate(100%)}.guest-info-banner[data-v-d49cf0a0]{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:8px;background:var(--overlay-light);border:1px solid var(--border-color);font-size:12px;color:var(--text-secondary);text-align:center;line-height:1.4}.guest-info-icon[data-v-d49cf0a0]{flex-shrink:0;opacity:.7}.modal-close-btn[data-v-d49cf0a0]{background:none;border:none;color:var(--text-secondary);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s;padding:0}.modal-close-btn[data-v-d49cf0a0]:hover{color:var(--text-primary);background:var(--overlay-light)}.playlist-content[data-v-d49cf0a0]{flex:1;overflow-y:auto;padding:8px}.playlist-item[data-v-d49cf0a0]{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--overlay-lighter);border-radius:6px;cursor:pointer;transition:all .15s;margin-bottom:4px;position:relative;-webkit-user-select:none;user-select:none}.playlist-item[data-v-d49cf0a0]:hover{background:var(--overlay-light)}.playlist-item.current[data-v-d49cf0a0]{background:var(--overlay-medium);border-left:3px solid var(--text-primary);padding-left:9px}.track-menu[data-v-d49cf0a0]{position:fixed;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;min-width:180px;z-index:500;box-shadow:0 8px 24px var(--shadow-color);overflow:hidden}.track-menu-item[data-v-d49cf0a0]{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:none;border:none;color:var(--text-primary);font-size:13px;cursor:pointer;text-align:left;transition:all .15s;white-space:nowrap}.track-menu-item[data-v-d49cf0a0]:hover{background:var(--overlay-light);color:#fff}.track-menu-item[data-v-d49cf0a0]:active{background:var(--overlay-medium)}.playlist-slide-enter-active[data-v-d49cf0a0],.playlist-slide-leave-active[data-v-d49cf0a0]{transition:all .25s ease-in-out}.playlist-slide-enter-from[data-v-d49cf0a0],.playlist-slide-leave-to[data-v-d49cf0a0]{opacity:0;transform:scale(.95)}.context-menu-fade-enter-active[data-v-d49cf0a0],.context-menu-fade-leave-active[data-v-d49cf0a0]{transition:opacity .15s ease-in-out}.context-menu-fade-enter-from[data-v-d49cf0a0],.context-menu-fade-leave-to[data-v-d49cf0a0]{opacity:0}@keyframes fadeIn-d49cf0a0{0%{opacity:0}to{opacity:1}}.queue-section[data-v-d49cf0a0]{display:flex;gap:8px;margin-bottom:16px;padding-bottom:12px;justify-content:space-evenly;width:100%;flex-direction:row;flex-wrap:nowrap;align-content:stretch;align-items:stretch}.queue-section .queue-btn[data-v-d49cf0a0]{flex:1;width:auto}.queue-section .queue-btn svg[data-v-d49cf0a0]{flex-shrink:0;width:18px;height:18px}@media (max-width: 767px){.queue-panel[data-v-d49cf0a0]{max-width:100%;border-left:none}}.queue-panel-list[data-v-d49cf0a0]::-webkit-scrollbar{width:6px}.queue-panel-list[data-v-d49cf0a0]::-webkit-scrollbar-track{background:transparent}.queue-panel-list[data-v-d49cf0a0]::-webkit-scrollbar-thumb{background:var(--overlay-medium);border-radius:3px}.queue-panel-list[data-v-d49cf0a0]::-webkit-scrollbar-thumb:hover{background:var(--overlay-strong)}.lyrics-source-badge[data-v-d49cf0a0]{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);background:var(--overlay-light);border-radius:6px;padding:2px 8px;margin-left:auto;margin-right:8px;flex-shrink:0}.lyrics-panel .lyrics-container[data-v-d49cf0a0]{flex:1;overflow-y:auto;padding:40px 24px 80px;display:flex;flex-direction:column;align-items:center;scroll-behavior:smooth}.lyrics-panel .lyrics-container[data-v-d49cf0a0]::-webkit-scrollbar{width:4px}.lyrics-panel .lyrics-container[data-v-d49cf0a0]::-webkit-scrollbar-track{background:transparent}.lyrics-panel .lyrics-container[data-v-d49cf0a0]::-webkit-scrollbar-thumb{background:var(--overlay-medium);border-radius:2px}.lyrics-status[data-v-d49cf0a0]{color:var(--text-secondary);font-size:15px;text-align:center;margin-top:60px}.lyrics-line[data-v-d49cf0a0]{width:100%;text-align:center;font-size:20px;font-weight:700;line-height:1.5;padding:10px 0;color:var(--text-secondary);opacity:.4;transition:color .3s ease,opacity .3s ease,transform .2s ease;transform-origin:center center;cursor:default}.lyrics-line.lyrics-past[data-v-d49cf0a0]{opacity:.55}.lyrics-line.lyrics-current[data-v-d49cf0a0]{color:var(--text-primary);opacity:1;transform:scale(1.06)}.lyrics-panel .lyrics-line[data-v-d49cf0a0]{cursor:pointer}.tabs-section[data-v-d49cf0a0]{display:none}.back-toast[data-v-d49cf0a0]{position:fixed;bottom:100px;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:10px 20px;border-radius:20px;font-size:14px;z-index:10001;pointer-events:none;white-space:nowrap}.toast-fade-enter-active[data-v-d49cf0a0],.toast-fade-leave-active[data-v-d49cf0a0]{transition:opacity .3s ease}.toast-fade-enter-from[data-v-d49cf0a0],.toast-fade-leave-to[data-v-d49cf0a0]{opacity:0}.track-slide-left-enter-active[data-v-d49cf0a0],.track-slide-left-leave-active[data-v-d49cf0a0],.track-slide-right-enter-active[data-v-d49cf0a0],.track-slide-right-leave-active[data-v-d49cf0a0]{transition:all .3s cubic-bezier(.2,.9,.3,1)}.track-slide-left-enter-from[data-v-d49cf0a0]{transform:translate(30px);opacity:0}.track-slide-left-leave-to[data-v-d49cf0a0],.track-slide-right-enter-from[data-v-d49cf0a0]{transform:translate(-30px);opacity:0}.track-slide-right-leave-to[data-v-d49cf0a0]{transform:translate(30px);opacity:0}.app-container[data-v-ef641121]{width:100%;height:100vh;background:var(--bg-primary);color:var(--text-primary);display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.loading-screen[data-v-ef641121]{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:20px}.spinner[data-v-ef641121]{width:50px;height:50px;border:4px solid var(--overlay-light);border-top:4px solid var(--text-primary);border-radius:50%;animation:spin-ef641121 1s linear infinite}.update-progress[data-v-ef641121]{display:flex;align-items:center;gap:8px;min-width:180px}.update-progress-bar[data-v-ef641121]{position:relative;flex:1;height:8px;border-radius:999px;background:#ffffff38;overflow:hidden}.update-progress-fill[data-v-ef641121]{height:100%;border-radius:inherit;background:#ffffffe6;transition:width .2s ease}.update-progress-label[data-v-ef641121]{min-width:42px;font-size:13px;font-weight:600}@keyframes spin-ef641121{to{transform:rotate(360deg)}}.update-banner[data-v-ef641121]{position:fixed;top:12px;left:50%;transform:translate(-50%);background:#1db954;color:#fff;padding:8px 16px;border-radius:20px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:12px;z-index:99999;box-shadow:0 4px 12px #0000004d;white-space:nowrap}.update-banner-actions[data-v-ef641121]{display:flex;align-items:center;gap:6px}.update-btn[data-v-ef641121]{background:#ffffff40;border:none;color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;cursor:pointer}.update-btn[data-v-ef641121]:hover{background:#fff6}.update-dismiss[data-v-ef641121]{background:#00000026;border:none;color:#ffffffd9;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500;cursor:pointer}.update-dismiss[data-v-ef641121]:hover{background:#00000040}.update-slide-enter-active[data-v-ef641121],.update-slide-leave-active[data-v-ef641121]{transition:all .3s ease}.update-slide-enter-from[data-v-ef641121],.update-slide-leave-to[data-v-ef641121]{opacity:0;transform:translate(-50%) translateY(-20px)}:root{--bg-primary: #121212;--bg-secondary: #181818;--bg-tertiary: #282828;--bg-hover: #333333;--text-primary: #ffffff;--text-secondary: #b3b3b3;--border-color: #282828;--accent-color: #ffffff;--player-bg: #181818;--overlay-light: rgba(255, 255, 255, .1);--overlay-lighter: rgba(255, 255, 255, .05);--overlay-medium: rgba(255, 255, 255, .2);--overlay-strong: rgba(255, 255, 255, .3);--shadow-color: rgba(0, 0, 0, .5);--shadow-heavy: rgba(0, 0, 0, .8);--card-bg: #282828;--select-arrow-color: %23999;--btn-contrast-hover: #e0e0e0;--input-bg: #404040;--input-bg-focus: #535353;--modal-overlay: rgba(0, 0, 0, .7);--overlay-scrollbar: rgba(255, 255, 255, .5)}html.light{--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-tertiary: #e8e8e8;--bg-hover: #d5d5d5;--text-primary: #1a1a1a;--text-secondary: #666666;--border-color: #d0d0d0;--accent-color: #333333;--player-bg: #ffffff;--overlay-light: rgba(0, 0, 0, .06);--overlay-lighter: rgba(0, 0, 0, .03);--overlay-medium: rgba(0, 0, 0, .1);--overlay-strong: rgba(0, 0, 0, .15);--shadow-color: rgba(0, 0, 0, .15);--shadow-heavy: rgba(0, 0, 0, .3);--card-bg: #ffffff;--select-arrow-color: %23555;--btn-contrast-hover: #333333;--input-bg: #e0e0e0;--input-bg-focus: #d0d0d0;--modal-overlay: rgba(0, 0, 0, .4);--overlay-scrollbar: rgba(0, 0, 0, .25)}html.oled{--bg-primary: #000000;--bg-secondary: #0a0a0a;--bg-tertiary: #111111;--bg-hover: #1a1a1a;--text-primary: #ffffff;--text-secondary: #b3b3b3;--border-color: #1a1a1a;--accent-color: #ffffff;--player-bg: #000000;--overlay-light: rgba(255, 255, 255, .1);--overlay-lighter: rgba(255, 255, 255, .05);--overlay-medium: rgba(255, 255, 255, .2);--overlay-strong: rgba(255, 255, 255, .3);--shadow-color: rgba(0, 0, 0, .8);--shadow-heavy: rgba(0, 0, 0, 1);--card-bg: #111111;--select-arrow-color: %23999;--btn-contrast-hover: #e0e0e0;--input-bg: #1a1a1a;--input-bg-focus: #222222;--modal-overlay: rgba(0, 0, 0, .85);--overlay-scrollbar: rgba(255, 255, 255, .5)}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg-primary);color:var(--text-primary)}*{margin:0;padding:0;box-sizing:border-box;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}:focus:not(:focus-visible){outline:none!important}:focus-visible{outline:2px solid var(--accent-primary, #1db954);outline-offset:2px}input,textarea,[contenteditable]{user-select:text;-webkit-user-select:text}html,body,#app{width:100%;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:var(--bg-primary);color:var(--text-primary);overflow:hidden}#app{padding-top:var(--sat)}body{background:var(--bg-primary)}:root{--sat: env(safe-area-inset-top, 0px);--sab: env(safe-area-inset-bottom, 0px);--color-primary: #fff;--color-primary-dark: #cccccc;--color-primary-light: #e0e0e0;--color-bg-primary: #121212;--color-bg-secondary: #181818;--color-bg-tertiary: #282828;--color-text-primary: #ffffff;--color-text-secondary: #b3b3b3;--color-border: #404040}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}button:focus,input:focus,a:focus{outline:2px solid var(--color-primary);outline-offset:2px}::selection{background:var(--color-primary);color:#000}img.lazy-loading{opacity:0}.lazy-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000040;display:none;align-items:center;justify-content:center;pointer-events:none}.lazy-loading-overlay:before{content:"";width:24px;height:24px;border-radius:50%;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;animation:lazy-spin .8s linear infinite}@keyframes lazy-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.playlist-cover:has(img.lazy-loading),.track-row:has(img.lazy-loading){position:relative}.playlist-cover:has(img.lazy-loading)>.lazy-loading-overlay,.track-row:has(img.lazy-loading)>.lazy-loading-overlay{display:flex}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
