:root{--neon-enabled:1;--bg-primary:#0d0d12;--bg-secondary:#161620;--bg-tertiary:#1e1e2a;--bg-elevated:#262636;--border-color:#ffffff1a;--border-hover:#ffffff2e;--border-focus:#f59e0b80;--text-primary:#f5f5f7;--text-secondary:#a8a8b3;--text-muted:#6b6b7a;--text-inverse:#0d0d12;--accent:#f59e0b;--accent-hover:#fbbf24;--accent-dim:#f59e0b26;--accent-active:#d97706;--neon-glow-base:#f59e0b26;--neon-glow-hover:#f59e0b59;--neon-glow-active:#5fd06866;--error:#ff6b6b;--error-dim:#ff6b6b1f;--success:#5fd068;--success-dim:#5fd0681f;--warning:#ffb347;--warning-dim:#ffb3471f;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px #0000004d;--shadow-lg:0 10px 20px #0006;--transition-fast:0.15s ease;--transition-normal:0.25s ease;--transition-slow:0.35s ease;--transition-smooth:0.3s cubic-bezier(0.4,0,0.2,1);--transition-bounce:0.4s cubic-bezier(0.34,1.56,0.64,1)}[data-neon=disabled]{--neon-enabled:0}[data-theme=light]{--bg-primary:#f5f5f7;--bg-secondary:#fff;--bg-tertiary:#e8e8ed;--bg-elevated:#fff;--border-color:#0000001a;--border-hover:#0000002e;--border-focus:#3b5bdb80;--text-primary:#1a1a1f;--text-secondary:#5a5a6e;--text-muted:#8a8a9a;--text-inverse:#f5f5f7;--accent:#3b5bdb;--accent-hover:#5472e4;--accent-dim:#3b5bdb1f;--accent-active:#2f4bc0;--neon-glow-base:#3b5bdb33;--neon-glow-hover:#3b5bdb66;--neon-glow-active:#43a04780;--error:#e53935;--error-dim:#e539351f;--success:#43a047;--success-dim:#43a0471f;--warning:#fb8c00;--warning-dim:#fb8c001f;--shadow-sm:0 1px 2px #00000014;--shadow-md:0 4px 6px #0000001a;--shadow-lg:0 10px 20px #0000001f}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;min-height:100vh;overflow:auto}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.pending-page{align-items:center;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:24px;position:relative}.pending-bg-glow{background:radial-gradient(circle,#f59e0b0f 0,#0000 70%);height:700px;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:700px}.pending-notes-container{align-items:center;display:flex;inset:0;justify-content:center;pointer-events:none;position:absolute}.pending-note{color:var(--accent);font-size:24px;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none}.pending-card{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#161620d9;border:1px solid var(--border-color);border-radius:16px;box-shadow:0 24px 64px #00000080,0 0 40px #f59e0b0d;max-width:420px;padding:40px;position:relative;text-align:center;width:100%;z-index:1}.pending-icon-wrap{height:72px;margin:0 auto 24px;position:relative;width:72px}.pending-icon{background:var(--accent-dim);border:1px solid var(--border-focus);border-radius:18px;color:var(--accent);height:72px;width:72px}.pending-clock,.pending-icon{align-items:center;display:flex;justify-content:center}.pending-clock{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:50%;bottom:-6px;color:var(--text-muted);height:28px;position:absolute;right:-6px;width:28px}.pending-title{color:var(--text-primary);font-size:22px;font-weight:700;margin:0 0 8px}.pending-subtitle{color:var(--accent);font-size:14px;font-weight:500;margin:0 0 24px}.pending-user{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);display:flex;gap:12px;margin-bottom:20px;padding:12px 16px;text-align:left}.pending-avatar{border:2px solid var(--border-focus);border-radius:50%;flex-shrink:0;height:40px;object-fit:cover;width:40px}.pending-user-info{display:flex;flex-direction:column;gap:2px;min-width:0}.pending-user-name{color:var(--text-primary);font-size:14px;font-weight:600}.pending-user-email{color:var(--text-muted);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pending-message{color:var(--text-secondary);font-size:13px;line-height:1.6;margin:0 0 28px}.pending-logout{align-items:center;background:none;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;display:inline-flex;font-size:13px;gap:8px;padding:10px 20px;transition:all var(--transition-smooth)}.pending-logout:hover{border-color:var(--error);color:var(--error)}.admin-page{max-width:700px;padding:32px}.admin-loading{align-items:center;display:flex;height:200px;justify-content:center}.admin-spinner{animation:admin-spin .7s linear infinite;border:2px solid var(--border-color);border-radius:50%;border-top-color:var(--accent);height:32px;width:32px}@keyframes admin-spin{to{transform:rotate(1turn)}}.admin-header{align-items:center;display:flex;gap:10px;margin-bottom:32px}.admin-header-icon{color:var(--accent)}.admin-title{color:var(--text-primary);font-size:22px;font-weight:700;margin:0}.admin-section{margin-bottom:36px}.admin-section-header{align-items:center;color:var(--text-muted);display:flex;gap:8px;margin-bottom:16px}.admin-section-header h2{align-items:center;color:var(--text-secondary);display:flex;font-size:14px;font-weight:600;gap:8px;letter-spacing:.5px;margin:0;text-transform:uppercase}.admin-count{background:var(--accent-dim);border-radius:10px;color:var(--accent);font-size:11px;font-weight:700;letter-spacing:0;padding:2px 7px;text-transform:none}.admin-empty{color:var(--text-muted);font-size:13px;padding:16px 0}.admin-user-list{display:flex;flex-direction:column;gap:8px}.admin-user-card{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);display:flex;gap:16px;justify-content:space-between;padding:14px 16px;transition:border-color var(--transition-fast)}.admin-user-card:hover{border-color:var(--border-focus)}.admin-user-card--approved{opacity:.75}.admin-user-info{align-items:center;display:flex;gap:12px;min-width:0}.admin-avatar{border:1px solid var(--border-color);border-radius:50%;flex-shrink:0;height:40px;object-fit:cover;width:40px}.admin-avatar-placeholder{align-items:center;background:var(--bg-tertiary);color:var(--text-muted);display:flex;font-size:16px;font-weight:600;justify-content:center}.admin-user-text{display:flex;flex-direction:column;gap:2px;min-width:0}.admin-user-name{align-items:center;color:var(--text-primary);display:flex;font-size:14px;font-weight:600;gap:6px}.admin-badge{background:var(--accent-dim);border-radius:4px;color:var(--accent);font-size:10px;font-weight:700;letter-spacing:.5px;padding:1px 6px;text-transform:uppercase}.admin-user-email{color:var(--text-muted);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-actions{display:flex;flex-shrink:0;gap:8px}.admin-btn{align-items:center;background:none;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;display:flex;height:34px;justify-content:center;transition:all var(--transition-fast);width:34px}.admin-btn:disabled{cursor:not-allowed;opacity:.4}.admin-btn-approve:hover:not(:disabled){background:#34d3991a;border-color:#34d39966;color:#34d399}.admin-btn-reject:hover:not(:disabled){background:#ff6b6b1a;border-color:#ff6b6b66;color:var(--error)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 15px var(--neon-glow-base)}50%{box-shadow:0 0 30px var(--neon-glow-hover)}}@keyframes spin-slow{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes equalizer-bar-1{0%,to{height:20%}25%{height:80%}50%{height:40%}75%{height:90%}}@keyframes equalizer-bar-2{0%,to{height:50%}30%{height:90%}60%{height:30%}80%{height:70%}}@keyframes equalizer-bar-3{0%,to{height:30%}20%{height:70%}45%{height:90%}70%{height:20%}}@keyframes marquee{0%{transform:translateX(0)}to{transform:translateX(-50%)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.03)}}@keyframes neon-flicker{0%,to{opacity:1}92%{opacity:1}93%{opacity:.8}94%{opacity:1}96%{opacity:.9}97%{opacity:1}}@keyframes gradient-shift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.animate-float{animation:float 3s ease-in-out infinite}.animate-pulse-glow{animation:pulse-glow 2s ease-in-out infinite}.animate-breathe{animation:breathe 4s ease-in-out infinite}.animate-fade-in{animation:fade-in .3s ease-out}.animate-slide-up{animation:slide-up .4s ease-out}.app-shell{background:var(--bg-primary);color:var(--text-primary);display:flex}.app-main,.app-shell{min-height:100vh;position:relative}.app-main{flex:1 1;margin-left:240px;overflow-y:auto;padding:24px 32px 120px;z-index:1}@media (max-width:1024px){.app-main{margin-left:64px;padding:20px 24px 120px}}@media (max-width:768px){.app-main{margin-left:0;padding:16px 16px 180px}}.sidebar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0d0d12d9;border-right:1px solid var(--border-color);bottom:0;display:flex;flex-direction:column;left:0;padding:24px 16px;position:fixed;top:0;width:240px;z-index:10}.sidebar-brand{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:12px;margin-bottom:24px;padding:0 8px 24px}.sidebar-logo{color:var(--accent);filter:drop-shadow(0 0 8px var(--neon-glow-base))}.sidebar-title{color:var(--text-primary);font-size:18px;font-weight:700;letter-spacing:1px}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:4px}.sidebar-link{align-items:center;border-radius:var(--radius-lg);color:var(--text-secondary);display:flex;font-size:14px;font-weight:500;gap:12px;padding:12px 16px;text-decoration:none;transition:all var(--transition-smooth)}.sidebar-link:hover{background:#ffffff0d;color:var(--text-primary)}.sidebar-link.active{background:var(--accent-dim);box-shadow:0 0 15px var(--neon-glow-base);color:var(--accent)}.sidebar-link.active svg{filter:drop-shadow(0 0 6px var(--neon-glow-hover))}.sidebar-footer{align-items:center;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;padding:16px 8px 0}.sidebar-user{color:var(--text-muted);font-size:13px}.sidebar-logout{background:none;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;padding:6px;transition:all var(--transition-fast)}.sidebar-logout:hover{background:var(--error-dim);color:var(--error)}@media (max-width:1024px){.sidebar{align-items:center;padding:16px 8px;width:64px}.sidebar-brand{margin-bottom:16px;padding:0 0 16px}.sidebar-title{display:none}.sidebar-link{justify-content:center;padding:12px}.sidebar-link span{display:none}.sidebar-footer{flex-direction:column;gap:8px;padding:12px 0 0}.sidebar-user{display:none}}@media (max-width:768px){.sidebar{display:none}}.mobile-tabs{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0d0d12f2;border-top:1px solid var(--border-color);bottom:0;display:none;left:0;padding:8px 0 calc(8px + env(safe-area-inset-bottom));position:fixed;right:0;z-index:20}@media (max-width:768px){.mobile-tabs{display:flex;justify-content:space-around}}.mobile-tab{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;font-size:10px;gap:4px;padding:6px 16px;text-decoration:none;transition:color var(--transition-fast)}.mobile-tab.active{color:var(--accent)}.mobile-tab.active svg{filter:drop-shadow(0 0 6px var(--neon-glow-hover))}.bottom-player{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#161620eb;border-top:1px solid var(--border-color);bottom:0;left:240px;position:fixed;right:0;z-index:15}@media (max-width:1024px){.bottom-player{left:64px}}@media (max-width:768px){.bottom-player{bottom:56px;left:0}}.bottom-player-progress{background:#ffffff14;cursor:pointer;height:3px;transition:height var(--transition-fast)}.bottom-player-progress:hover{height:5px}.bottom-player-progress-fill{background:var(--accent);border-radius:0 2px 2px 0;box-shadow:0 0 8px var(--neon-glow-base);height:100%;transition:width .1s linear}.bottom-player-content{align-items:center;display:flex;gap:16px;justify-content:space-between;padding:10px 20px}.bottom-player-info{align-items:center;cursor:pointer;display:flex;flex:1 1;gap:12px;min-width:0;transition:opacity var(--transition-fast)}.bottom-player-info:hover{opacity:.8}.bottom-player-cover{background:var(--bg-tertiary);border-radius:var(--radius-md);flex-shrink:0;height:44px;overflow:hidden;position:relative;width:44px}.bottom-player-cover img{height:100%;object-fit:cover;width:100%}.bottom-player-cover-fallback{align-items:center;background:linear-gradient(135deg,var(--accent),#ff6b35);color:var(--text-inverse);display:flex;font-size:16px;font-weight:700;height:100%;justify-content:center;width:100%}.bottom-player-text{min-width:0}.bottom-player-title{color:var(--text-primary);font-size:14px;font-weight:600}.bottom-player-artist,.bottom-player-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bottom-player-artist{color:var(--text-muted);font-size:12px}.bottom-player-controls{align-items:center;display:flex;flex-shrink:0;gap:8px}.player-btn{align-items:center;background:none;border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all var(--transition-smooth)}.player-btn:hover{background:#ffffff14;color:var(--text-primary)}.player-btn-main{background:var(--accent);box-shadow:0 0 15px var(--neon-glow-base);color:var(--text-inverse);height:40px;width:40px}.player-btn-main:hover{background:var(--accent-hover);box-shadow:0 0 25px var(--neon-glow-hover);color:var(--text-inverse);transform:scale(1.05)}.album-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;overflow:hidden;transition:all var(--transition-smooth)}.album-card:hover{border-color:var(--border-hover);box-shadow:0 8px 32px #0006,0 0 20px var(--neon-glow-base);transform:translateY(-4px)}.album-card-art{background:var(--bg-tertiary);padding-top:100%;position:relative}.album-card-art img,.album-card-art-fallback{height:100%;left:0;object-fit:cover;position:absolute;top:0;width:100%}.album-card-art-fallback{align-items:center;display:flex;justify-content:center}.album-card-art-icon{color:#fff6}.album-card-overlay{align-items:center;background:#00000080;display:flex;height:100%;justify-content:center;left:0;opacity:0;position:absolute;top:0;transition:opacity var(--transition-normal);width:100%}.album-card:hover .album-card-overlay{opacity:1}.album-card-play{align-items:center;background:var(--accent);border-radius:50%;box-shadow:0 0 24px var(--neon-glow-hover);color:var(--text-inverse);display:flex;height:52px;justify-content:center;transition:transform var(--transition-bounce);width:52px}.album-card:hover .album-card-play{transform:scale(1.1)}.album-card-info{padding:12px}.album-card-name{color:var(--text-primary);font-size:14px;font-weight:600}.album-card-meta,.album-card-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.album-card-meta{color:var(--text-muted);font-size:12px;margin-top:2px}.track-row{grid-gap:12px;align-items:center;border-radius:var(--radius-md);cursor:pointer;display:grid;gap:12px;grid-template-columns:40px 1fr auto;padding:8px 12px;transition:background var(--transition-fast)}.track-row:hover{background:#ffffff0d}.track-row.active{background:var(--accent-dim)}.track-row-index{align-items:center;display:flex;height:32px;justify-content:center;position:relative;width:32px}.track-row-num{font-feature-settings:"tnum";color:var(--text-muted);font-size:14px;font-variant-numeric:tabular-nums}.track-row-num.active-num{color:var(--accent)}.track-row-hover-play{align-items:center;color:var(--text-primary);display:flex;height:100%;justify-content:center;left:0;opacity:0;position:absolute;top:0;transition:opacity var(--transition-fast);width:100%}.track-row:hover .track-row-num{opacity:0}.track-row:hover .track-row-hover-play{opacity:1}.track-row-info{min-width:0}.track-row-title{color:var(--text-primary);font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-row.active .track-row-title{color:var(--accent)}.track-row-artist{color:var(--text-muted);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-row-actions{align-items:center;display:flex;gap:8px;opacity:0;transition:opacity var(--transition-fast)}.track-row.active .track-row-actions,.track-row:hover .track-row-actions{opacity:1}.track-row-duration{font-feature-settings:"tnum";color:var(--text-muted);font-size:13px;font-variant-numeric:tabular-nums;min-width:36px;text-align:right}.equalizer-icon{align-items:flex-end;display:flex;gap:2px;height:16px}.eq-bar{background:var(--accent);border-radius:1px;box-shadow:0 0 4px var(--neon-glow-base);width:3px}.eq-bar-1{animation:equalizer-bar-1 .8s ease-in-out infinite}.eq-bar-2{animation:equalizer-bar-2 .9s ease-in-out infinite}.eq-bar-3{animation:equalizer-bar-3 .7s ease-in-out infinite}.like-btn{align-items:center;background:none;border:none;border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all var(--transition-bounce)}.like-btn:hover{color:var(--error);transform:scale(1.15)}.like-btn.liked{animation:like-pop .3s var(--transition-bounce);color:var(--error);filter:drop-shadow(0 0 6px rgba(255,107,107,.5))}@keyframes like-pop{0%{transform:scale(1)}50%{transform:scale(1.4)}to{transform:scale(1)}}.progress-wrap{align-items:center;display:flex;gap:12px;width:100%}.progress-time{font-feature-settings:"tnum";color:var(--text-muted);flex-shrink:0;font-size:12px;font-variant-numeric:tabular-nums;min-width:36px}.progress-bar{cursor:pointer;flex:1 1;padding:8px 0;position:relative}.progress-track{background:#ffffff1a;border-radius:2px;height:4px;position:relative;transition:height var(--transition-fast)}.progress-bar.dragging .progress-track,.progress-bar:hover .progress-track{height:6px}.progress-fill{border-radius:2px;height:100%;transition:width .1s linear}.progress-thumb{border-radius:50%;height:14px;position:absolute;top:50%;transform:translate(-50%,-50%) scale(0);transition:transform var(--transition-fast),left .1s linear;width:14px}.progress-bar.dragging .progress-thumb,.progress-bar:hover .progress-thumb{transform:translate(-50%,-50%) scale(1)}.progress-hover-time{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-sm);bottom:16px;color:var(--text-secondary);font-size:11px;padding:3px 8px;pointer-events:none;position:absolute;transform:translateX(-50%);white-space:nowrap}.login-page{align-items:center;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:24px;position:relative}.login-bg-glow{background:radial-gradient(circle,#f59e0b14 0,#0000 70%);height:600px;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:600px}.login-card{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#161620cc;border:1px solid var(--border-color);border-radius:16px;box-shadow:0 24px 64px #00000080,0 0 40px #f59e0b0d;max-width:400px;padding:40px;position:relative;width:100%;z-index:1}.login-header{margin-bottom:32px;text-align:center}.login-icon{align-items:center;background:var(--accent-dim);border:1px solid var(--border-focus);border-radius:14px;box-shadow:0 0 20px var(--neon-glow-base);color:var(--accent);display:flex;height:56px;justify-content:center;margin:0 auto 16px;width:56px}.login-brand{color:var(--text-primary);font-size:20px;font-weight:700;letter-spacing:.5px;margin:0 0 6px}.login-tagline{color:var(--text-muted);font-size:13px;margin:0}.login-tabs{background:var(--bg-tertiary);border-radius:var(--radius-lg);display:flex;gap:4px;margin-bottom:24px;padding:4px}.login-tab{background:none;border:none;border-radius:6px;color:var(--text-muted);cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:8px;transition:all var(--transition-smooth)}.login-tab.active{background:var(--bg-elevated);box-shadow:var(--shadow-sm);color:var(--text-primary)}.login-form{display:flex;flex-direction:column;gap:12px}.login-field{position:relative}.login-input{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-sizing:border-box;color:var(--text-primary);font-size:14px;outline:none;padding:12px 16px;transition:all var(--transition-fast);width:100%}.login-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #f59e0b1a}.login-input::placeholder{color:var(--text-muted)}.login-error{background:var(--error-dim);border:1px solid #ff6b6b4d;border-radius:var(--radius-md);color:var(--error);font-size:13px;overflow:hidden;padding:10px 14px}.login-submit{background:var(--accent);border:none;border-radius:var(--radius-md);box-shadow:0 0 20px var(--neon-glow-base);color:var(--text-inverse);cursor:pointer;font-size:14px;font-weight:600;margin-top:4px;padding:13px;transition:all var(--transition-smooth);width:100%}.login-submit:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 0 30px var(--neon-glow-hover);transform:translateY(-1px)}.login-submit:disabled{cursor:not-allowed;opacity:.6;transform:none}.login-loading{align-items:center;display:flex;gap:5px;justify-content:center}.login-loading span{animation:login-dot .8s ease-in-out infinite;background:currentColor;border-radius:50%;height:6px;width:6px}.login-loading span:nth-child(2){animation-delay:.15s}.login-loading span:nth-child(3){animation-delay:.3s}@keyframes login-dot{0%,80%,to{opacity:.5;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.login-google-btn{align-items:center;background:#ffffff0d;border:1px solid #ffffff26;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:12px;justify-content:center;margin-top:8px;padding:13px 20px;transition:all var(--transition-smooth);width:100%}.login-google-btn:hover{background:#ffffff1a;border-color:#ffffff40;box-shadow:0 4px 20px #0000004d;transform:translateY(-1px)}.login-note{color:var(--text-muted);font-size:12px;margin:16px 0 0;text-align:center}.library-page{max-width:1400px}.library-header{margin-bottom:32px}.library-title{color:var(--text-primary);font-size:32px;font-weight:800;letter-spacing:-.5px;margin:0}.library-section{margin-bottom:48px}.library-section-title{color:var(--text-primary);font-size:18px;font-weight:700;margin:0 0 20px}.recent-row{display:flex;gap:16px;overflow-x:auto;padding-bottom:8px;scrollbar-width:none}.recent-row::-webkit-scrollbar{display:none}.recent-card{cursor:pointer;flex-shrink:0;width:140px}.recent-card-art{background:var(--bg-tertiary);border-radius:var(--radius-lg);height:140px;margin-bottom:8px;overflow:hidden;position:relative;width:140px}.recent-card-art img{height:100%;object-fit:cover;width:100%}.recent-card-play{align-items:center;background:#00000080;color:var(--accent);display:flex;inset:0;justify-content:center;opacity:0;position:absolute;transition:opacity var(--transition-normal)}.recent-card:hover .recent-card-play{opacity:1}.recent-card-title{color:var(--text-primary);font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-card-count{color:var(--text-muted);font-size:11px;margin-top:2px}.albums-grid,.library-loading{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.album-card-skeleton{animation:shimmer 1.5s ease-in-out infinite;background:var(--bg-secondary);border-radius:var(--radius-lg);padding-top:100%}@keyframes shimmer{0%,to{opacity:.5}50%{opacity:1}}@media (max-width:768px){.albums-grid,.library-loading{gap:12px;grid-template-columns:repeat(2,1fr)}.library-title{font-size:24px}}.album-page{position:relative}.album-back-btn{align-items:center;background:none;border:none;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;gap:6px;margin-bottom:24px;padding:8px 0;transition:color var(--transition-fast)}.album-back-btn:hover{color:var(--text-primary)}.album-bg{background-position:50%;background-size:cover;filter:blur(60px) saturate(.8);height:100%;left:0;opacity:.06;pointer-events:none;position:fixed;top:0;width:100%;z-index:0}.album-header{align-items:flex-end;display:flex;gap:32px;margin-bottom:40px;position:relative;z-index:1}.album-cover{border-radius:12px;box-shadow:0 16px 48px #00000080,0 0 32px var(--neon-glow-base);flex-shrink:0;height:220px;overflow:hidden;width:220px}.album-cover img{height:100%;object-fit:cover;width:100%}.album-cover-fallback{align-items:center;background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-elevated));color:var(--text-muted);display:flex;height:100%;justify-content:center;width:100%}.album-meta{flex:1 1;min-width:0}.album-label{color:var(--text-muted);font-size:11px;font-weight:700;letter-spacing:2px;margin-bottom:8px;text-transform:uppercase}.album-name{color:var(--text-primary);font-size:40px;font-weight:900;line-height:1.1;margin:0 0 12px}.album-info-row{align-items:center;color:var(--text-secondary);display:flex;flex-wrap:wrap;font-size:14px;gap:12px;margin-bottom:24px}.album-artist{font-weight:600}.album-stats{align-items:center;color:var(--text-muted);display:flex;gap:4px}.album-actions{display:flex;gap:12px}.album-play-btn{align-items:center;background:var(--accent);border:none;border-radius:24px;box-shadow:0 0 20px var(--neon-glow-base);color:var(--text-inverse);cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;padding:12px 28px;transition:all var(--transition-smooth)}.album-play-btn:hover{background:var(--accent-hover);box-shadow:0 0 32px var(--neon-glow-hover);transform:scale(1.03)}.album-shuffle-btn{align-items:center;background:#ffffff0f;border:1px solid var(--border-color);border-radius:24px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;gap:8px;padding:12px 20px;transition:all var(--transition-smooth)}.album-shuffle-btn:hover{background:#ffffff1a;color:var(--text-primary)}.album-tracks{position:relative;z-index:1}.album-empty,.album-loading{color:var(--text-muted);padding:48px;text-align:center}@media (max-width:768px){.album-header{align-items:flex-start;flex-direction:column}.album-cover{height:160px;width:160px}.album-name{font-size:28px}}.now-playing-page{align-items:center;background:var(--bg-primary);display:flex;inset:0;justify-content:center;overflow:hidden;position:fixed;z-index:50}.np-bg{inset:0;pointer-events:none;position:absolute;transition:background 1s ease}.np-inner{align-items:center;display:flex;flex-direction:column;gap:20px;max-width:440px;padding:24px 32px;position:relative;width:100%;z-index:1}.np-back-btn{align-self:flex-start;background:none;border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;padding:8px;transition:all var(--transition-fast)}.np-back-btn:hover{background:#ffffff14;color:var(--text-primary)}.np-visual-wrap{align-items:center;display:flex;height:320px;justify-content:center;position:relative;width:320px}.np-canvas{height:320px;left:0;pointer-events:none;position:absolute;top:0;width:320px}.np-cover{border-radius:16px;box-shadow:0 0 40px #00000080;height:200px;overflow:hidden;position:relative;width:200px;z-index:1}.np-cover-img{height:100%;object-fit:cover;width:100%}.np-cover-fallback{align-items:center;flex-direction:column;height:100%;justify-content:center;width:100%}.np-cover-initial{color:#fffc;font-size:72px;font-weight:900;text-transform:uppercase}.np-info{width:100%}.np-title-row{align-items:flex-start;display:flex;gap:12px;justify-content:space-between}.np-title-text{flex:1 1;min-width:0}.np-title{color:var(--text-primary);font-size:22px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.np-artist{color:var(--text-secondary);font-size:15px;margin-top:2px}.np-album{color:var(--text-muted);font-size:13px;margin-top:2px}.np-progress{width:100%}.np-controls{gap:8px;width:100%}.np-controls,.np-ctrl-btn{align-items:center;display:flex;justify-content:center}.np-ctrl-btn{background:none;border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;padding:10px;transition:all var(--transition-smooth)}.np-ctrl-btn:hover{background:#ffffff0f;color:var(--text-primary)}.np-ctrl-btn.active{color:var(--accent);color:var(--np-color-1,var(--accent));filter:drop-shadow(0 0 6px currentColor)}.np-ctrl-skip{color:var(--text-primary)}.np-ctrl-skip:hover{background:#ffffff14}.np-play-btn{align-items:center;background:var(--accent);background:var(--np-color-1,var(--accent));border:none;border-radius:50%;box-shadow:0 0 30px var(--neon-glow-hover);color:#000;cursor:pointer;display:flex;height:68px;justify-content:center;margin:0 8px;transition:all var(--transition-bounce);width:68px}.np-play-btn:hover{box-shadow:0 0 50px var(--neon-glow-hover);transform:scale(1.08)}.np-volume{align-items:center;display:flex;gap:10px;width:100%}.np-volume-icon{color:var(--text-muted);flex-shrink:0}.np-volume-slider{-webkit-appearance:none;appearance:none;background:linear-gradient(to right,var(--accent) var(--vol-pct),#ffffff1a var(--vol-pct));background:linear-gradient(to right,var(--np-accent,var(--accent)) var(--vol-pct),#ffffff1a var(--vol-pct));border-radius:2px;cursor:pointer;flex:1 1;height:4px;outline:none}.np-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent);background:var(--np-accent,var(--accent));border-radius:50%;box-shadow:0 0 8px var(--neon-glow-base);cursor:pointer;height:14px;width:14px}.now-playing-empty{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;gap:16px;height:60vh;justify-content:center}.now-playing-empty button{background:var(--accent);border:none;border-radius:24px;color:var(--text-inverse);cursor:pointer;font-size:14px;padding:10px 24px}@media (max-width:768px){.np-inner{padding:16px 20px}.np-canvas,.np-visual-wrap{height:280px;width:280px}.np-cover{height:172px;width:172px}}.favorites-page{max-width:800px}.favorites-header{margin-bottom:32px}.favorites-title-row{align-items:center;display:flex;gap:12px;margin-bottom:4px}.favorites-icon{color:var(--error);filter:drop-shadow(0 0 8px rgba(255,107,107,.4))}.favorites-title{color:var(--text-primary);font-size:32px;font-weight:800;margin:0}.favorites-count{color:var(--text-muted);font-size:14px;margin:0 0 20px}.favorites-actions{display:flex;gap:12px}.fav-play-btn{align-items:center;background:var(--accent);border:none;border-radius:24px;box-shadow:0 0 16px var(--neon-glow-base);color:var(--text-inverse);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 24px;transition:all var(--transition-smooth)}.fav-play-btn:hover{background:var(--accent-hover);box-shadow:0 0 24px var(--neon-glow-hover)}.fav-shuffle-btn{align-items:center;background:#ffffff0f;border:1px solid var(--border-color);border-radius:24px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;gap:8px;padding:10px 20px;transition:all var(--transition-smooth)}.fav-shuffle-btn:hover{background:#ffffff1a;color:var(--text-primary)}.favorites-loading{color:var(--text-muted);padding:48px;text-align:center}.favorites-empty{align-items:center;display:flex;flex-direction:column;gap:8px;padding:80px 24px;text-align:center}.favorites-empty-icon{color:var(--text-muted);margin-bottom:8px;opacity:.3}.favorites-empty p{color:var(--text-secondary);font-size:18px;font-weight:600;margin:0}.favorites-empty span{color:var(--text-muted);font-size:14px}.search-page{max-width:900px}.search-box{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;display:flex;gap:12px;margin-bottom:32px;padding:14px 18px;transition:all var(--transition-fast)}.search-box:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px #f59e0b14,0 0 20px var(--neon-glow-base)}.search-icon{color:var(--text-muted);flex-shrink:0}.search-input{background:none;border:none;color:var(--text-primary);flex:1 1;font-size:16px;outline:none}.search-clear,.search-input::placeholder{color:var(--text-muted)}.search-clear{background:none;border:none;border-radius:50%;cursor:pointer;font-size:14px;padding:2px 6px;transition:color var(--transition-fast)}.search-clear:hover{color:var(--text-primary)}.search-empty{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;gap:12px;padding:80px 24px}.search-empty-icon{opacity:.3}.search-empty p{font-size:16px;margin:0}.search-section{margin-bottom:40px}.search-section-title{color:var(--text-primary);font-size:16px;font-weight:700;margin:0 0 16px}.search-albums-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));margin-bottom:8px}.search-no-results{color:var(--text-muted);font-size:15px;padding:48px 24px;text-align:center}.search-no-results strong{color:var(--text-secondary)}#root{min-height:100vh}
/*# sourceMappingURL=main.6dadbd78.css.map*/