.mini-player[data-v-fbeb6385]{position:fixed;bottom:var(--nav-height);left:0;right:0;height:var(--player-height);background:var(--bg-elevated);z-index:99;cursor:pointer;transition:transform var(--transition-normal)}.mini-player[data-v-fbeb6385]:active{transform:scale(.98)}.progress-bar[data-v-fbeb6385]{position:absolute;top:0;left:0;right:0;height:2px;background:var(--bg-highlight)}.progress-fill[data-v-fbeb6385]{height:100%;background:var(--accent);transition:width .1s linear}.player-content[data-v-fbeb6385]{display:flex;align-items:center;justify-content:space-between;height:100%;padding:var(--spacing-sm) var(--spacing-md)}.track-info[data-v-fbeb6385]{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:0}.track-cover[data-v-fbeb6385]{width:48px;height:48px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0}.cover-image[data-v-fbeb6385]{width:100%;height:100%;object-fit:cover}.cover-placeholder[data-v-fbeb6385]{width:100%;height:100%;background:var(--bg-highlight);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.cover-placeholder svg[data-v-fbeb6385]{width:24px;height:24px}.track-meta[data-v-fbeb6385]{display:flex;flex-direction:column;min-width:0;gap:2px}.track-title[data-v-fbeb6385]{font-size:var(--font-size-md);font-weight:500;color:var(--text-primary)}.track-artist[data-v-fbeb6385]{font-size:var(--font-size-sm);color:var(--text-secondary)}.controls[data-v-fbeb6385]{display:flex;align-items:center;gap:var(--spacing-sm)}.control-btn[data-v-fbeb6385]{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);transition:all var(--transition-fast);color:var(--text-primary)}.control-btn[data-v-fbeb6385]:active{transform:scale(.9)}.nav-btn[data-v-fbeb6385]{color:var(--text-secondary)}.nav-btn[data-v-fbeb6385]:disabled{opacity:.3}.nav-btn svg[data-v-fbeb6385]{width:20px;height:20px}.play-btn[data-v-fbeb6385]{background:var(--text-primary);color:var(--bg-primary)}.play-btn svg[data-v-fbeb6385]{width:20px;height:20px}.play-btn[data-v-fbeb6385]:disabled{opacity:.7}.loader[data-v-fbeb6385]{width:16px;height:16px;border:2px solid var(--bg-primary);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.sheet-overlay[data-v-93e9f860]{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:flex-end;z-index:1200;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.sheet[data-v-93e9f860]{background:var(--bg-elevated);width:100%;max-height:min(78vh,640px);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--spacing-sm) var(--spacing-md) var(--spacing-md);padding-bottom:calc(var(--spacing-lg) + env(safe-area-inset-bottom));display:flex;flex-direction:column;min-height:0}.sheet-handle[data-v-93e9f860]{width:36px;height:4px;background:var(--text-muted);border-radius:2px;margin:0 auto var(--spacing-md);opacity:.5}.sheet-title[data-v-93e9f860]{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin:0 0 var(--spacing-xs);text-align:center}.sheet-subtitle[data-v-93e9f860]{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0 0 var(--spacing-md);text-align:center}.sheet-loading[data-v-93e9f860]{display:flex;justify-content:center;padding:var(--spacing-xl)}.sheet-error[data-v-93e9f860]{color:#f87171;font-size:var(--font-size-sm);text-align:center;padding:var(--spacing-md)}.sheet-list[data-v-93e9f860]{overflow-y:auto;flex:1;min-height:120px;-webkit-overflow-scrolling:touch}.picker-row[data-v-93e9f860]{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);width:100%;padding:var(--spacing-md) var(--spacing-sm);border:none;background:transparent;border-radius:var(--radius-md);cursor:pointer;text-align:left;color:inherit;font:inherit}.picker-row[data-v-93e9f860]:active:not(:disabled){background:var(--bg-highlight)}.picker-row[data-v-93e9f860]:disabled{opacity:.85}.picker-row-text[data-v-93e9f860]{min-width:0;flex:1}.picker-name[data-v-93e9f860]{display:block;font-weight:600;color:var(--text-primary);font-size:var(--font-size-md)}.picker-meta[data-v-93e9f860]{display:block;font-size:var(--font-size-sm);color:var(--text-muted);margin-top:2px}.round-check[data-v-93e9f860]{position:relative;flex-shrink:0;width:24px;height:24px;border-radius:50%;border:2px solid var(--text-muted);box-sizing:border-box;transition:background .15s ease,border-color .15s ease}.round-check.on[data-v-93e9f860]{border-color:var(--accent);background:var(--accent)}.round-check.on[data-v-93e9f860]:after{content:"";position:absolute;left:50%;top:45%;width:5px;height:9px;border:solid var(--bg-primary);border-width:0 2px 2px 0;transform:translate(-50%,-50%) rotate(45deg);box-sizing:border-box}.round-check.busy[data-v-93e9f860]{opacity:.5}.sheet-done[data-v-93e9f860]{margin-top:var(--spacing-md);width:100%;padding:var(--spacing-md);border:none;border-radius:var(--radius-full);background:var(--bg-highlight);color:var(--text-primary);font-weight:600;font-size:var(--font-size-md)}.menu-enter-active[data-v-93e9f860],.menu-leave-active[data-v-93e9f860]{transition:opacity var(--motion-duration-overlay) var(--motion-ease-standard)}.menu-enter-active .sheet[data-v-93e9f860],.menu-leave-active .sheet[data-v-93e9f860]{transition:transform var(--motion-duration-sheet) var(--motion-ease-sheet)}.menu-enter-from[data-v-93e9f860],.menu-leave-to[data-v-93e9f860]{opacity:0}.menu-enter-from .sheet[data-v-93e9f860],.menu-leave-to .sheet[data-v-93e9f860]{transform:translateY(100%)}.menu-leave-active[data-v-93e9f860]{pointer-events:none}.loader[data-v-93e9f860]{width:28px;height:28px;border:3px solid var(--bg-highlight);border-top-color:var(--accent);border-radius:50%;animation:spin-93e9f860 .7s linear infinite}@keyframes spin-93e9f860{to{transform:rotate(360deg)}}.truncate[data-v-93e9f860]{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.full-player[data-v-c257797b]{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-primary);z-index:150;display:flex;flex-direction:column}.player-top-bar[data-v-c257797b]{position:sticky;top:0;z-index:20;flex-shrink:0;background:var(--bg-primary);margin-left:calc(-1 * var(--spacing-md));margin-right:calc(-1 * var(--spacing-md));padding-left:var(--spacing-md);padding-right:var(--spacing-md);padding-bottom:var(--spacing-xs)}.player-grabber-wrap[data-v-c257797b]{display:flex;justify-content:center;padding:var(--spacing-xs) 0 var(--spacing-sm);margin-top:2px}.player-grabber[data-v-c257797b]{width:40px;height:5px;border-radius:3px;background:var(--text-muted);opacity:.4}.player-scroll-container[data-v-c257797b]{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;padding:var(--spacing-md);padding-top:calc(var(--spacing-md) + env(safe-area-inset-top));padding-bottom:calc(var(--spacing-lg) + env(safe-area-inset-bottom));-webkit-overflow-scrolling:touch}.header[data-v-c257797b]{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) 0;flex-shrink:0}.close-btn[data-v-c257797b],.menu-btn[data-v-c257797b]{width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--text-primary)}.close-btn svg[data-v-c257797b],.menu-btn svg[data-v-c257797b]{width:24px;height:24px}.chevron-down[data-v-c257797b]{transform:rotate(90deg)}.header-title[data-v-c257797b]{font-size:var(--font-size-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.cover-section[data-v-c257797b]{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);padding-top:var(--spacing-xl);min-height:200px;position:relative;z-index:0}.cover-art[data-v-c257797b]{width:100%;max-width:320px;aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 16px 48px #00000073;isolation:isolate}.cover-image[data-v-c257797b]{width:100%;height:100%;object-fit:cover}.cover-placeholder[data-v-c257797b]{width:100%;height:100%;background:linear-gradient(135deg,var(--bg-elevated),var(--bg-highlight));display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.cover-placeholder svg[data-v-c257797b]{width:80px;height:80px}.track-info[data-v-c257797b]{text-align:center;padding:var(--spacing-md) 0}.track-title[data-v-c257797b]{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.track-artist[data-v-c257797b]{font-size:var(--font-size-md);color:var(--text-secondary)}.progress-section[data-v-c257797b]{padding:var(--spacing-md) 0}.progress-bar[data-v-c257797b]{height:4px;background:var(--bg-highlight);border-radius:2px;position:relative;cursor:pointer}.progress-fill[data-v-c257797b]{height:100%;background:var(--accent);border-radius:2px;transition:width .1s linear}.progress-thumb[data-v-c257797b]{position:absolute;top:50%;width:12px;height:12px;background:var(--accent);border-radius:50%;transform:translate(-50%,-50%);opacity:0;transition:opacity var(--transition-fast)}.progress-bar:hover .progress-thumb[data-v-c257797b],.progress-bar:active .progress-thumb[data-v-c257797b],.progress-bar.dragging .progress-thumb[data-v-c257797b]{opacity:1}.progress-bar.dragging[data-v-c257797b]{height:6px}.progress-bar.dragging .progress-fill[data-v-c257797b]{transition:none}.time-info[data-v-c257797b]{display:flex;justify-content:space-between;margin-top:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--text-muted)}.controls[data-v-c257797b]{display:flex;align-items:center;justify-content:center;gap:var(--spacing-lg);padding:var(--spacing-lg) 0}.control-btn[data-v-c257797b]{width:48px;height:48px;display:flex;align-items:center;justify-content:center;color:var(--text-primary);border-radius:var(--radius-full);transition:all var(--transition-fast)}.control-btn[data-v-c257797b]:active{transform:scale(.9)}.control-btn.secondary[data-v-c257797b]{width:40px;height:40px;color:var(--text-secondary)}.control-btn.secondary.active[data-v-c257797b]{color:var(--accent)}.control-btn.secondary svg[data-v-c257797b]{width:22px;height:22px}.control-btn svg[data-v-c257797b]{width:28px;height:28px}.play-btn[data-v-c257797b]{width:64px;height:64px;background:var(--accent);color:var(--bg-primary)}.play-btn svg[data-v-c257797b]{width:32px;height:32px}.play-btn[data-v-c257797b]:disabled{opacity:.7}.loader[data-v-c257797b]{width:24px;height:24px;border:3px solid var(--bg-primary);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.bottom-actions[data-v-c257797b]{display:flex;justify-content:center;gap:var(--spacing-xl);padding:var(--spacing-md) 0}.action-btn[data-v-c257797b]{width:48px;height:48px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:color var(--transition-fast)}.action-btn.active[data-v-c257797b]{color:var(--accent)}.action-btn svg[data-v-c257797b]{width:24px;height:24px}.queue-btn[data-v-c257797b]{position:relative}.queue-badge[data-v-c257797b]{position:absolute;top:4px;right:4px;min-width:16px;height:16px;background:var(--accent);color:var(--bg-primary);font-size:10px;font-weight:700;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}.menu-overlay[data-v-c257797b]{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:flex-end;z-index:1100;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.menu[data-v-c257797b]{background:var(--bg-elevated);width:100%;border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--spacing-sm) var(--spacing-md) var(--spacing-md);padding-bottom:calc(var(--spacing-lg) + env(safe-area-inset-bottom))}.menu-handle[data-v-c257797b]{width:36px;height:4px;background:var(--text-muted);border-radius:2px;margin:0 auto var(--spacing-md);opacity:.5}.menu-item[data-v-c257797b]{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-md);transition:background var(--transition-fast)}.menu-item[data-v-c257797b]:active{background:var(--bg-highlight)}.menu-item.cancel[data-v-c257797b]{justify-content:center;color:var(--text-secondary);margin-top:var(--spacing-sm);border-top:1px solid var(--bg-highlight);padding-top:var(--spacing-lg)}.menu-item svg[data-v-c257797b]{width:22px;height:22px;flex-shrink:0;color:var(--text-secondary)}.menu-enter-active[data-v-c257797b],.menu-leave-active[data-v-c257797b]{transition:opacity var(--motion-duration-overlay) var(--motion-ease-standard)}.menu-enter-active .menu[data-v-c257797b],.menu-leave-active .menu[data-v-c257797b]{transition:transform var(--motion-duration-sheet) var(--motion-ease-sheet)}.menu-enter-from[data-v-c257797b],.menu-leave-to[data-v-c257797b]{opacity:0}.menu-enter-from .menu[data-v-c257797b],.menu-leave-to .menu[data-v-c257797b]{transform:translateY(100%)}.menu-leave-active[data-v-c257797b]{pointer-events:none}.bottom-nav[data-v-b82fddd7]{position:fixed;bottom:0;left:0;right:0;height:var(--nav-height);background:linear-gradient(to top,var(--bg-primary) 85%,transparent);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;justify-content:space-around;align-items:center;z-index:1000;border-top:1px solid var(--border);touch-action:manipulation}.nav-item[data-v-b82fddd7]{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:var(--spacing-sm) var(--spacing-md);color:var(--text-secondary);transition:color var(--transition-fast);background:none;border:none;font:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent}.nav-item.active[data-v-b82fddd7]{color:var(--text-primary)}.nav-icon[data-v-b82fddd7]{width:24px;height:24px}.nav-label[data-v-b82fddd7]{font-size:var(--font-size-xs);font-weight:500}.app[data-v-bba9d81d]{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;background:var(--bg-primary)}.main-content[data-v-bba9d81d]{flex:1;overflow-y:auto;padding-bottom:calc(var(--nav-height) + env(safe-area-inset-bottom))}.app.player-open .main-content[data-v-bba9d81d]{padding-bottom:calc(var(--nav-height) + var(--player-height) + env(safe-area-inset-bottom))}.fade-enter-active[data-v-bba9d81d],.fade-leave-active[data-v-bba9d81d]{transition:opacity var(--motion-duration-page) var(--motion-ease-standard)}.fade-enter-from[data-v-bba9d81d],.fade-leave-to[data-v-bba9d81d]{opacity:0}[data-v-bba9d81d] .player-sheet-enter-active,[data-v-bba9d81d] .player-sheet-leave-active{transition:transform var(--motion-duration-player) var(--motion-ease-sheet)}[data-v-bba9d81d] .player-sheet-enter-from,[data-v-bba9d81d] .player-sheet-leave-to{transform:translateY(100%)}.not-telegram[data-v-bba9d81d]{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:var(--spacing-lg)}.not-telegram-content[data-v-bba9d81d]{text-align:center}.tg-icon[data-v-bba9d81d]{font-size:64px;margin-bottom:var(--spacing-lg)}.not-telegram h1[data-v-bba9d81d]{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-sm);color:var(--text-primary)}.not-telegram p[data-v-bba9d81d]{color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.tg-link[data-v-bba9d81d]{display:inline-block;padding:var(--spacing-md) var(--spacing-xl);background:var(--accent);color:var(--bg-primary);border-radius:var(--radius-full);font-weight:600}:root{--spotify-green: #1DB954;--spotify-green-hover: #1ed760;--spotify-black: #121212;--spotify-dark: #181818;--spotify-gray: #282828;--spotify-light-gray: #b3b3b3;--spotify-white: #ffffff;--bg-primary: #121212;--bg-secondary: #181818;--bg-elevated: #282828;--bg-highlight: #333333;--text-primary: #ffffff;--text-secondary: #b3b3b3;--text-muted: #727272;--accent: #1DB954;--accent-hover: #1ed760;--border: rgba(255, 255, 255, .1);--shadow: rgba(0, 0, 0, .5);--nav-height: 56px;--player-height: 64px;--header-height: 56px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 20px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--motion-ease-sheet: cubic-bezier(.32, .72, 0, 1);--motion-ease-emphasized: cubic-bezier(.2, .8, .2, 1);--motion-ease-standard: cubic-bezier(.4, 0, .2, 1);--motion-duration-sheet: .34s;--motion-duration-overlay: .34s;--motion-duration-modal: .3s;--motion-duration-player: .4s;--motion-duration-page: .2s;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif;--font-size-xs: 11px;--font-size-sm: 13px;--font-size-md: 14px;--font-size-lg: 16px;--font-size-xl: 20px;--font-size-2xl: 24px;--font-size-3xl: 32px}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-elevated: #e8e8e8;--bg-highlight: #d9d9d9;--text-primary: #121212;--text-secondary: #535353;--text-muted: #888888;--border: rgba(0, 0, 0, .1);--shadow: rgba(0, 0, 0, .15)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-family);font-size:var(--font-size-md);line-height:1.5;color:var(--text-primary);background:var(--bg-primary);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button{font-family:inherit;font-size:inherit;border:none;background:none;cursor:pointer;color:inherit}input{font-family:inherit;font-size:inherit;border:none;background:none;outline:none;color:inherit}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-highlight);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent)}.bg-primary{background:var(--bg-primary)}.bg-secondary{background:var(--bg-secondary)}.bg-elevated{background:var(--bg-elevated)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.animate-pulse{animation:pulse 2s infinite}.animate-spin{animation:spin 1s linear infinite}.safe-bottom{padding-bottom:env(safe-area-inset-bottom)}.safe-top{padding-top:env(safe-area-inset-top)}@media (prefers-reduced-motion: reduce){:root{--motion-duration-sheet: .01ms;--motion-duration-overlay: .01ms;--motion-duration-modal: .01ms;--motion-duration-player: .01ms;--motion-duration-page: .01ms}}
