.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:#00843d;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-bottom:none;display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-lg);z-index:100}.header-left{display:flex;align-items:center;gap:var(--spacing-md)}.sidebar-toggle{display:none}.logo{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;transition:transform var(--transition-fast)}.logo:hover{transform:scale(1.02)}.logo-img{width:auto;height:44px;object-fit:contain}.logo-ring{position:absolute;width:100%;height:100%;border-radius:50%;background:var(--accent-gradient);animation:pulse 3s infinite}.logo-dot{position:relative;width:12px;height:12px;background:#fff;border-radius:50%;z-index:1}.logo-text{font-size:var(--font-size-xl);font-weight:800;letter-spacing:-.5px}.search-form{flex:1;max-width:500px;margin:0 var(--spacing-xl)}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:var(--spacing-md);color:var(--text-muted);pointer-events:none;transition:color var(--transition-fast)}.search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);padding-left:calc(var(--spacing-md) * 2 + 18px);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-full);color:var(--text-primary);font-size:var(--font-size-sm);transition:all var(--transition-fast)}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #8b5cf626;background:var(--bg-secondary)}.search-input:focus+.search-icon,.search-input-wrapper:focus-within .search-icon{color:var(--accent-primary)}.header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.theme-toggle{color:var(--text-secondary);transition:all var(--transition-base)}.theme-toggle:hover{color:var(--accent-primary);transform:rotate(15deg)}@media (max-width: 768px){.header{padding:0 var(--spacing-md)}.sidebar-toggle{display:flex}.logo-text{display:none}.search-form{margin:0 var(--spacing-md)}.search-input::placeholder{font-size:var(--font-size-xs)}.login-btn span,.user-name{display:none}}.user-menu-container{position:relative}.user-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm)}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:600;color:#fff}.user-name{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary)}.user-dropdown{position:absolute;top:calc(100% + var(--spacing-sm));right:0;min-width:200px;background:var(--bg-secondary);border:var(--glass-border);border-radius:var(--border-radius-md);box-shadow:var(--shadow-lg);z-index:200;animation:slideUp .2s ease}.user-dropdown-header{padding:var(--spacing-md);display:flex;flex-direction:column;gap:2px}.user-dropdown-header strong{font-size:var(--font-size-sm);color:var(--text-primary)}.user-dropdown-header span{font-size:var(--font-size-xs);color:var(--text-muted)}.user-dropdown-divider{height:1px;background:var(--border-color)}.user-dropdown-item{width:100%;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);color:var(--text-secondary);background:none;border:none;cursor:pointer;transition:all var(--transition-fast)}.user-dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.login-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md)}.admin-badge{display:inline-block;font-size:10px;background:var(--accent-gradient);color:#fff;padding:2px 6px;border-radius:var(--border-radius-full);margin-top:2px}.sidebar-overlay{display:none}.sidebar{position:fixed;top:var(--header-height);left:0;bottom:var(--player-height);width:var(--sidebar-width);background:var(--bg-primary);border-right:var(--glass-border);display:flex;flex-direction:column;padding:var(--spacing-lg) 0;z-index:90;transition:all var(--transition-base);overflow-y:auto;overflow-x:hidden}.sidebar-close{display:none}.sidebar-nav{flex:1}.nav-section{margin-bottom:var(--spacing-xl);padding:0 var(--spacing-sm)}.nav-section-title{display:block;font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:var(--spacing-sm);padding:0 var(--spacing-sm);white-space:nowrap;overflow:hidden;transition:opacity var(--transition-fast)}.nav-list{list-style:none}.nav-link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-md);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-fast);text-decoration:none;position:relative;min-height:44px}.nav-link:hover{color:var(--text-primary);background:var(--bg-hover)}.nav-link.active{color:var(--text-primary);background:#f93f2626}.nav-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--accent-gradient);border-radius:0 2px 2px 0}.nav-link svg{flex-shrink:0;width:20px;height:20px}.nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-badge{margin-left:auto;background:var(--accent-gradient);color:#fff;font-size:var(--font-size-xs);font-weight:600;padding:2px 8px;border-radius:var(--border-radius-full);min-width:20px;text-align:center}.sidebar-footer{padding:var(--spacing-md);border-top:var(--glass-border)}.powered-by{font-size:var(--font-size-xs);color:var(--text-muted);text-align:center}.powered-by a{color:#fff}.designed-by{font-size:var(--font-size-xs);color:var(--text-muted);text-align:center;margin-top:var(--spacing-xs)}@media (max-width: 1024px){.sidebar{width:72px}.nav-section-title{opacity:0;height:0;margin:0;padding:0}.nav-link{justify-content:center;padding:var(--spacing-sm)}.nav-label{display:none}.nav-badge{position:absolute;top:2px;right:2px;padding:2px 4px;font-size:9px;min-width:14px}.powered-by,.designed-by{display:none}}@media (max-width: 768px){.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:140;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sidebar{position:fixed;top:0;left:0;bottom:0;width:230px;transform:translate(-100%);z-index:150;padding-top:var(--spacing-xl);box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.sidebar-close{display:flex;position:absolute;top:var(--spacing-md);right:var(--spacing-md);color:var(--text-secondary)}.sidebar.open .nav-section-title{opacity:1;height:auto;margin-bottom:var(--spacing-sm);padding:0 var(--spacing-sm)}.sidebar.open .nav-link{justify-content:flex-start;padding:var(--spacing-sm) var(--spacing-md)}.sidebar.open .nav-label{display:block}.sidebar.open .nav-badge{position:static;padding:2px 8px;font-size:var(--font-size-xs);min-width:20px}.sidebar.open .powered-by,.sidebar.open .designed-by{display:block}}.add-playlist-modal{background:var(--bg-secondary);border:var(--glass-border);border-radius:var(--border-radius-lg);width:100%;max-width:360px;box-shadow:var(--shadow-xl);animation:slideUp .2s ease-out;overflow:hidden}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--border-color)}.modal-header h3{font-size:var(--font-size-base);font-weight:600;margin:0}.modal-body{padding:var(--spacing-md);max-height:400px;overflow-y:auto}.new-playlist-btn{width:100%;justify-content:center;margin-bottom:var(--spacing-md);border-style:dashed}.create-form{margin-bottom:var(--spacing-md);background:var(--bg-tertiary);padding:var(--spacing-sm);border-radius:var(--border-radius-md)}.playlist-input{width:100%;padding:8px 12px;border-radius:4px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);margin-bottom:8px}.create-actions{display:flex;justify-content:flex-end;gap:8px}.playlists-list{display:flex;flex-direction:column;gap:4px}.playlist-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);width:100%;background:transparent;border:none;color:var(--text-primary);text-align:left;cursor:pointer;border-radius:var(--border-radius-md);transition:background var(--transition-fast)}.playlist-item:hover:not(:disabled){background:var(--bg-tertiary)}.playlist-item:disabled{opacity:.6;cursor:default}.playlist-item-icon{width:40px;height:40px;background:var(--bg-tertiary);border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.playlist-item-info{flex:1;display:flex;flex-direction:column}.playlist-item-info .name{font-weight:500;font-size:var(--font-size-sm)}.playlist-item-info .count{color:var(--text-secondary);font-size:11px}.added-badge{font-size:10px;color:var(--accent-primary);font-weight:600;text-transform:uppercase}.no-playlists{text-align:center;color:var(--text-muted);font-size:var(--font-size-sm);padding:var(--spacing-md)}.queue-drawer-overlay{position:fixed;top:0;right:0;bottom:var(--player-height);left:0;z-index:1000;pointer-events:none;background:transparent;transition:background .3s ease}.queue-drawer-overlay.open{pointer-events:auto;background:#00000080}.queue-drawer{position:absolute;top:0;right:0;bottom:0;width:350px;max-width:85vw;background:var(--bg-secondary);border-left:1px solid var(--border-color);box-shadow:-4px 0 20px #0000004d;transform:translate(100%);transition:transform .3s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.queue-drawer-overlay.open .queue-drawer{transform:translate(0)}.queue-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.queue-header h2{font-size:var(--font-size-lg);font-weight:700;margin:0}.btn-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:var(--border-radius-full);transition:all .2s}.btn-close:hover{color:var(--text-primary);background:var(--bg-hover)}.queue-list{flex:1;overflow-y:auto;padding:var(--spacing-sm) 0}.queue-empty{padding:var(--spacing-xl);text-align:center;color:var(--text-muted)}.queue-item{display:flex;align-items:center;padding:8px var(--spacing-md);gap:var(--spacing-sm);transition:background .2s;-webkit-user-select:none;user-select:none;border-bottom:1px solid transparent}.queue-item:hover{background:var(--bg-hover)}.queue-item.active{background:#8b5cf61a}.queue-item.active .queue-track-name{color:var(--accent-primary)}.queue-item.dragging{opacity:.5;background:var(--bg-tertiary)}.drag-handle{cursor:grab;color:var(--text-muted);padding:4px;opacity:0;transition:opacity .2s}.queue-item:hover .drag-handle{opacity:1}.drag-handle:active{cursor:grabbing}.queue-item-info{flex:1;min-width:0;cursor:pointer;display:flex;align-items:center;gap:8px}.playing-dot{width:6px;height:6px;background:var(--accent-primary);border-radius:50%;box-shadow:0 0 8px var(--accent-primary)}.queue-track-details{display:flex;flex-direction:column;min-width:0}.queue-track-name{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.queue-track-artist{font-size:var(--font-size-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-remove-track{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;opacity:0;transition:all .2s}.btn-remove-track:hover{color:var(--error)}.queue-item:hover .btn-remove-track{opacity:1}.queue-list::-webkit-scrollbar{width:6px}.queue-list::-webkit-scrollbar-track{background:transparent}.queue-list::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:3px}.queue-list::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (max-width: 768px){.queue-drawer-overlay{bottom:0}.queue-drawer{width:100%;max-width:100%;padding-bottom:var(--player-height)}.drag-handle,.btn-remove-track{opacity:1}}.player{position:fixed;bottom:0;left:0;right:0;height:var(--player-height);background:#ef3340;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-top:none;display:grid;grid-template-columns:1fr 2fr 1fr;align-items:center;padding:0 var(--spacing-lg);z-index:100}.player-empty{display:flex;justify-content:center;border-top:none;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}.player.player-empty{height:48px;background:#ef3340;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-top:none}.player-empty p{color:#fff;font-size:var(--font-size-sm);font-weight:500}.player-suspended{display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#ef444433,#b91c1c4d);border-top:2px solid rgba(239,68,68,.5)}.suspended-content{display:flex;align-items:center;gap:var(--spacing-md);color:#f87171;font-size:var(--font-size-lg);font-weight:700;letter-spacing:1px;animation:pulse-suspended 2s ease-in-out infinite}@keyframes pulse-suspended{0%,to{opacity:1}50%{opacity:.6}}.player-track{display:flex;align-items:center;gap:var(--spacing-md);min-width:0}.player-cover{position:relative;width:56px;height:56px;border-radius:var(--border-radius-sm);overflow:hidden;flex-shrink:0}.player-cover img{width:100%;height:100%;object-fit:cover}.player-visualizer{position:absolute;bottom:4px;left:4px;display:flex;align-items:flex-end;gap:2px;height:12px;opacity:0;transition:opacity var(--transition-fast)}.player-visualizer.playing{opacity:1}.player-visualizer span{width:3px;background:var(--accent-primary);border-radius:1px;animation:playingBar .8s ease-in-out infinite}.player-visualizer span:nth-child(1){animation-delay:0s;height:60%}.player-visualizer span:nth-child(2){animation-delay:.2s;height:100%}.player-visualizer span:nth-child(3){animation-delay:.4s;height:40%}.player-visualizer span:nth-child(4){animation-delay:.6s;height:80%}.player-info{min-width:0;flex:1}.player-title-row{display:flex;align-items:center;gap:var(--spacing-xs)}.player-title{font-size:var(--font-size-sm);font-weight:600}.offline-badge{display:flex;align-items:center;justify-content:center;width:18px;height:18px;background:#10b981;color:#fff;border-radius:50%;flex-shrink:0}.player-artist{font-size:var(--font-size-xs);color:#fffc}.player-track .download-btn.cached{color:#10b981}.player-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0009;color:var(--accent-primary)}.favorite-btn.active{color:var(--accent-secondary)}.player-controls{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.player-buttons{display:flex;align-items:center;gap:var(--spacing-sm)}.player-buttons .active{color:var(--accent-primary)}.play-btn{transform:scale(1);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.play-btn:hover{transform:scale(1.05)}.play-btn:active{transform:scale(.95)}.player-progress{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;max-width:600px}.progress-time{font-size:var(--font-size-xs);color:#fffc;min-width:40px;text-align:center;font-variant-numeric:tabular-nums}.progress-bar{flex:1;height:6px;background:#fff3;border-radius:3px;cursor:pointer;position:relative;transition:height .2s ease}.progress-bar:hover{height:6px}.progress-fill{height:100%;background:var(--accent-gradient);border-radius:2px;transition:width .1s linear}.progress-thumb{position:absolute;top:50%;transform:translate(-50%,-50%) scale(0);width:12px;height:12px;background:#fff;border-radius:50%;box-shadow:0 2px 4px #0000004d;transition:transform var(--transition-fast)}.progress-bar:hover .progress-thumb{transform:translate(-50%,-50%) scale(1)}.player-volume{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm)}.volume-slider{width:100px;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#fff3;border-radius:3px;cursor:pointer;transition:height .2s ease}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0000004d}.volume-slider::-moz-range-thumb{width:12px;height:12px;background:#fff;border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 4px #0000004d}.mini-player,.player-expanded,.player-overlay{display:none}@media (max-width: 768px){.player-desktop{display:none}.player-empty{height:48px;min-height:0}.mini-player{display:block;position:fixed;bottom:0;left:0;right:0;background:#ef3340;border-top:none;z-index:100;cursor:pointer}.mini-player.hidden{display:none}.mini-progress{height:2px;background:var(--bg-tertiary)}.mini-progress-fill{height:100%;background:var(--accent-gradient);transition:width .2s linear}.mini-content{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md)}.mini-cover{width:48px;height:48px;border-radius:var(--border-radius-sm);object-fit:cover;flex-shrink:0}.mini-info{flex:1;min-width:0}.mini-info h4{font-size:var(--font-size-sm);font-weight:600;margin-bottom:2px}.mini-info p{font-size:var(--font-size-xs);color:var(--text-secondary)}.mini-controls{display:flex;align-items:center;gap:var(--spacing-xs)}.mini-expand-icon{color:var(--text-muted);flex-shrink:0}.player-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:199;animation:fadeIn .2s ease}.player-expanded{display:flex;flex-direction:column;position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-primary);z-index:200;padding:var(--spacing-md) var(--spacing-lg);padding-bottom:calc(env(safe-area-inset-bottom,0px) + var(--spacing-lg));transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);overflow-y:auto}.player-expanded.open{transform:translateY(0)}.expanded-close{display:flex;align-items:center;justify-content:center;width:100%;padding:var(--spacing-sm);color:var(--text-muted);background:none;border:none;cursor:pointer}.expanded-cover{display:flex;align-items:center;justify-content:center;position:relative;padding:var(--spacing-md)}.expanded-cover img{width:100%;max-width:280px;max-height:280px;aspect-ratio:1;object-fit:cover;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg),var(--accent-glow)}.offline-badge-large{position:absolute;bottom:var(--spacing-lg);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background:#10b981;color:#fff;border-radius:var(--border-radius-full);font-size:var(--font-size-xs);font-weight:600}.expanded-info{text-align:center;padding:var(--spacing-lg) 0}.expanded-info h2{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--spacing-xs)}.expanded-info p{font-size:var(--font-size-base);color:var(--text-secondary)}.expanded-progress{padding:0 var(--spacing-sm)}.expanded-progress .progress-bar{height:6px;margin-bottom:var(--spacing-sm)}.progress-times{display:flex;justify-content:space-between;font-size:var(--font-size-xs);color:var(--text-muted)}.expanded-controls{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-lg) 0}.expanded-controls .active{color:var(--accent-primary)}.expanded-play{width:72px;height:72px}.expanded-actions{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xl);padding:var(--spacing-md) 0}.expanded-actions .active{color:var(--accent-secondary)}.expanded-actions .cached{color:#10b981}}.track-card{background:var(--glass-bg);transition:all var(--transition-base)}.track-card.playing{border-color:var(--accent-primary);box-shadow:var(--accent-glow)}.track-card .card-cover{cursor:pointer;position:relative}.playing-indicator{position:absolute;bottom:var(--spacing-sm);left:var(--spacing-sm);background:#000000b3;padding:4px 8px;border-radius:var(--border-radius-sm)}.cached-badge{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:#10b981;color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center}.track-card-info{display:flex;flex-direction:column;gap:4px}.track-card-title{font-size:var(--font-size-sm);font-weight:600}.track-card-artist{font-size:var(--font-size-xs);color:var(--text-secondary)}.track-card-meta{display:flex;align-items:center;justify-content:space-between;margin-top:var(--spacing-xs)}.track-duration{font-size:var(--font-size-xs);color:var(--text-muted);font-variant-numeric:tabular-nums}.track-actions{display:flex;gap:2px}.track-card .favorite-btn,.track-card .download-btn{opacity:0;transition:opacity var(--transition-fast)}.track-card:hover .favorite-btn,.track-card:hover .download-btn{opacity:1}.track-card .favorite-btn.active{opacity:1;color:var(--accent-secondary)}.track-card .download-btn.cached{opacity:1;color:#10b981}.skeleton-card{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--glass-bg);border-radius:var(--border-radius-lg);border:var(--glass-border)}.skeleton-cover{aspect-ratio:1;border-radius:var(--border-radius-md)}.skeleton-title{height:16px;width:80%}.skeleton-subtitle{height:12px;width:60%}.skeleton-text{height:14px;width:70%}.home-page{max-width:1400px;margin:0 auto}.hero{position:relative;padding:var(--spacing-2xl) 0;margin-bottom:var(--spacing-xl);text-align:center;overflow:hidden}.hero-content{position:relative;z-index:1}.hero-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;margin-bottom:var(--spacing-md);letter-spacing:-1px}.hero-description{font-size:var(--font-size-lg);color:var(--text-secondary);max-width:500px;margin:0 auto}.hero-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:300px;background:radial-gradient(ellipse,rgba(139,92,246,.2) 0%,transparent 70%);pointer-events:none}.section{margin-bottom:var(--spacing-2xl)}.section-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.section-header h2{font-size:var(--font-size-2xl);font-weight:700}.section-icon{color:#fff}.genre-tabs{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);overflow-x:auto;padding-bottom:var(--spacing-sm);-ms-overflow-style:none;scrollbar-width:none}.genre-tabs::-webkit-scrollbar{display:none}.genre-tab{padding:var(--spacing-sm) var(--spacing-lg);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-full);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;white-space:nowrap;cursor:pointer;transition:all var(--transition-fast)}.genre-tab:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent-primary)}.genre-tab.active{background:var(--accent-gradient);color:#fff;border-color:transparent;box-shadow:var(--accent-glow)}@media (max-width: 768px){.hero{padding:var(--spacing-xl) 0}.section-header h2{font-size:var(--font-size-xl)}}.search-page{max-width:1400px;margin:0 auto;padding-bottom:140px}.search-hero{margin-bottom:var(--spacing-xl)}.search-page-form{max-width:100%;width:100%}.search-hero h1{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-lg)}.search-input-large{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--border-radius-xl);transition:all var(--transition-fast);width:100%;box-sizing:border-box}.search-input-large:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 4px #8b5cf626}.search-input-large svg{color:var(--text-muted);flex-shrink:0}.search-input-large input{flex:1;background:none;border:none;color:var(--text-primary);font-size:var(--font-size-lg);outline:none;width:100%}.search-input-large input::placeholder{color:var(--text-muted)}.search-tabs{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);border-bottom:1px solid var(--border-color);padding-bottom:var(--spacing-md);overflow-x:auto;white-space:nowrap;scrollbar-width:none}.search-tabs::-webkit-scrollbar{display:none}.search-tab{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid transparent;color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;border-radius:var(--border-radius-full);transition:all var(--transition-fast);flex-shrink:0}.search-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.search-tab.active{color:var(--accent-primary);background:#8b5cf626;border-color:#8b5cf64d}.tab-count{background:#ffffff1a;padding:2px 8px;border-radius:var(--border-radius-full);font-size:var(--font-size-xs);margin-left:4px}.search-tab.active .tab-count{background:var(--accent-primary);color:#fff}.search-results{min-height:300px}.no-results,.search-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;color:var(--text-muted)}.no-results svg,.search-empty svg{margin-bottom:var(--spacing-md);opacity:.5}.no-results h3,.search-empty h2{margin-bottom:var(--spacing-sm);color:var(--text-secondary)}.artists-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:var(--spacing-md)}.artist-card{text-align:center;padding:var(--spacing-md)}.artist-image{width:90px;height:90px;margin:0 auto var(--spacing-sm);border-radius:50%;overflow:hidden;background:var(--bg-tertiary)}.artist-card h4{font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs)}.artist-meta{font-size:var(--font-size-xs);color:var(--text-muted)}.artist-card.clickable,.album-card.clickable{cursor:pointer;transition:all var(--transition-base)}.artist-card.clickable:hover,.album-card.clickable:hover{transform:translateY(-4px);border-color:var(--accent-primary);box-shadow:var(--accent-glow)}.album-artist{font-size:var(--font-size-xs);color:var(--text-secondary)}.skeleton-list{display:flex;flex-direction:column}@media (max-width: 768px){.search-tabs{padding-bottom:var(--spacing-sm);margin:0 -20px var(--spacing-lg) -20px;padding:0 20px var(--spacing-sm) 20px}.search-input-large{padding:var(--spacing-sm) var(--spacing-md)}}.track-list{width:100%}.track-list-header{display:grid;grid-template-columns:50px 1fr 1fr 80px 50px;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--border-color);color:var(--text-muted);font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.track-list-body{display:flex;flex-direction:column}.track-row{display:grid;grid-template-columns:50px 1fr 1fr 80px 50px;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-md);cursor:pointer;transition:background var(--transition-fast)}.track-row:hover{background:var(--bg-hover)}.track-row.playing{background:#8b5cf61a}.track-row.playing .track-name{color:var(--accent-primary)}.track-col-index{display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:var(--font-size-sm);font-variant-numeric:tabular-nums;position:relative}.track-number{transition:opacity var(--transition-fast)}.play-btn-mini{position:absolute;display:none;align-items:center;justify-content:center;background:none;border:none;color:var(--text-primary);cursor:pointer}.track-row:hover .track-number{opacity:0}.track-row:hover .play-btn-mini{display:flex}.track-row.playing .track-number{opacity:0}.track-row.playing .playing-bars{display:flex}.track-col-title{display:flex;align-items:center;gap:var(--spacing-md);min-width:0}.track-mini-cover{width:40px;height:40px;border-radius:var(--border-radius-sm);object-fit:cover;flex-shrink:0}.track-title-info{display:flex;flex-direction:column;min-width:0}.track-name{font-size:var(--font-size-sm);font-weight:500;color:var(--text-primary)}.track-artist{font-size:var(--font-size-xs);color:var(--text-secondary)}.track-col-album{display:flex;align-items:center;font-size:var(--font-size-sm);color:var(--text-secondary)}.track-col-duration{display:flex;align-items:center;font-size:var(--font-size-sm);color:var(--text-muted);font-variant-numeric:tabular-nums}.track-col-actions{display:flex;align-items:center;justify-content:center}.track-col-actions .active{color:var(--accent-secondary)}.track-col-actions .btn{opacity:0;transition:opacity var(--transition-fast)}.track-row:hover .track-col-actions .btn,.track-col-actions .btn.active{opacity:1}@media (max-width: 768px){.track-list-header{display:none}.track-row{grid-template-columns:1fr 50px}.track-col-index,.track-col-album,.track-col-duration{display:none}.track-col-actions .btn{opacity:1}}.favorites-page{max-width:1200px;margin:0 auto}.favorites-header{display:flex;align-items:flex-end;gap:var(--spacing-xl);padding:var(--spacing-xl) 0;margin-bottom:var(--spacing-lg)}.favorites-icon{width:200px;height:200px;background:var(--accent-gradient);border-radius:var(--border-radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--accent-glow);flex-shrink:0}.favorites-info{display:flex;flex-direction:column;gap:var(--spacing-sm)}.favorites-label{font-size:var(--font-size-sm);font-weight:600;text-transform:uppercase;letter-spacing:1px}.favorites-info h1{font-size:var(--font-size-4xl);font-weight:800}.favorites-info p{color:var(--text-secondary)}.favorites-actions{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.favorites-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;color:var(--text-muted)}.favorites-empty svg{margin-bottom:var(--spacing-md);opacity:.5}.favorites-empty h3{margin-bottom:var(--spacing-sm);color:var(--text-secondary)}@media (max-width: 768px){.favorites-header{flex-direction:column;align-items:center;text-align:center}.favorites-icon{width:150px;height:150px}.favorites-info h1{font-size:var(--font-size-2xl)}}.artist-page{max-width:1200px;margin:0 auto}.back-btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);color:var(--text-secondary)}.back-btn:hover{color:var(--text-primary)}.artist-header{display:flex;align-items:flex-end;gap:var(--spacing-xl);padding:var(--spacing-xl) 0;margin-bottom:var(--spacing-lg)}.artist-image{width:220px;height:220px;border-radius:50%;overflow:hidden;box-shadow:var(--shadow-lg),var(--accent-glow);flex-shrink:0}.artist-image img{width:100%;height:100%;object-fit:cover}.artist-info{display:flex;flex-direction:column;gap:var(--spacing-sm)}.artist-label{font-size:var(--font-size-sm);font-weight:600;text-transform:uppercase;letter-spacing:1px}.artist-info h1{font-size:clamp(2rem,5vw,4rem);font-weight:800;line-height:1.1}.artist-info p{color:var(--text-secondary)}.artist-actions{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-2xl)}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-base)}.artist-tracks h2{font-size:var(--font-size-xl);margin-bottom:var(--spacing-lg)}.no-tracks{text-align:center;padding:var(--spacing-2xl);color:var(--text-muted)}.skeleton-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.skeleton-row{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md)}.skeleton-avatar{width:40px;height:40px;border-radius:var(--border-radius-sm);flex-shrink:0}.skeleton-row-info{display:flex;flex-direction:column;gap:var(--spacing-xs);flex:1}.skeleton-text{height:14px;width:60%}.skeleton-text-sm{height:12px;width:40%}@media (max-width: 768px){.artist-header{flex-direction:column;align-items:center;text-align:center}.artist-image{width:180px;height:180px}.artist-actions{justify-content:center}}.downloads-page{max-width:1200px;margin:0 auto}.downloads-header{display:flex;align-items:flex-end;gap:var(--spacing-xl);padding:var(--spacing-xl) 0;margin-bottom:var(--spacing-lg)}.downloads-icon{width:200px;height:200px;background:linear-gradient(135deg,#10b981,#059669);border-radius:var(--border-radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 0 30px #10b98166;flex-shrink:0}.downloads-info{display:flex;flex-direction:column;gap:var(--spacing-sm)}.downloads-label{font-size:var(--font-size-sm);font-weight:600;text-transform:uppercase;letter-spacing:1px;color:#10b981}.downloads-info h1{font-size:var(--font-size-4xl);font-weight:800}.downloads-stats{display:flex;gap:var(--spacing-lg);color:var(--text-secondary)}.stat{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm)}.downloads-actions{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.downloads-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.download-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-md);transition:background var(--transition-fast)}.download-item:hover{background:var(--bg-hover)}.download-cover{width:48px;height:48px;border-radius:var(--border-radius-sm);object-fit:cover;flex-shrink:0}.download-info{flex:1;min-width:0;cursor:pointer}.download-info h4{font-size:var(--font-size-sm);font-weight:500;margin-bottom:2px}.download-info p{font-size:var(--font-size-xs);color:var(--text-secondary)}.download-duration{font-size:var(--font-size-sm);color:var(--text-muted);font-variant-numeric:tabular-nums}.download-badge{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#10b98133;color:#10b981;border-radius:var(--border-radius-full)}.delete-btn{opacity:0;color:var(--text-muted)}.download-item:hover .delete-btn{opacity:1}.delete-btn:hover{color:#ef4444}.downloads-empty,.downloads-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;color:var(--text-muted)}.downloads-empty svg{margin-bottom:var(--spacing-md);opacity:.5;color:#10b981}.downloads-empty h3{margin-bottom:var(--spacing-sm);color:var(--text-secondary)}.downloads-empty .hint{margin-top:var(--spacing-md);font-size:var(--font-size-xs);opacity:.7}@media (max-width: 768px){.downloads-header{flex-direction:column;align-items:center;text-align:center}.downloads-icon{width:150px;height:150px}.downloads-stats{justify-content:center}.downloads-actions{flex-direction:column}.download-duration{display:none}}.playlists-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-lg)}@media (max-width: 768px){.playlists-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}}.playlist-card{background:var(--bg-secondary);border-radius:var(--border-radius-lg);padding:var(--spacing-md);transition:all var(--transition-fast);position:relative;display:flex;flex-direction:column;text-decoration:none;color:inherit;border:1px solid transparent}.playlist-card:hover{transform:translateY(-4px);background:var(--bg-tertiary);border-color:#ffffff0d;box-shadow:var(--shadow-lg)}.playlist-image{width:100%;aspect-ratio:1;border-radius:var(--border-radius-md);overflow:hidden;margin-bottom:var(--spacing-md);position:relative;background:var(--bg-tertiary)}.playlist-image img{width:100%;height:100%;object-fit:cover}.placeholder-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:var(--bg-tertiary)}.create-card{border:2px dashed var(--border-color);background:transparent;align-items:center;justify-content:center;cursor:pointer;min-height:260px}.create-card:hover{border-color:var(--accent-primary);background:#8b5cf60d}.create-icon{width:64px;height:64px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);margin-bottom:var(--spacing-md);transition:all var(--transition-fast)}.create-card:hover .create-icon{background:var(--accent-primary);color:#fff;transform:scale(1.1)}.playlist-info h3{font-size:var(--font-size-base);font-weight:600;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-info p{font-size:var(--font-size-xs);color:var(--text-secondary)}.playlist-desc{margin-top:4px;font-size:var(--font-size-xs);color:var(--text-muted)}.playlist-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast)}.playlist-card:hover .playlist-overlay{opacity:1}.playlist-card:hover .play-btn{transform:scale(1)}.playlist-card .play-btn{transform:scale(.8);transition:transform var(--transition-fast)}.playlist-actions{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);display:flex;gap:4px;opacity:0;transition:opacity var(--transition-fast)}.playlist-card:hover .playlist-actions{opacity:1}.playlist-actions button{background:#0009;border-radius:50%;color:#fff}.playlist-actions button:hover{background:var(--accent-primary)}.text-danger:hover{background:#ef4444!important}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal-content{background:var(--bg-secondary);border:var(--glass-border);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);width:100%;max-width:480px;animation:zoomIn .2s cubic-bezier(.16,1,.3,1)}.modal-content h2{margin-bottom:var(--spacing-lg);font-size:var(--font-size-xl)}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm);font-weight:500}.form-group input,.form-group textarea{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:var(--spacing-sm) var(--spacing-md);color:var(--text-primary);font-family:inherit;font-size:var(--font-size-base);transition:all var(--transition-fast)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #8b5cf633}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-xl)}@keyframes zoomIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.playlist-details-page{padding-bottom:120px}.back-link{display:inline-flex;align-items:center;gap:8px;color:var(--text-secondary);text-decoration:none;margin-bottom:var(--spacing-lg);font-weight:500;transition:color var(--transition-fast)}.back-link:hover{color:var(--text-primary)}.playlist-header-content{display:flex;gap:var(--spacing-xl);align-items:flex-end;margin-bottom:var(--spacing-xl)}.playlist-cover-large{width:232px;height:232px;min-width:232px;border-radius:var(--border-radius-lg);overflow:hidden;box-shadow:0 8px 24px #00000080;background:var(--bg-tertiary)}.playlist-cover-large img{width:100%;height:100%;object-fit:cover}.placeholder-large{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.playlist-meta{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.meta-subtitle{text-transform:uppercase;font-size:var(--font-size-xs);font-weight:700;letter-spacing:.1em;color:var(--text-primary)}.playlist-meta h1{font-size:3rem;font-weight:800;margin:0;line-height:1.1;cursor:pointer}.playlist-meta h1:hover{text-decoration:underline}.description{color:var(--text-secondary);font-size:var(--font-size-sm);max-width:600px}.meta-stats{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--text-primary);font-weight:500}.dot{font-size:20px;line-height:10px}.header-actions{display:flex;align-items:center;gap:var(--spacing-lg);margin-top:var(--spacing-md)}.tracks-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.tracks-table th{text-align:left;padding:var(--spacing-sm) var(--spacing-md);color:var(--text-secondary);border-bottom:1px solid var(--border-color);text-transform:uppercase;font-weight:500;font-size:12px;letter-spacing:.1em}.tracks-table td{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.05);color:var(--text-secondary);vertical-align:middle}.tracks-table tr{transition:background-color var(--transition-fast);cursor:default}.tracks-table tr:hover{background-color:#ffffff0d}.tracks-table tr.active{background-color:#8b5cf61a}.tracks-table tr.active td{color:var(--accent-primary)}.track-number{text-align:center;color:var(--text-muted)}.track-primary{display:flex;align-items:center;gap:var(--spacing-md)}.track-thumb{width:40px;height:40px;border-radius:var(--border-radius-sm);object-fit:cover}.track-info-cell{display:flex;flex-direction:column}.track-name{color:var(--text-primary);font-weight:500;font-size:var(--font-size-base)}.track-name.active-text{color:var(--accent-primary)}.track-artist{font-size:var(--font-size-xs)}.hover-danger:hover{color:#ef4444!important;background:#ef44441a}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) 0;color:var(--text-secondary);text-align:center;gap:var(--spacing-md)}@media (max-width: 768px){.playlist-header-content{flex-direction:column;align-items:center;text-align:center}.playlist-meta{align-items:center}.meta-stats{justify-content:center}.playlist-meta h1{font-size:2rem}.tracks-table th:nth-child(3),.tracks-table td:nth-child(3){display:none}}.history-page{padding:var(--spacing-xl);max-width:1200px;margin:0 auto;padding-bottom:120px}.history-page.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center;color:var(--text-muted)}.history-page.empty svg{margin-bottom:var(--spacing-lg);opacity:.5}.history-page.empty h2{color:var(--text-primary);margin-bottom:var(--spacing-sm)}.history-page.empty p{margin-bottom:var(--spacing-xl)}.history-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.history-header h1{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-xs)}.history-header p{color:var(--text-secondary)}.history-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.history-item{display:flex;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border-radius:var(--border-radius-md);transition:all var(--transition-fast);cursor:pointer;border:1px solid transparent}.history-item:hover{background:var(--bg-hover);transform:translate(4px);border-color:#ffffff0d}.history-index{color:var(--text-muted);font-size:var(--font-size-sm);width:30px;text-align:center;margin-right:var(--spacing-md)}.history-cover{width:48px;height:48px;border-radius:var(--border-radius-sm);overflow:hidden;margin-right:var(--spacing-md);position:relative;flex-shrink:0}.history-cover img{width:100%;height:100%;object-fit:cover}.history-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast)}.history-item:hover .history-overlay{opacity:1}.history-info{flex:1;min-width:0;margin-right:var(--spacing-md)}.history-info h3{font-size:var(--font-size-base);font-weight:500;margin-bottom:2px}.history-info p{font-size:var(--font-size-sm);color:var(--text-secondary)}.history-duration{color:var(--text-muted);font-size:var(--font-size-sm);font-feature-settings:"tnum"}@media (max-width: 768px){.history-page{padding:var(--spacing-md);padding-bottom:120px}.history-index{display:none}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl)}.auth-card{width:100%;max-width:420px;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--border-radius-xl);padding:var(--spacing-md) var(--spacing-2xl);box-shadow:var(--shadow-lg)}.auth-header{text-align:center;margin-bottom:var(--spacing-lg)}.auth-header h1{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-sm);background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-header p{color:var(--text-secondary)}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-lg);font-size:var(--font-size-sm);cursor:pointer;transition:opacity var(--transition-fast)}.auth-error:hover{opacity:.8}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-group label{font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary)}.input-wrapper{position:relative;display:flex;align-items:center}.input-wrapper>svg{position:absolute;left:var(--spacing-md);color:var(--text-muted);pointer-events:none;z-index:1}.input-wrapper input{width:100%;padding:var(--spacing-sm) var(--spacing-md);padding-left:calc(var(--spacing-md) * 2 + 18px);padding-right:48px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);color:var(--text-primary);font-size:var(--font-size-base);transition:all var(--transition-fast)}.input-wrapper input::placeholder{color:var(--text-muted)}.input-wrapper input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #8b5cf633}.password-toggle{position:absolute;right:8px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast);z-index:2}.password-toggle:hover{color:var(--accent-primary)}.password-toggle svg{pointer-events:none}.auth-submit{margin-top:var(--spacing-sm);padding:var(--spacing-md);font-size:var(--font-size-base)}.auth-footer{text-align:center;margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.auth-footer p{font-size:var(--font-size-sm);color:var(--text-secondary)}.auth-footer a{color:var(--accent-primary);font-weight:500}.auth-footer a:hover{text-decoration:underline}@media (max-width: 768px){.auth-page{padding:var(--spacing-md);padding-bottom:100px}.auth-card{padding:var(--spacing-xl)}}.admin-dashboard{padding:var(--spacing-lg);max-width:1200px;margin:0 auto}.admin-header{margin-bottom:var(--spacing-xl)}.admin-header h1{font-size:var(--font-size-3xl);background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-xs)}.admin-header p{color:var(--text-secondary)}.admin-alert{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-lg);font-size:var(--font-size-sm)}.admin-alert.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;cursor:pointer}.admin-alert.success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#22c55e}.admin-section{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.admin-section h2{font-size:var(--font-size-xl);display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.section-header h2{margin-bottom:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.stats-grid.secondary{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.stat-card{background:var(--bg-tertiary);border-radius:var(--border-radius-md);padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md)}.stat-card.mini{padding:var(--spacing-md);font-size:var(--font-size-sm);color:var(--text-secondary)}.stat-card.mini strong{color:var(--text-primary)}.stat-icon{width:48px;height:48px;border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.today{background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff}.stat-icon.month{background:linear-gradient(135deg,#ec4899,#f472b6);color:#fff}.stat-icon.year{background:linear-gradient(135deg,#10b981,#34d399);color:#fff}.stat-icon.total{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#fff}.stat-info{display:flex;flex-direction:column}.stat-label{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary)}.stat-sublabel{font-size:var(--font-size-xs);color:var(--text-secondary)}.users-table-container{overflow-x:auto}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--border-color)}.users-table th{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-weight:600}.users-table td{font-size:var(--font-size-sm)}.role-badge{display:inline-block;padding:2px 8px;border-radius:var(--border-radius-full);font-size:var(--font-size-xs);font-weight:500}.role-badge.admin{background:#8b5cf633;color:#a78bfa}.role-badge.user{background:#64748b33;color:#94a3b8}.status-badge{display:inline-block;padding:4px 10px;border-radius:var(--border-radius-full);font-size:var(--font-size-xs);font-weight:600}.status-badge.active{background:#22c55e33;color:#4ade80}.status-badge.suspended{background:#ef444433;color:#f87171}.action-buttons{display:flex;gap:var(--spacing-sm);justify-content:flex-start}.btn-action{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm);font-weight:500;border-radius:var(--border-radius-md);background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff;border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-action:hover{transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf666}.btn-action.danger{background:linear-gradient(135deg,#ef4444,#f87171)}.btn-action.danger:hover{box-shadow:0 4px 12px #ef444466}.btn-action.success{background:linear-gradient(135deg,#22c55e,#4ade80)}.btn-action.success:hover{box-shadow:0 4px 12px #22c55e66}.btn-action.secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.btn-action.secondary:hover{background:var(--bg-hover);color:var(--text-primary);box-shadow:none}.btn-action.warning{background:linear-gradient(135deg,#f59e0b,#fbbf24)}.btn-action.warning:hover{box-shadow:0 4px 12px #f59e0b66}.btn-action.info{background:linear-gradient(135deg,#3b82f6,#60a5fa)}.btn-action.info:hover{box-shadow:0 4px 12px #3b82f666}.edit-input,.edit-select{padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:var(--font-size-sm)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg)}.modal-content{background:var(--bg-secondary);border-radius:var(--border-radius-lg);max-width:480px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-header h3{font-size:var(--font-size-lg)}.modal-form{padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.modal-subtitle{color:var(--text-secondary);font-size:var(--font-size-sm);margin:0}.modal-subtitle strong{color:var(--accent-primary)}.modal-form .form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.modal-form label{font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary)}.modal-form input,.modal-form select{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);color:var(--text-primary);font-size:var(--font-size-base)}.modal-form input:focus,.modal-form select:focus{outline:none;border-color:var(--accent-primary)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-md)}@media (max-width: 768px){.admin-dashboard{padding:var(--spacing-md);padding-bottom:100px}.admin-section{padding:var(--spacing-md)}.section-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.stats-grid{grid-template-columns:1fr 1fr}.users-table th:nth-child(4),.users-table td:nth-child(4){display:none}}.devices-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#3b82f626;color:#60a5fa;border-radius:var(--border-radius-full);font-size:var(--font-size-sm);font-weight:500}.btn-action{display:inline-flex;align-items:center;gap:6px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.modal-edit-user{max-width:500px}.edit-user-info{padding:0 var(--spacing-lg);padding-top:var(--spacing-sm)}.edit-user-email{color:var(--text-muted);font-size:var(--font-size-sm)}.form-hint{color:var(--text-muted);font-size:var(--font-size-xs)}.form-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:var(--spacing-sm);border-radius:var(--border-radius-md);font-size:var(--font-size-sm)}.danger-zone{border-top:1px solid var(--border-color);padding:var(--spacing-lg);margin-top:var(--spacing-md)}.danger-zone h4{color:#ef4444;font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--spacing-md);text-transform:uppercase;letter-spacing:.5px}.danger-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.btn-warning{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#fff}.btn-success{background:linear-gradient(135deg,#22c55e,#4ade80);color:#fff}.btn-danger{background:linear-gradient(135deg,#ef4444,#f87171);color:#fff;display:inline-flex;align-items:center;gap:6px}.btn-warning:hover,.btn-success:hover,.btn-danger:hover{transform:translateY(-2px)}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{flex:1;padding-right:44px}.password-toggle-btn{position:absolute;right:8px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast)}.password-toggle-btn:hover{color:var(--text-primary)}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{margin-left:var(--sidebar-width);margin-top:var(--header-height);min-height:calc(100vh - var(--header-height) - var(--player-height));padding:var(--spacing-xl);padding-bottom:calc(var(--player-height) + var(--spacing-xl))}@media (max-width: 768px){.main-content{margin-left:0;padding:var(--spacing-md);padding-bottom:calc(var(--player-height) + var(--spacing-md))}}:root{--bg-primary: #121212;--bg-secondary: #1e1e1e;--bg-tertiary: #282828;--bg-card: rgba(40, 40, 40, .8);--bg-hover: rgba(255, 255, 255, .1);--accent-primary: #8b5cf6;--accent-secondary: #a78bfa;--accent-gradient: linear-gradient(135deg, #8b5cf6 0%, #a78bfa 100%);--accent-glow: 0 0 20px rgba(139, 92, 246, .5);--text-primary: #ffffff;--text-secondary: #b3b3b3;--text-muted: #7a7a7a;--border-color: rgba(255, 255, 255, .1);--border-radius-sm: 8px;--border-radius-md: 12px;--border-radius-lg: 16px;--border-radius-xl: 24px;--border-radius-full: 9999px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--sidebar-width: 280px;--header-height: 64px;--player-height: 90px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--glass-bg: rgba(40, 40, 40, .7);--glass-blur: blur(20px);--glass-border: 1px solid rgba(255, 255, 255, .1)}[data-theme=light]{--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-tertiary: #e5e5e5;--bg-card: rgba(255, 255, 255, .9);--bg-hover: rgba(0, 0, 0, .05);--text-primary: #121212;--text-secondary: #5a5a5a;--text-muted: #8a8a8a;--border-color: rgba(0, 0, 0, .1);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12);--glass-bg: rgba(255, 255, 255, .8);--glass-border: 1px solid rgba(0, 0, 0, .06)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at top left,rgba(139,92,246,.1) 0%,transparent 50%),radial-gradient(ellipse at bottom right,rgba(0,0,0,.3) 0%,transparent 50%),var(--bg-primary);z-index:-1;pointer-events:none;transition:background var(--transition-base)}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;color:var(--text-primary)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}p{color:var(--text-secondary)}a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-secondary)}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-base)}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:var(--accent-glow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 30px #8b5cf680}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--accent-primary)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-hover)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--border-radius-full)}.btn-icon-sm{width:32px;height:32px}.btn-icon-lg{width:56px;height:56px}.card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--border-radius-lg);padding:var(--spacing-md);transition:all var(--transition-base)}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#8b5cf64d}.card-cover{position:relative;aspect-ratio:1;border-radius:var(--border-radius-md);overflow:hidden;margin-bottom:var(--spacing-md)}.card-cover img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.card:hover .card-cover img{transform:scale(1.05)}.card-cover .play-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000080;opacity:0;transition:opacity var(--transition-base)}.card:hover .card-cover .play-overlay{opacity:1}input,textarea{font-family:inherit;font-size:var(--font-size-base)}.input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);color:var(--text-primary);transition:all var(--transition-fast)}.input::placeholder{color:var(--text-muted)}.input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #8b5cf633}.app-layout{display:grid;grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:var(--header-height) 1fr var(--player-height);min-height:100vh}.main-content{grid-column:2;grid-row:2;overflow-y:auto;padding:var(--spacing-xl);padding-bottom:calc(var(--player-height) + var(--spacing-xl))}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.grid{display:grid;gap:var(--spacing-lg)}.grid-tracks{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.grid-artists{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.text-gradient{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-pulse{animation:pulse 2s infinite}.animate-spin{animation:spin 1s linear infinite}.animate-slide-up{animation:slideUp .5s ease-out}.animate-fade-in{animation:fadeIn .3s ease-out}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 0%,var(--bg-secondary) 50%,var(--bg-tertiary) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--border-radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.playing-bars{display:flex;align-items:flex-end;gap:2px;height:16px}.playing-bars span{width:3px;background:var(--accent-primary);border-radius:1px;animation:playingBar .8s ease-in-out infinite}.playing-bars span:nth-child(1){animation-delay:0s;height:60%}.playing-bars span:nth-child(2){animation-delay:.2s;height:100%}.playing-bars span:nth-child(3){animation-delay:.4s;height:40%}.playing-bars span:nth-child(4){animation-delay:.6s;height:80%}@keyframes playingBar{0%,to{transform:scaleY(.5)}50%{transform:scaleY(1)}}@media (max-width: 1024px){:root{--sidebar-width: 80px}}@media (max-width: 768px){:root{--sidebar-width: 0px;--header-height: 56px;--player-height: 70px}.app-layout{grid-template-columns:1fr}.main-content{grid-column:1;padding:var(--spacing-md)}.grid-tracks{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}
