@import url(https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800;900&display=swap);*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#1db954;--primary-hover:#1ed760;--bg-dark:#121212;--bg-elevated:#1a1a1a;--bg-card:#282828;--text-primary:#fff;--text-secondary:#b3b3b3;--border:#404040}body{font-family:Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;overflow:hidden}body.dark-mode{background:#121212;background:var(--bg-dark);color:#fff;color:var(--text-primary)}body.light-mode{background:#f5f5f5;color:#000}.app{display:flex;height:100vh;overflow:hidden}.app.dark{--bg:#121212;--bg-elevated:#1a1a1a;--bg-card:#282828;--text:#fff;--text-muted:#b3b3b3;--border:#404040;--accent:#1db954}.app.light{--bg:#fff;--bg-elevated:#f5f5f5;--bg-card:#fff;--text:#000;--text-muted:#666;--border:#e0e0e0;--accent:#1db954}.sidebar{background:#1a1a1a;background:var(--bg-elevated);border-right:1px solid #404040;border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;gap:1.5rem;overflow-x:hidden;overflow-y:auto;padding:1.5rem 1rem 110px;width:280px}.sidebar-header{justify-content:flex-start;padding:0 .5rem}.logo-section,.sidebar-header{align-items:center;display:flex}.logo-section{gap:.75rem}.logo-icon{align-items:center;color:var(--accent);display:flex;font-size:2rem;justify-content:center}.logo-image{border-radius:4px;height:40px;object-fit:contain;width:40px}.logo-text{color:var(--text);font-size:1.5rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-sidebar{padding:0 .5rem;position:relative}.search-icon-wrapper{color:var(--text-muted);left:1.5rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);z-index:1}.search-sidebar input{background:#282828;background:var(--bg-card);border:1px solid #404040;border:1px solid var(--border);border-radius:25px;color:var(--text);font-size:.9rem;padding:.75rem 1rem .75rem 3rem;width:100%}.search-sidebar input:focus{border-color:var(--accent);outline:none}.sidebar-nav{display:flex;flex-direction:column;gap:.5rem}.sidebar-nav a{align-items:center;border-radius:8px;color:var(--text-muted);cursor:pointer;display:flex;font-weight:500;gap:1rem;overflow:hidden;padding:.75rem 1rem;text-decoration:none;transition:all .3s;white-space:nowrap}.sidebar-nav a:hover{color:var(--text)}.sidebar-nav a.active,.sidebar-nav a:hover{background:#282828;background:var(--bg-card)}.sidebar-nav a.active{color:var(--accent)}.nav-icon{align-items:center;display:flex;justify-content:center;min-width:24px}.nav-icon svg{height:20px;width:20px}.sidebar-section{border-top:1px solid #404040;border-top:1px solid var(--border);padding-top:1rem}.sidebar-section h3{color:var(--text-muted);font-size:.85rem;letter-spacing:1px;padding:.5rem 1rem;text-transform:uppercase}.create-playlist-btn{align-items:center;background:#0000;border:1px dashed #404040;border:1px dashed var(--border);border-radius:8px;color:var(--text-muted);cursor:pointer;display:flex;font-size:1rem;gap:1rem;margin-bottom:.5rem;padding:.75rem 1rem;transition:all .3s}.create-playlist-btn span{align-items:center;display:flex;justify-content:center}.create-playlist-btn svg{height:20px;width:20px}.create-playlist-btn:hover{border-color:var(--accent);color:var(--accent)}.playlists-list{display:flex;flex-direction:column;gap:.25rem;max-height:200px;overflow-y:auto}.playlists-list a{align-items:center;border-radius:8px;color:var(--text-muted);cursor:pointer;display:flex;font-size:.9rem;gap:1rem;overflow:hidden;padding:.5rem 1rem;text-decoration:none;text-overflow:ellipsis;transition:all .3s;white-space:nowrap}.playlists-list a:hover{background:#282828;background:var(--bg-card);color:var(--text)}.sidebar-footer{border-top:1px solid #404040;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem;margin-top:auto;padding-top:1rem}.admin-btn,.login-btn,.logout-btn,.theme-toggle{align-items:center;background:#0000;border:1px solid #404040;border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;display:flex;font-size:.9rem;gap:1rem;overflow:hidden;padding:.75rem 1rem;transition:all .3s;white-space:nowrap}.admin-btn span,.login-btn span,.logout-btn span,.theme-toggle span{align-items:center;display:flex;justify-content:center;min-width:20px}.admin-btn svg,.login-btn svg,.logout-btn svg,.theme-toggle svg{flex-shrink:0;height:20px;width:20px}.admin-btn:hover,.login-btn:hover,.theme-toggle:hover{background:#282828;background:var(--bg-card);border-color:var(--accent)}.logout-btn:hover{background:#f44;border-color:#f44;color:#fff}.main-container{flex:1 1;flex-direction:column;overflow:hidden}.main-container,.top-navbar{display:flex;position:relative}.top-navbar{align-items:center;background:#1a1a1a;background:var(--bg-elevated);border-bottom:1px solid #404040;border-bottom:1px solid var(--border);justify-content:center;padding:1rem 2rem}.nav-tabs{display:flex;gap:1rem}.nav-tabs button{background:#0000;border:none;border-radius:25px;color:var(--text-muted);cursor:pointer;font-size:1rem;font-weight:600;padding:.5rem 1.5rem;transition:all .3s}.nav-tabs button:hover{color:var(--text)}.nav-tabs button.active{background:#282828;background:var(--bg-card);color:var(--accent)}.user-section{align-items:center;display:flex;gap:1rem;position:absolute;right:2rem}.user-badge{background:var(--accent);border-radius:25px;color:#fff;font-size:.85rem;font-weight:600;padding:.5rem 1rem}.user-avatar-badge{align-items:center;color:var(--text);cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .3s;width:40px}.user-avatar-badge:hover{color:var(--accent);transform:scale(1.1)}.user-avatar-badge svg{height:28px;width:28px}.content-area{background:var(--bg);overflow-y:auto;padding-bottom:0}.content-area,.home-view{display:flex;flex:1 1;flex-direction:column}.home-view{padding:2rem}.hero-section{align-items:center;animation:fadeInUp .6s ease-out;border-radius:12px;display:flex;height:400px;justify-content:center;margin-bottom:3rem;overflow:hidden;padding:3rem;position:relative}.hero-gradient{animation:gradientFlow 6s ease infinite;background:linear-gradient(135deg,#1db954,#1ed760 50%,#17a34a);background-size:200% 200%;inset:0;opacity:.95;position:absolute}@keyframes gradientFlow{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.hero-gradient:before{animation:floatingLight 8s ease-in-out infinite;background:radial-gradient(circle at center,#ffffff26 0,#0000 50%);content:"";height:200%;left:-50%;position:absolute;top:-50%;width:200%}@keyframes floatingLight{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.1)}66%{transform:translate(-30px,30px) scale(.9)}}.hero-gradient:after{animation:wave 4s ease-in-out infinite;background:linear-gradient(0deg,#0000001a 0,#0000 50%);bottom:0;content:"";height:100%;left:0;position:absolute;right:0}@keyframes wave{0%,to{opacity:.3}50%{opacity:.6}}.hero-content{max-width:800px;position:relative;text-align:center;z-index:2}.hero-content h1{animation:titleGlow .8s ease-out .2s both,floatTitle 3s ease-in-out infinite;color:#fff;font-size:4.5rem;font-weight:900;letter-spacing:2px;margin-bottom:1rem;text-shadow:0 4px 20px #0006,0 0 40px #fff3}@keyframes titleGlow{0%{opacity:0;text-shadow:0 0 0 #fff0;transform:scale(.8) translateY(20px)}to{opacity:1;text-shadow:0 4px 20px #0006,0 0 40px #fff3;transform:scale(1) translateY(0)}}@keyframes floatTitle{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.hero-content p{animation:fadeInUp .8s ease-out .4s both,shimmer 3s ease-in-out infinite;color:#fffffff2;font-size:1.5rem;font-weight:500;margin-bottom:2.5rem;text-shadow:0 2px 10px #0000004d}@keyframes shimmer{0%,to{opacity:.95}50%{opacity:1}}.hero-buttons{animation:fadeInUp .8s ease-out .6s both;display:flex;gap:1.5rem;justify-content:center}.hero-btn{align-items:center;border:none;border-radius:50px;cursor:pointer;display:flex;font-family:Poppins,sans-serif;font-size:1.1rem;font-weight:600;gap:.75rem;overflow:hidden;padding:1rem 2.5rem;position:relative;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.hero-btn:before{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.hero-btn:hover:before{height:300px;width:300px}.hero-btn svg{height:20px;transition:transform .3s;width:20px}.hero-btn span,.hero-btn svg{position:relative;z-index:1}.hero-btn.primary{animation:buttonPulse 2s ease-in-out infinite;background:#fff;box-shadow:0 4px 15px #ffffff4d;color:#1db954}@keyframes buttonPulse{0%,to{box-shadow:0 4px 15px #ffffff4d}50%{box-shadow:0 6px 25px #ffffff80}}.hero-btn.primary:hover{box-shadow:0 10px 30px #fff6;transform:scale(1.08) translateY(-3px)}.hero-btn.primary:hover svg{transform:scale(1.2) rotate(5deg)}.hero-btn.secondary{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:2px solid #fff;color:#fff}.hero-btn.secondary:hover{background:#ffffff40;box-shadow:0 10px 30px #ffffff4d;transform:scale(1.08) translateY(-3px)}.hero-btn.secondary:hover svg{transform:translateX(5px)}.about-section{animation:fadeInUp .8s ease-out .3s both;margin-bottom:3rem;padding:4rem 0}.about-content{margin:0 auto;max-width:1200px}.about-text h2{animation:fadeInLeft .8s ease-out .4s both;color:var(--text);font-size:2.5rem;font-weight:800;margin-bottom:1.5rem}@keyframes fadeInLeft{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}.about-text p{animation:fadeInUp .8s ease-out .5s both;color:var(--text-muted);font-size:1.1rem;line-height:1.8;margin-bottom:1.5rem}.about-features{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:3rem}.feature-item{animation:fadeInUp .8s ease-out both;background:#282828;background:var(--bg-card);border-radius:12px;padding:2rem;text-align:center;transition:all .3s}.feature-item:first-child{animation-delay:.6s}.feature-item:nth-child(2){animation-delay:.7s}.feature-item:nth-child(3){animation-delay:.8s}.feature-item:hover{box-shadow:0 15px 40px #1db9544d;transform:translateY(-10px)}.feature-icon{align-items:center;background:linear-gradient(135deg,#1db954,#1ed760);border-radius:50%;color:#fff;display:flex;height:80px;justify-content:center;margin:0 auto 1.5rem;transition:all .3s;width:80px}.feature-item:hover .feature-icon{transform:scale(1.1) rotate(5deg)}.feature-icon svg{height:40px;width:40px}.feature-item h4{color:var(--text);font-size:1.3rem;margin-bottom:.75rem}.feature-item p{color:var(--text-muted);font-size:1rem}.stats-section{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:4rem 0}.stat-card{animation:fadeInUp .6s ease-out forwards;background:#282828;background:var(--bg-card);border:1px solid #404040;border:1px solid var(--border);border-radius:12px;padding:2.5rem 2rem;text-align:center;transition:all .3s}.stat-card:first-child{animation-delay:.2s}.stat-card:nth-child(2){animation-delay:.3s}.stat-card:nth-child(3){animation-delay:.4s}.stat-card:nth-child(4){animation-delay:.5s}.stat-card:hover{border-color:var(--accent);box-shadow:0 15px 40px #1db9544d;transform:translateY(-8px) scale(1.05)}.stat-icon{height:60px;margin:0 auto 1rem;width:60px}.stat-icon svg{height:30px;width:30px}.stat-card h3{color:var(--accent);font-size:2.5rem;font-weight:800;margin-bottom:.5rem}.stat-card p{color:var(--text-muted);font-size:1rem;font-weight:500}.cta-section{animation:fadeInUp .8s ease-out both;background:linear-gradient(135deg,#1db954,#1ed760);border-radius:12px;margin:4rem 0;overflow:hidden;padding:4rem 3rem;position:relative;text-align:center}.cta-section:before{animation:rotate 20s linear infinite;background:radial-gradient(circle,#ffffff1a 0,#0000 70%);content:"";height:200%;left:-50%;position:absolute;top:-50%;width:200%}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.cta-content{position:relative;z-index:1}.cta-content h2{animation:fadeInScale .8s ease-out .3s both;color:#fff;font-size:3rem;font-weight:800;margin-bottom:1rem}.cta-content p{animation:fadeInUp .8s ease-out .5s both;color:#fffffff2;font-size:1.3rem;margin-bottom:2rem}.cta-button{align-items:center;animation:fadeInUp .8s ease-out .7s both;background:#fff;border:none;border-radius:50px;color:#1db954;cursor:pointer;display:inline-flex;font-family:Poppins,sans-serif;font-size:1.2rem;font-weight:700;gap:.75rem;padding:1.2rem 3rem;transition:all .3s}.cta-button svg{height:24px;transition:transform .3s;width:24px}.cta-button:hover{box-shadow:0 15px 40px #0006;transform:scale(1.08)}.cta-button:hover svg{transform:translateX(5px)}.footer{background:#1a1a1a;background:var(--bg-elevated);border-top:1px solid #404040;border-top:1px solid var(--border);margin-bottom:0;margin-top:auto;padding:3rem 2rem 2rem;position:relative}.footer-content{margin:0 auto;max-width:1200px}.footer-main{align-items:center;display:flex;flex-wrap:wrap;gap:3rem;justify-content:space-between;margin-bottom:2rem}.footer-brand{flex:1 1;min-width:250px}.footer-logo{align-items:center;color:var(--accent);display:flex;gap:.75rem;margin-bottom:1rem}.footer-logo svg{height:32px;width:32px}.footer-logo span{color:var(--text);font-size:1.5rem;font-weight:800}.footer-brand p{color:var(--text-muted);font-size:.95rem;line-height:1.6;max-width:400px}.footer-nav{display:flex;flex-wrap:wrap;gap:1rem}.footer-nav button{background:#282828;background:var(--bg-card);border:1px solid #404040;border:1px solid var(--border);border-radius:8px;color:var(--text-muted);cursor:pointer;font-family:Poppins,sans-serif;font-size:.95rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s}.footer-nav button:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-2px)}.footer-bottom{border-top:1px solid #404040;border-top:1px solid var(--border);color:var(--text-muted);font-size:.9rem;padding-top:1.5rem;text-align:center}.footer-bottom p{align-items:center;display:flex;gap:.5rem;justify-content:center}.music-section{animation:fadeInUp .8s ease-out both;margin-bottom:3rem}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.section-header h2{align-items:center;color:var(--text);display:flex;font-size:2rem;font-weight:700;gap:.75rem}.section-header h2 svg{animation:pulse 2s ease-in-out infinite;color:var(--accent);height:28px;width:28px}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.section-header button{background:#0000;border:1px solid #404040;border:1px solid var(--border);border-radius:25px;color:var(--text-muted);cursor:pointer;font-weight:600;padding:.5rem 1.5rem;transition:all .3s}.section-header button:hover{border-color:var(--accent);color:var(--accent)}.music-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));margin-bottom:3rem}.music-card{animation:fadeInUp .5s ease-out forwards;background:#282828;background:var(--bg-card);border-radius:12px;cursor:pointer;padding:1rem;position:relative;transition:all .3s}.music-card:first-child{animation-delay:.1s}.music-card:nth-child(2){animation-delay:.15s}.music-card:nth-child(3){animation-delay:.2s}.music-card:nth-child(4){animation-delay:.25s}.music-card:nth-child(5){animation-delay:.3s}.music-card:nth-child(6){animation-delay:.35s}.music-card:nth-child(7){animation-delay:.4s}.music-card:nth-child(8){animation-delay:.45s}.music-card:hover{background:#333;box-shadow:0 12px 30px #1db9544d;transform:translateY(-8px) scale(1.02)}.card-image{aspect-ratio:1;border-radius:8px;margin-bottom:1rem;overflow:hidden;position:relative;width:100%}.image-placeholder{align-items:center;background:linear-gradient(135deg,#1db954,#1ed760);color:#ffffff4d;display:flex;font-size:4rem;height:100%;justify-content:center;width:100%}.image-placeholder svg{height:60px;width:60px}.card-image img{height:100%;object-fit:cover;width:100%}.play-button{align-items:center;background:var(--accent);border:none;border-radius:50%;bottom:10px;box-shadow:0 8px 16px #0006;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:50px;justify-content:center;opacity:0;position:absolute;right:10px;transform:translateY(10px);transition:all .3s;width:50px}.play-button svg{height:20px;margin-left:2px;width:20px}.music-card:hover .play-button{opacity:1;transform:translateY(0)}.play-button:hover{background:#1ed760;background:var(--primary-hover);transform:scale(1.1)}.favorite-button{align-items:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:35px;justify-content:center;opacity:0;position:absolute;right:10px;top:10px;transition:all .3s;width:35px}.favorite-button svg{height:18px;width:18px}.music-card:hover .favorite-button{opacity:1}.card-info h4{color:var(--text);font-size:1rem;margin-bottom:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-info p{color:var(--text-muted);font-size:.9rem}.album-year{color:var(--text-muted);display:block;font-size:.85rem;margin-top:.25rem}.artist-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));margin-bottom:3rem}.artist-card-new{animation:fadeInUp .5s ease-out forwards;background:#282828;background:var(--bg-card);border-radius:12px;cursor:pointer;padding:1rem;text-align:center;transition:all .3s}.artist-card-new:first-child{animation-delay:.1s}.artist-card-new:nth-child(2){animation-delay:.15s}.artist-card-new:nth-child(3){animation-delay:.2s}.artist-card-new:nth-child(4){animation-delay:.25s}.artist-card-new:nth-child(5){animation-delay:.3s}.artist-card-new:nth-child(6){animation-delay:.35s}.artist-card-new:nth-child(7){animation-delay:.4s}.artist-card-new:nth-child(8){animation-delay:.45s}.artist-card-new:hover{background:#333;transform:translateY(-5px)}.artist-image{aspect-ratio:1;border-radius:50%;margin-bottom:1rem;overflow:hidden;width:100%}.artist-image img{height:100%;object-fit:cover;width:100%}.artist-placeholder-new{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#ffffff4d;display:flex;font-size:4rem;height:100%;justify-content:center;width:100%}.artist-placeholder-new svg{height:60px;width:60px}.artist-card-new h4{color:var(--text);font-size:1rem;margin-bottom:.5rem}.artist-card-new span{color:var(--text-muted);font-size:.85rem;letter-spacing:1px;text-transform:uppercase}.artist-detail-header{margin-bottom:3rem}.empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px;padding:4rem 2rem;text-align:center}.empty-state svg{color:var(--text-muted);height:80px;margin-bottom:1.5rem;opacity:.5;width:80px}.empty-state h3{color:var(--text);font-size:1.8rem;font-weight:700;margin-bottom:.5rem}.empty-state p{color:var(--text-muted);font-size:1.1rem;margin-bottom:2rem}.empty-state .cta-button{align-items:center;background:var(--accent);border:none;border-radius:50px;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.75rem;padding:1rem 2rem;transition:all .3s}.empty-state .cta-button:hover{background:#1ed760;background:var(--primary-hover);box-shadow:0 8px 24px #1db9544d;transform:scale(1.05)}.empty-state .cta-button svg{color:#fff;height:20px;margin:0;opacity:1;width:20px}.btn-back-page{align-items:center;background:#282828;background:var(--bg-card);border:1px solid #404040;border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;margin-bottom:2rem;padding:.75rem 1.5rem;transition:all .3s}.btn-back-page svg{height:20px;width:20px}.btn-back-page:hover{background:#1a1a1a;background:var(--bg-elevated);border-color:var(--accent);color:var(--accent);transform:translateX(-5px)}.artist-detail-hero{align-items:flex-end;background:linear-gradient(135deg,#1db95433,#1db9540d);border:1px solid #404040;border:1px solid var(--border);border-radius:12px;display:flex;gap:3rem;padding:3rem}.artist-detail-image{border:4px solid var(--accent);border-radius:50%;box-shadow:0 20px 60px #1db9544d;flex-shrink:0;height:250px;overflow:hidden;width:250px}.artist-detail-image img{height:100%;object-fit:cover;width:100%}.artist-detail-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#ffffff80;display:flex;height:100%;justify-content:center;width:100%}.artist-detail-placeholder svg{height:100px;width:100px}.artist-detail-info{flex:1 1}.artist-badge{background:var(--accent);border-radius:25px;color:#fff;display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:1px;margin-bottom:1rem;padding:.5rem 1rem}.artist-detail-info h1{color:var(--text);font-size:4rem;font-weight:900;line-height:1;margin-bottom:1rem}.artist-bio{color:var(--text-muted);font-size:1.1rem;line-height:1.6;margin-bottom:1.5rem;max-width:800px}.artist-stats{align-items:center;color:var(--text-muted);display:flex;font-size:1rem;font-weight:600;gap:1rem}.artist-section{margin-bottom:3rem}.artist-section h2{color:var(--text);font-size:2rem;font-weight:700;margin-bottom:1.5rem}.page-view{display:flex;flex:1 1;flex-direction:column;padding:2rem}.page-header{align-items:center;display:flex;gap:1rem;margin-bottom:2rem}.page-header svg{color:var(--accent);height:48px;width:48px}.page-header h1,.page-view h1{color:var(--text);font-size:3rem;font-weight:800}.songs-table{background:#282828;background:var(--bg-card);border-radius:12px;margin-bottom:3rem;overflow:hidden}.song-row-new{grid-gap:1rem;align-items:center;border-bottom:1px solid #404040;border-bottom:1px solid var(--border);cursor:pointer;display:grid;gap:1rem;grid-template-columns:60px 1fr 200px 140px;padding:1rem 1.5rem;position:relative;transition:all .3s}.song-row-new:hover{background:#1a1a1a;background:var(--bg-elevated);z-index:10}.row-album,.row-info,.song-row-cover{cursor:pointer}.song-actions{align-items:center;display:flex;gap:.5rem;justify-content:flex-end}.song-menu-dropdown{position:relative}.btn-song-menu{align-items:center;background:#0000;border:1px solid #404040;border:1px solid var(--border);border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .3s;width:32px}.btn-song-menu svg{height:16px;width:16px}.btn-song-menu:hover{background:#1a1a1a;background:var(--bg-elevated);border-color:var(--accent);color:var(--accent)}.song-menu-dropdown-content{background:#282828;background:var(--bg-card);border:1px solid #404040;border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #0006;margin-left:-10rem;margin-top:-6rem;min-width:180px;opacity:0;position:fixed;transform:translateY(10px);transition:all .3s;visibility:hidden;z-index:1000}.song-menu-dropdown .song-menu-dropdown-content:hover,.song-menu-dropdown:hover .song-menu-dropdown-content{opacity:1;transform:translateY(0);visibility:visible}.song-menu-dropdown-content a,.song-menu-dropdown-content button{align-items:center;background:#0000;border:none;color:var(--text);cursor:pointer;display:flex;font-family:inherit;font-size:.9rem;gap:.75rem;padding:.75rem 1rem;text-align:left;text-decoration:none;transition:all .3s;width:100%}.song-menu-dropdown-content a svg,.song-menu-dropdown-content button svg{color:var(--accent);height:16px;width:16px}.song-menu-dropdown-content a:hover,.song-menu-dropdown-content button:hover{background:#1a1a1a;background:var(--bg-elevated);color:var(--accent)}.song-menu-dropdown-content a:first-child,.song-menu-dropdown-content button:first-child{border-radius:8px 8px 0 0}.song-menu-dropdown-content a:last-child,.song-menu-dropdown-content button:last-child{border-radius:0 0 8px 8px}.add-to-playlist-dropdown{position:relative}.btn-add-playlist{align-items:center;background:#0000;border:1px solid #404040;border:1px solid var(--border);border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .3s;width:32px}.btn-add-playlist svg{height:16px;width:16px}.btn-add-playlist:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:scale(1.1)}.playlist-dropdown-menu{background:#282828;background:var(--bg-card);border:1px solid #404040;border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #0006;margin-left:-12rem;margin-top:-8rem;max-height:300px;max-width:300px;min-width:200px;opacity:0;overflow-y:auto;position:fixed;transform:translateY(10px);transition:all .3s;visibility:hidden;z-index:1000}.add-to-playlist-dropdown .playlist-dropdown-menu:hover,.add-to-playlist-dropdown:hover .playlist-dropdown-menu{opacity:1;transform:translateY(0);visibility:visible}.playlist-dropdown-menu button{word-wrap:break-word;align-items:center;background:#0000;border:none;color:var(--text);cursor:pointer;display:flex;font-size:.9rem;gap:.75rem;padding:.75rem 1rem;text-align:left;transition:all .3s;white-space:normal;width:100%}.playlist-dropdown-menu button span{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;flex:1 1;line-height:1.4;overflow:hidden;text-overflow:ellipsis}.playlist-dropdown-menu button svg{color:var(--accent);height:16px;width:16px}.playlist-dropdown-menu button:hover{background:#1a1a1a;background:var(--bg-elevated);color:var(--accent)}.no-playlists{padding:1rem;text-align:center}.no-playlists p{color:var(--text-muted);font-size:.9rem;margin-bottom:.75rem}.no-playlists button{background:var(--accent);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:.5rem 1rem;transition:all .3s;width:100%}.no-playlists button:hover{background:#1ed760;background:var(--primary-hover)}.playlist-actions{display:flex;gap:1rem;margin-bottom:2rem}.btn-remove-from-playlist{align-items:center;background:#0000;border:1px solid #404040;border:1px solid var(--border);border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .3s;width:32px}.btn-remove-from-playlist svg{height:16px;width:16px}.btn-remove-from-playlist:hover{background:#f44;border-color:#f44;color:#fff;transform:scale(1.1)}.btn-delete-playlist{align-items:center;background:#f44;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s}.btn-delete-playlist svg{height:18px;width:18px}.btn-delete-playlist:hover{background:red;box-shadow:0 4px 12px #f446;transform:translateY(-2px)}.song-row-cover{border:2px solid #404040;border:2px solid var(--border);border-radius:50%;flex-shrink:0;height:50px;overflow:hidden;width:50px}.song-row-cover img{height:100%;object-fit:cover;width:100%}.song-cover-placeholder{align-items:center;background:linear-gradient(135deg,#1db954,#1ed760);color:#ffffff80;display:flex;height:100%;justify-content:center;width:100%}.song-cover-placeholder svg{height:24px;width:24px}.row-info h4{color:var(--text);font-size:1rem;margin-bottom:.25rem}.row-album,.row-info p{color:var(--text-muted);font-size:.9rem}.row-favorite{align-items:center;background:#0000;border:none;color:var(--text-muted);cursor:pointer;display:flex;font-size:1.2rem;justify-content:center;transition:transform .3s}.row-favorite svg{height:20px;width:20px}.row-favorite:hover{color:var(--accent);transform:scale(1.2)}.row-duration{color:var(--text-muted);text-align:right}.browse-hero{align-items:center;animation:fadeInUp .6s ease-out;background:linear-gradient(135deg,#1db954,#1ed760);border-radius:12px;display:flex;height:300px;justify-content:center;margin-bottom:3rem;overflow:hidden;position:relative}.browse-hero:before{animation:patternMove 20s linear infinite;background:url("data:image/svg+xml;charset=utf-8,%3Csvg width='100' height='100' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='50' cy='50' r='40' fill='rgba(255,255,255,0.05)'/%3E%3C/svg%3E");background-size:100px 100px;content:"";inset:0;position:absolute}@keyframes patternMove{0%{transform:translate(0)}to{transform:translate(100px,100px)}}.browse-hero-content{position:relative;text-align:center;z-index:2}.browse-hero-content h1{animation:fadeInScale .8s ease-out .2s both;color:#fff;font-size:4rem;font-weight:900;margin-bottom:1rem;text-shadow:0 4px 20px #0000004d}.browse-hero-content p{animation:fadeInUp .8s ease-out .4s both;color:#fffffff2;font-size:1.5rem;text-shadow:0 2px 10px #0003}.browse-content{animation:fadeInUp .8s ease-out .3s both}.browse-section{margin-bottom:4rem}.browse-section>h2{color:var(--text);font-size:2rem;font-weight:700;margin-bottom:2rem}.browse-categories-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.browse-category-card{animation:fadeInUp .6s ease-out both;background:#282828;background:var(--bg-card);border:2px solid #404040;border:2px solid var(--border);border-radius:16px;cursor:pointer;overflow:hidden;padding:2rem;position:relative;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.browse-category-card:first-child{animation-delay:.1s}.browse-category-card:nth-child(2){animation-delay:.2s}.browse-category-card:nth-child(3){animation-delay:.3s}.browse-category-card:nth-child(4){animation-delay:.4s}.browse-category-card:nth-child(5){animation-delay:.5s}.browse-category-card:nth-child(6){animation-delay:.6s}.browse-category-card.featured{background:linear-gradient(135deg,#1db954,#1ed760);border-color:#1db954;grid-column:span 2}.browse-category-card.featured .category-content h3,.browse-category-card.featured .category-content p{color:#fff}.browse-category-card.featured .category-arrow,.browse-category-card.featured .category-icon-wrapper{background:#fff3;color:#fff}.category-bg-pattern{background:radial-gradient(circle,#1db9541a 0,#0000 70%);height:200%;pointer-events:none;position:absolute;right:-50%;top:-50%;transition:all .6s;width:200%}.browse-category-card:hover .category-bg-pattern{transform:scale(1.5) rotate(45deg)}.browse-category-card:hover{border-color:var(--accent);box-shadow:0 20px 50px #1db9544d;transform:translateY(-10px) scale(1.02)}.category-icon-wrapper{align-items:center;background:linear-gradient(135deg,#1db954,#1ed760);border-radius:16px;color:#fff;display:flex;height:70px;justify-content:center;margin-bottom:1.5rem;transition:all .4s;width:70px}.category-icon-wrapper svg{height:35px;width:35px}.browse-category-card:hover .category-icon-wrapper{box-shadow:0 10px 30px #1db95466;transform:scale(1.1) rotate(5deg)}.category-content{position:relative;z-index:1}.category-content h3{color:var(--text);font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.category-content p{color:var(--text-muted);font-size:1rem;margin-bottom:1rem}.category-arrow{align-items:center;background:#1a1a1a;background:var(--bg-elevated);border-radius:50%;color:var(--accent);display:flex;height:40px;justify-content:center;margin-top:1rem;transition:all .3s;width:40px}.category-arrow svg{height:20px;width:20px}.browse-category-card:hover .category-arrow{background:var(--accent);color:#fff;transform:translateX(10px)}.browse-categories{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.category-card{background:#282828;background:var(--bg-card);border-radius:12px;cursor:pointer;padding:3rem 2rem;text-align:center;transition:all .3s}.category-card:hover{background:#333;transform:translateY(-5px)}.category-card span{color:var(--accent);display:block;font-size:4rem;margin-bottom:1rem}.category-card span svg{height:80px;width:80px}.category-card h3{color:var(--text);font-size:1.5rem}.login-page-fullscreen{align-items:center;background:#fff;display:flex;height:100vh;justify-content:center;left:0;overflow-y:auto;padding:2rem;position:fixed;top:0;width:100vw;z-index:9999}.login-page-fullscreen:before{animation:floatingLight 8s ease-in-out infinite;background:radial-gradient(circle at center,#1db9540d 0,#0000 50%);content:"";height:200%;left:-50%;pointer-events:none;position:fixed;top:-50%;width:200%}.login-container{animation:fadeInScale .8s ease-out;margin:auto;max-width:500px;position:relative;text-align:center;width:100%;z-index:2}.login-brand{margin-bottom:2rem}.login-logo{align-items:center;animation:pulse 2s ease-in-out infinite;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#1db954,#1ed760);border-radius:50%;box-shadow:0 8px 24px #1db9544d;color:#fff;display:flex;height:80px;justify-content:center;margin:0 auto 1rem;width:80px}.login-logo svg{height:40px;width:40px}.login-brand h1{color:#1db954;font-size:2.5rem;font-weight:900;letter-spacing:2px;margin-bottom:.5rem;text-shadow:none}.login-brand p{color:#666;font-size:1rem;text-shadow:none}.login-page-fullscreen .auth-box{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#282828;border:1px solid #404040;box-shadow:0 20px 60px #00000080;max-width:450px}.login-page-fullscreen .auth-icon{background:#1db954}.login-page-fullscreen .auth-box h2{color:#fff}.login-page-fullscreen .auth-box p,.login-page-fullscreen .form-group label{color:#b3b3b3}.login-page-fullscreen .form-group input{background:#1a1a1a;border:1px solid #404040;color:#fff}.login-page-fullscreen .form-group input:focus{border-color:#1db954}.login-page-fullscreen .submit-btn{background:#1db954}.login-page-fullscreen .submit-btn:hover{background:#1ed760}.auth-view{align-items:center;display:flex;justify-content:center;min-height:60vh;padding:2rem}.auth-box{background:#282828;background:var(--bg-card);border:1px solid #404040;border:1px solid var(--border);border-radius:12px;max-width:450px;padding:3rem;text-align:center;width:100%}.auth-icon{align-items:center;background:var(--accent);border-radius:50%;color:#fff;display:flex;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.auth-icon svg{height:40px;width:40px}.auth-box h2{color:var(--text);font-size:2rem;margin-bottom:.5rem}.auth-box p{color:var(--text-muted);font-size:.9rem;margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-muted);display:block;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.form-group input{background:#1a1a1a;background:var(--bg-elevated);border:1px solid #404040;border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:1rem;padding:.75rem 1rem;width:100%}.form-group input:focus{border-color:var(--accent);outline:none}.submit-btn{background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem;transition:all .3s;width:100%}.submit-btn:hover{background:#1ed760;background:var(--primary-hover);transform:translateY(-2px)}.admin-view{padding:2rem}.admin-tabs,.admin-view .page-header{margin-bottom:2rem}.admin-tabs{border-bottom:2px solid #404040;border-bottom:2px solid var(--border);display:flex;gap:1rem}.admin-tabs button{align-items:center;background:#0000;border:none;border-bottom:3px solid #0000;color:var(--text-muted);cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin-bottom:-2px;padding:1rem 2rem;transition:all .3s}.admin-tabs button svg{height:20px;width:20px}.admin-tabs button:hover{background:#1a1a1a;background:var(--bg-elevated);color:var(--text)}.admin-tabs button.active{border-bottom-color:var(--accent);color:var(--accent)}.edit-banner{align-items:center;background:linear-gradient(135deg,#1db954,#1ed760);border-radius:8px;color:#fff;display:flex;font-weight:600;justify-content:space-between;margin-bottom:2rem;padding:1rem 2rem}.edit-banner button{background:#fff;border:none;border-radius:6px;color:#1db954;cursor:pointer;font-weight:600;padding:.5rem 1.5rem;transition:all .3s}.edit-banner button:hover{transform:scale(1.05)}.admin-panels{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.admin-panel{background:#282828;background:var(--bg-card);border:1px solid #404040;border:1px solid var(--border);border-radius:12px;padding:2rem}.admin-panel h3{align-items:center;color:var(--text);display:flex;font-size:1.3rem;gap:.75rem;margin-bottom:1.5rem}.admin-panel h3 svg{color:var(--accent);height:24px;width:24px}.admin-panel form{display:flex;flex-direction:column;gap:1rem}.admin-panel input,.admin-panel select,.admin-panel textarea{background:#1a1a1a;background:var(--bg-elevated);border:1px solid #404040;border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:1rem;padding:.75rem 1rem}.admin-panel textarea{resize:vertical}.admin-panel input:focus,.admin-panel select:focus,.admin-panel textarea:focus{border-color:var(--accent);outline:none}.admin-panel button{background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem;transition:all .3s}.admin-panel button:hover{background:#1ed760;background:var(--primary-hover);transform:translateY(-2px)}.btn-cancel-edit{background:#0000!important;border:1px solid #404040!important;border:1px solid var(--border)!important;color:var(--text)!important}.btn-cancel-edit:hover{background:#1a1a1a!important;background:var(--bg-elevated)!important;transform:none!important}.edit-form-container{margin:0 auto;max-width:800px}.edit-form-header{align-items:center;border-bottom:2px solid #404040;border-bottom:2px solid var(--border);display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.edit-form-header h2{align-items:center;color:var(--text);display:flex;font-size:2rem;gap:.75rem}.edit-form-header h2 svg{color:var(--accent);height:32px;width:32px}.btn-back{align-items:center;background:#282828;background:var(--bg-card);border:1px solid #404040;border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s}.btn-back svg{height:20px;width:20px}.btn-back:hover{background:#1a1a1a;background:var(--bg-elevated);border-color:var(--accent);color:var(--accent)}.admin-panel-single{background:#282828;background:var(--bg-card);border:1px solid #404040;border:1px solid var(--border);border-radius:12px;padding:2.5rem}.admin-panel-single .form-group{margin-bottom:1.5rem}.admin-panel-single .form-group label{color:var(--text);display:block;font-size:1rem;font-weight:600;margin-bottom:.75rem}.admin-panel-single input,.admin-panel-single select,.admin-panel-single textarea{background:#1a1a1a;background:var(--bg-elevated);border:1px solid #404040;border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:1rem;padding:.875rem 1rem;width:100%}.admin-panel-single textarea{resize:vertical}.admin-panel-single input:focus,.admin-panel-single select:focus,.admin-panel-single textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1db9541a;outline:none}.current-image{border:2px solid #404040;border:2px solid var(--border);border-radius:8px;height:150px;margin-top:.5rem;overflow:hidden;width:150px}.current-image img{height:100%;object-fit:cover;width:100%}.form-actions{border-top:1px solid #404040;border-top:1px solid var(--border);display:flex;gap:1rem;margin-top:2rem;padding-top:2rem}.btn-submit{background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:1.1rem;font-weight:700;padding:1rem;transition:all .3s}.btn-submit:hover{background:#1ed760;background:var(--primary-hover);box-shadow:0 6px 20px #1db95466;transform:translateY(-2px)}.btn-cancel{border:2px solid #404040;border:2px solid var(--border);font-size:1.1rem;font-weight:700;padding:1rem 2rem}.manage-content{display:flex;flex-direction:column;gap:3rem}.manage-section{background:#282828;background:var(--bg-card);border:1px solid #404040;border:1px solid var(--border);border-radius:12px;padding:2rem}.manage-header{border-bottom:2px solid #404040;border-bottom:2px solid var(--border);margin-bottom:2rem;padding-bottom:1rem}.manage-header h2{align-items:center;color:var(--text);display:flex;font-size:1.8rem;gap:.75rem}.manage-header h2 svg{color:var(--accent);height:32px;width:32px}.manage-list-view{display:flex;flex-direction:column;gap:1rem}.manage-list-row{align-items:center;background:#1a1a1a;background:var(--bg-elevated);border:1px solid #404040;border:1px solid var(--border);border-radius:12px;display:flex;justify-content:space-between;padding:1rem 1.5rem;transition:all .3s}.manage-list-row:hover{border-color:var(--accent);box-shadow:0 4px 12px #1db95426;transform:translateX(5px)}.manage-row-left{align-items:center;display:flex;flex:1 1;gap:1.5rem;min-width:0}.manage-avatar{border:2px solid #404040;border:2px solid var(--border);border-radius:50%;flex-shrink:0;height:60px;overflow:hidden;width:60px}.manage-avatar img{height:100%;object-fit:cover;width:100%}.avatar-placeholder{align-items:center;background:linear-gradient(135deg,#1db954,#1ed760);color:#ffffff80;display:flex;height:100%;justify-content:center;width:100%}.avatar-placeholder svg{height:30px;width:30px}.manage-row-info{flex:1 1;min-width:0}.manage-row-info h4{color:var(--text);font-size:1.1rem;margin-bottom:.25rem}.manage-row-info h4,.manage-row-info p{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.manage-row-info p{color:var(--text-muted);font-size:.9rem}.manage-row-actions{display:flex;flex-shrink:0;gap:.75rem}.btn-delete,.btn-edit{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:all .3s;white-space:nowrap}.btn-delete svg,.btn-edit svg{height:18px;width:18px}.btn-edit{background:var(--accent);color:#fff}.btn-edit:hover{background:#1ed760;background:var(--primary-hover);box-shadow:0 4px 12px #1db95466;transform:translateY(-2px)}.btn-delete{background:#f44;color:#fff}.btn-delete:hover{background:red;box-shadow:0 4px 12px #f446;transform:translateY(-2px)}.file-input-wrapper{margin:.5rem 0;position:relative}.file-label{align-items:center;background:#1a1a1a;background:var(--bg-elevated);border:2px dashed #404040;border:2px dashed var(--border);border-radius:8px;color:var(--text-muted);cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:.75rem;padding:1rem;transition:all .3s}.file-label,.file-label span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-label span{flex:1 1}.file-label:hover{background:#282828;background:var(--bg-card);border-color:var(--accent);color:var(--accent)}.file-label svg{height:24px;width:24px}.file-input{height:0;opacity:0;position:absolute;width:0}.file-input:focus+.file-label{border-color:var(--accent);box-shadow:0 0 0 3px #1db9541a}.file-input-wrapper:has(input[type=file]:not(:placeholder-shown)) .file-label{background:#1db9541a;border-color:var(--accent);color:var(--accent)}.modal-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;display:flex;inset:0;justify-content:center;position:fixed;z-index:2000}.modal-content{animation:slideUp .3s ease-out;background:#282828;background:var(--bg-card);border:1px solid #404040;border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px #00000080;max-width:500px;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #404040;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:1.5rem 2rem}.modal-header h2{color:var(--text);font-size:1.5rem;font-weight:700}.modal-close{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--text-muted);cursor:pointer;display:flex;font-size:2rem;height:40px;justify-content:center;line-height:1;transition:all .3s;width:40px}.modal-close:hover{background:#1a1a1a;background:var(--bg-elevated);color:var(--text)}.modal-body{padding:2rem}.modal-body .form-group{margin-bottom:0}.modal-body .form-group label{color:var(--text);display:block;font-size:1rem;font-weight:600;margin-bottom:.75rem}.modal-body .form-group input{background:#1a1a1a;background:var(--bg-elevated);border:2px solid #404040;border:2px solid var(--border);border-radius:8px;color:var(--text);font-size:1rem;padding:.875rem 1rem;transition:all .3s;width:100%}.modal-body .form-group input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1db9541a;outline:none}.modal-footer{border-top:1px solid #404040;border-top:1px solid var(--border);display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem 2rem}.btn-cancel{background:#0000;border:1px solid #404040;border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s}.btn-cancel:hover{background:#1a1a1a;background:var(--bg-elevated);border-color:var(--text-muted)}.btn-create{align-items:center;background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s}.btn-create svg{height:20px;width:20px}.btn-create:hover{background:#1ed760;background:var(--primary-hover);box-shadow:0 4px 12px #1db95466;transform:translateY(-2px)}.player{grid-gap:2rem;align-items:center;background:#1a1a1a;background:var(--bg-elevated);border-top:1px solid #404040;border-top:1px solid var(--border);bottom:0;display:grid;gap:2rem;grid-template-columns:1fr 2fr 1fr;height:90px;left:0;padding:0 1.5rem;position:fixed;right:0;z-index:1001}.player-left{align-items:center;display:flex;gap:1rem}.player-thumbnail{border-radius:8px;flex-shrink:0;height:60px;overflow:hidden;width:60px}.player-thumbnail img{height:100%;object-fit:cover;width:100%}.player-thumbnail-placeholder{align-items:center;background:linear-gradient(135deg,#1db954,#1ed760);color:#ffffff80;display:flex;height:100%;justify-content:center;width:100%}.player-thumbnail-placeholder svg{height:30px;width:30px}.player-info h4{color:var(--text);font-size:.95rem;margin-bottom:.25rem}.player-info p{color:var(--text-muted);font-size:.85rem}.player-favorite{align-items:center;background:#0000;border:none;color:var(--text-muted);cursor:pointer;display:flex;font-size:1.3rem;justify-content:center;margin-left:.5rem;transition:transform .3s}.player-favorite svg{height:22px;width:22px}.player-favorite:hover{color:var(--accent);transform:scale(1.2)}.player-center{display:flex;flex-direction:column;gap:.75rem}.player-buttons{gap:1rem}.player-buttons,.player-buttons button{align-items:center;display:flex;justify-content:center}.player-buttons button{background:#0000;border:none;color:var(--text-muted);cursor:pointer;font-size:1.2rem;padding:.5rem;transition:all .3s}.player-buttons button svg{height:20px;width:20px}.player-buttons button:hover{color:var(--text);transform:scale(1.1)}.play-main{align-items:center;background:#fff;border-radius:50%;color:#000;display:flex;font-size:1rem;height:40px;justify-content:center;width:40px}.play-main svg{height:18px;width:18px}.play-main:hover{transform:scale(1.1)}.player-progress{align-items:center;display:flex;gap:.75rem}.player-progress span{color:var(--text-muted);font-size:.75rem;min-width:40px}.progress-bar{appearance:none;background:#404040;background:var(--border);border-radius:2px;cursor:pointer;flex:1 1;height:4px;outline:none}.progress-bar::-webkit-slider-thumb{appearance:none;background:#fff;border-radius:50%;cursor:pointer;height:12px;width:12px}.progress-bar::-moz-range-thumb{background:#fff;border:none;border-radius:50%;cursor:pointer;height:12px;width:12px}.player-right{align-items:center;display:flex;gap:1rem;justify-content:flex-end}.player-right button{align-items:center;background:#0000;border:none;color:var(--text-muted);cursor:pointer;display:flex;font-size:1.2rem;justify-content:center;transition:all .3s}.player-right button svg{height:20px;width:20px}.player-right button:hover{color:var(--text)}.volume-control{align-items:center;display:flex;gap:.5rem}.volume-bar{appearance:none;background:#404040;background:var(--border);border-radius:2px;cursor:pointer;height:4px;outline:none;width:100px}.volume-bar::-webkit-slider-thumb{appearance:none;background:#fff;border-radius:50%;cursor:pointer;height:12px;width:12px}.volume-bar::-moz-range-thumb{background:#fff;border:none;border-radius:50%;cursor:pointer;height:12px;width:12px}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:#404040;background:var(--border);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width:1024px){.sidebar{width:240px}.hero-content h1{font-size:3.5rem}.artist-detail-info h1,.browse-hero-content h1{font-size:3rem}}@media (max-width:768px){.app{flex-direction:column}.sidebar{border-bottom:1px solid #404040;border-bottom:1px solid var(--border);border-right:none;height:auto;overflow-y:visible;padding:1rem;width:100%}.sidebar-header{padding:0}.logo-text{font-size:1.25rem}.search-sidebar,.sidebar-footer,.sidebar-nav,.sidebar-section{display:none}.main-container{padding-bottom:90px}.top-navbar{flex-direction:column;gap:1rem;padding:1rem}.nav-tabs{flex-wrap:wrap;gap:.5rem;justify-content:center;width:100%}.nav-tabs button{font-size:.9rem;padding:.5rem 1rem}.user-section{justify-content:center;position:static;width:100%}.content-area{padding-bottom:0}.home-view,.page-view{padding:1rem}.page-header h1,.page-view h1{font-size:2rem}.hero-section{height:300px;padding:2rem}.hero-content h1{font-size:2.5rem}.hero-content p{font-size:1.1rem}.hero-buttons{flex-direction:column;gap:1rem}.hero-btn{justify-content:center;width:100%}.about-section{padding:2rem 0}.about-text h2{font-size:2rem}.about-text p{font-size:1rem}.about-features{grid-template-columns:1fr}.stats-section{gap:1rem;grid-template-columns:repeat(2,1fr);margin:2rem 0}.stat-card{padding:1.5rem 1rem}.stat-card h3{font-size:2rem}.cta-section{margin:2rem 0;padding:2.5rem 1.5rem}.cta-content h2{font-size:2rem}.cta-content p{font-size:1.1rem}.artist-grid,.music-grid{gap:1rem;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.browse-categories-grid{grid-template-columns:1fr}.browse-category-card.featured{grid-column:span 1}.browse-hero{height:200px}.browse-hero-content h1{font-size:2.5rem}.browse-hero-content p{font-size:1.1rem}.section-header h2{font-size:1.5rem}.song-row-new{gap:.75rem;grid-template-columns:40px 1fr 40px;padding:.75rem 1rem}.row-album{display:none}.song-actions{gap:.25rem}.song-menu-dropdown{display:none}.artist-detail-hero{align-items:center;flex-direction:column;gap:2rem;padding:2rem;text-align:center}.artist-detail-image{height:180px;width:180px}.artist-detail-info h1{font-size:2.5rem}.artist-bio{font-size:1rem}.footer-main{align-items:flex-start;flex-direction:column;gap:2rem}.footer-nav{width:100%}.footer-nav button{flex:1 1;min-width:0}.admin-tabs{flex-wrap:nowrap;overflow-x:auto}.admin-tabs button{padding:.75rem 1.5rem;white-space:nowrap}.admin-panels{grid-template-columns:1fr}.manage-list-row{align-items:flex-start;flex-direction:column;gap:1rem}.manage-row-actions{justify-content:stretch;width:100%}.btn-delete,.btn-edit{flex:1 1}.player{gap:1rem;grid-template-columns:1fr;height:auto;padding:1rem}.player-center,.player-left{width:100%}.player-right{display:none}.toast{left:1rem;min-width:auto;right:1rem;top:1rem}}@media (max-width:480px){.hero-content h1{font-size:2rem}.hero-content p{font-size:1rem}.about-text h2,.cta-content h2{font-size:1.5rem}.cta-content p{font-size:1rem}.artist-grid,.music-grid{gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.stats-section{grid-template-columns:1fr}.page-header h1,.page-view h1{font-size:1.75rem}.section-header h2{font-size:1.25rem}.song-row-new{gap:.5rem;grid-template-columns:35px 1fr 35px;padding:.5rem .75rem}.song-row-cover{height:35px;width:35px}.row-info h4{font-size:.9rem}.row-info p{font-size:.8rem}.artist-detail-info h1,.browse-hero-content h1{font-size:2rem}.footer-nav{flex-direction:column}.footer-nav button{width:100%}}.toast{align-items:center;animation:slideInRight .3s ease-out;background:#282828;background:var(--bg-card);border:1px solid #404040;border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 24px #0006;display:flex;gap:1rem;max-width:500px;min-width:300px;padding:1rem 1.5rem;position:fixed;right:2rem;top:2rem;z-index:10000}@keyframes slideInRight{0%{opacity:0;transform:translateX(400px)}to{opacity:1;transform:translateX(0)}}.toast-icon{align-items:center;display:flex;flex-shrink:0;height:24px;justify-content:center;width:24px}.toast-icon svg{height:20px;width:20px}.toast span{color:var(--text);font-size:.95rem;font-weight:500}.toast-success{border-left:4px solid #1db954}.toast-success .toast-icon{color:#1db954}.toast-error{border-left:4px solid #f44}.toast-error .toast-icon{color:#f44}.toast-warning{border-left:4px solid orange}.toast-warning .toast-icon{color:orange}.toast-info{border-left:4px solid #3b82f6}.toast-info .toast-icon{color:#3b82f6}.confirm-dialog{animation:slideUp .3s ease-out;background:#282828;background:var(--bg-card);border:1px solid #404040;border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px #00000080;max-width:400px;padding:2rem;text-align:center;width:90%}.confirm-icon{align-items:center;background:linear-gradient(135deg,orange,#ff8c00);border-radius:50%;color:#fff;display:flex;height:60px;justify-content:center;margin:0 auto 1.5rem;width:60px}.confirm-icon svg{height:30px;width:30px}.confirm-dialog h3{color:var(--text);font-size:1.5rem;font-weight:700;margin-bottom:1rem}.confirm-dialog p{color:var(--text-muted);font-size:1rem;line-height:1.6;margin-bottom:2rem}.confirm-actions{display:flex;gap:1rem;justify-content:center}.confirm-actions .btn-cancel{background:#0000;border:2px solid #404040;border:2px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:.875rem 1.5rem;transition:all .3s}.confirm-actions .btn-cancel:hover{background:#1a1a1a;background:var(--bg-elevated);border-color:var(--text-muted)}.confirm-actions .btn-confirm{background:#f44;border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:.875rem 1.5rem;transition:all .3s}.confirm-actions .btn-confirm:hover{background:red;box-shadow:0 4px 12px #f446;transform:translateY(-2px)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.artist-card-new,.music-card{animation:fadeInUp .5s ease-out forwards}.settings-view{margin:0 auto;max-width:1000px}.settings-section{margin-bottom:3rem}.settings-section h2{align-items:center;color:var(--text);display:flex;font-size:1.8rem;font-weight:700;gap:.75rem;margin-bottom:1.5rem}.settings-section h2 svg{color:var(--accent);height:28px;width:28px}.settings-panel{background:#282828;background:var(--bg-card);border:1px solid #404040;border:1px solid var(--border);border-radius:12px;padding:2rem}.settings-panel .form-group{margin-bottom:1.5rem}.settings-panel .form-group:last-of-type{margin-bottom:2rem}.settings-panel .form-group label{color:var(--text);display:block;font-size:1rem;font-weight:600;margin-bottom:.75rem}.settings-panel input{background:#1a1a1a;background:var(--bg-elevated);border:1px solid #404040;border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:1rem;padding:.875rem 1rem;width:100%}.settings-panel input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1db9541a;outline:none}.info-row{align-items:center;border-bottom:1px solid #404040;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:1rem 0}.info-row:last-child{border-bottom:none}.info-label{color:var(--text-muted);font-size:1rem;font-weight:600}.info-value{color:var(--text);font-size:1rem;font-weight:500}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-item{align-items:center;background:#1a1a1a;background:var(--bg-elevated);border:1px solid #404040;border:1px solid var(--border);border-radius:8px;display:flex;gap:1rem;padding:1.5rem;transition:all .3s}.stat-item:hover{border-color:var(--accent);transform:translateY(-3px)}.stat-icon{align-items:center;background:linear-gradient(135deg,#1db954,#1ed760);border-radius:50%;color:#fff;display:flex;flex-shrink:0;height:50px;justify-content:center;width:50px}.stat-icon svg{height:24px;width:24px}.stat-info{display:flex;flex-direction:column}.stat-number{color:var(--text);font-size:2rem;font-weight:800;line-height:1;margin-bottom:.25rem}.stat-label{color:var(--text-muted);font-size:.9rem;font-weight:500}.btn-edit-account{align-items:center;background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;margin-top:1.5rem;padding:.875rem 1.5rem;transition:all .3s;width:100%}.btn-edit-account svg{height:20px;width:20px}.btn-edit-account:hover{background:#1ed760;background:var(--primary-hover);box-shadow:0 6px 20px #1db95466;transform:translateY(-2px)}.settings-panel .form-actions{display:flex;gap:1rem;margin-top:2rem}.settings-panel .form-actions .btn-submit{flex:1 1}.settings-panel .form-actions .btn-cancel{padding:.875rem 2rem}.player-right button.active-control{color:var(--accent)}.player-right button.active-control:hover{color:#1ed760;color:var(--primary-hover)}.player-close{align-items:center;background:#0000;border:1px solid #404040;border:1px solid var(--border);border-radius:50%;color:var(--text-muted);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .3s;width:32px}.player-close svg{height:18px;width:18px}.player-close:hover{background:#f44;border-color:#f44;color:#fff;transform:scale(1.1)}
/*# sourceMappingURL=main.dfe7b917.css.map*/