:root{--font-main:"Inter", sans-serif;--font-title:"Outfit", sans-serif;--color-green:#1db954;--color-green-hover:#1ed760;--bg-dark-base:#09090b;--bg-dark-sidebar:#121214;--bg-dark-surface:#18181b;--bg-dark-surface-hover:#27272a;--bg-dark-player:#121214;--text-primary:#fff;--text-secondary:#a1a1aa;--text-muted:#71717a;--border-subtle:#ffffff0d;--glass-bg:#18181ba6;--glass-border:#ffffff0a;--glass-blur:24px;--transition-smooth:all .25s cubic-bezier(.4, 0, .2, 1);--transition-fast:all .15s ease}*{box-sizing:border-box;font-family:var(--font-main);-webkit-font-smoothing:antialiased;margin:0;padding:0}body{background-color:var(--bg-dark-base);color:var(--text-primary);-webkit-user-select:none;user-select:none;height:100vh;overflow:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.btn-primary{background-color:var(--color-green);color:#000;font-family:var(--font-title);cursor:pointer;transition:var(--transition-fast);border:none;border-radius:500px;align-items:center;gap:.5rem;padding:.75rem 2rem;font-size:.95rem;font-weight:700;display:inline-flex}.btn-primary:hover{background-color:var(--color-green-hover);transform:scale(1.04)}.btn-primary:active{transform:scale(.98)}.app-container{background-color:var(--bg-dark-base);flex-direction:column;width:100vw;height:100vh;display:flex}.main-layout{flex:1;gap:.5rem;padding:.5rem .5rem 0;display:flex;overflow:hidden}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.4s cubic-bezier(.4,0,.2,1) forwards fadeIn}@keyframes pulse-soft{0%,to{opacity:1}50%{opacity:.6}}.pulse{animation:2s ease-in-out infinite pulse-soft}.glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border)}.sidebar-container{background-color:var(--bg-dark-sidebar);border-radius:8px;flex-direction:column;gap:.5rem;width:280px;height:100%;padding:1.25rem .5rem;display:flex}.brand-logo{cursor:pointer;align-items:center;gap:.5rem;padding:0 1rem 1rem;display:flex}.logo-icon{color:var(--color-green);transition:var(--transition-fast);font-size:2.2rem}.brand-logo:hover .logo-icon{color:var(--color-green-hover);transform:scale(1.05)}.logo-text{font-family:var(--font-title);letter-spacing:-.5px;font-size:1.4rem;font-weight:800}.sidebar-nav{border-bottom:1px solid var(--border-subtle);flex-direction:column;gap:.25rem;padding-bottom:.75rem;display:flex}.nav-item{color:var(--text-secondary);cursor:pointer;text-align:left;width:100%;transition:var(--transition-fast);background:0 0;border:none;border-radius:6px;align-items:center;gap:1.25rem;padding:.75rem 1rem;font-size:.95rem;font-weight:600;display:flex}.nav-item i{text-align:center;width:20px;font-size:1.2rem}.nav-item:hover,.nav-item.active{color:var(--text-primary);background-color:var(--bg-dark-surface-hover)}.library-section{flex-direction:column;flex:1;padding-top:.5rem;display:flex;overflow:hidden}.library-header{color:var(--text-secondary);justify-content:space-between;align-items:center;padding:.5rem 1rem;display:flex}.lib-title{font-size:.95rem;font-weight:700;font-family:var(--font-title);align-items:center;gap:.75rem;display:flex}.add-playlist-btn{color:var(--text-secondary);cursor:pointer;width:28px;height:28px;transition:var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;display:flex}.add-playlist-btn:hover{color:var(--text-primary);background-color:var(--bg-dark-surface-hover)}.playlists-list{flex-direction:column;flex:1;gap:.25rem;margin-top:.5rem;display:flex;overflow-y:auto}.no-playlists{background-color:var(--bg-dark-surface);text-align:center;border:1px solid var(--border-subtle);border-radius:8px;flex-direction:column;gap:1rem;margin:.5rem;padding:1.5rem 1rem;display:flex}.no-playlists p{color:var(--text-secondary);font-size:.85rem;line-height:1.4}.btn-create-first{color:#000;font-family:var(--font-title);cursor:pointer;transition:var(--transition-fast);background-color:#fff;border:none;border-radius:100px;padding:.5rem 1rem;font-size:.85rem;font-weight:700}.btn-create-first:hover{background-color:#f4f4f5;transform:scale(1.02)}.playlist-item{cursor:pointer;width:100%;transition:var(--transition-fast);background:0 0;border:none;border-radius:6px;align-items:center;gap:.75rem;padding:.5rem .75rem;display:flex}.playlist-item:hover,.playlist-item.selected{background-color:var(--bg-dark-surface-hover)}.playlist-icon-box{background-color:var(--bg-dark-surface);width:44px;height:44px;color:var(--text-secondary);border:1px solid var(--border-subtle);border-radius:4px;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.playlist-info{flex-direction:column;align-items:flex-start;display:flex;overflow:hidden}.playlist-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;text-align:left;width:100%;font-size:.9rem;font-weight:600;overflow:hidden}.playlist-meta{color:var(--text-secondary);margin-top:2px;font-size:.75rem}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000bf;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{border-radius:12px;width:100%;max-width:400px;padding:1.5rem;position:relative}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.modal-header h2{font-family:var(--font-title);font-size:1.25rem;font-weight:700}.close-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;font-size:1.2rem}.close-btn:hover{color:var(--text-primary)}.playlist-input{background-color:var(--bg-dark-surface);border:1px solid var(--border-subtle);width:100%;color:var(--text-primary);transition:var(--transition-fast);border-radius:6px;outline:none;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.95rem}.playlist-input:focus{border-color:var(--color-green)}.modal-actions{justify-content:flex-end;align-items:center;gap:1rem;display:flex}.btn-cancel{color:var(--text-secondary);font-family:var(--font-title);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;font-size:.9rem;font-weight:700}.btn-cancel:hover{color:var(--text-primary)}.main-content-container{background-color:var(--bg-dark-base);border-radius:8px;flex-direction:column;flex:1;height:100%;display:flex;overflow-y:auto}.home-view,.search-view,.playlist-view{flex-direction:column;gap:1.5rem;padding:1.5rem;display:flex}.view-header{margin-bottom:.5rem}.welcome-title{font-family:var(--font-title);letter-spacing:-.5px;font-size:2rem;font-weight:800}.featured-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.featured-card{border:1px solid var(--border-subtle);cursor:pointer;transition:var(--transition-fast);background-color:#ffffff08;border-radius:6px;align-items:center;gap:1rem;display:flex;position:relative;overflow:hidden}.featured-card:hover{background-color:#ffffff14}.featured-card img{object-fit:cover;width:80px;height:80px}.card-info{flex-direction:column;flex:1;gap:2px;display:flex}.card-info span{font-size:.9rem;font-weight:600;line-height:1.3}.card-info p{color:var(--text-secondary);font-size:.75rem}.play-hover-btn{background-color:var(--color-green);color:#000;opacity:0;width:40px;height:40px;transition:var(--transition-fast);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.95rem;display:flex;position:absolute;right:1rem;transform:translateY(8px);box-shadow:0 4px 12px #0006}.featured-card:hover .play-hover-btn{opacity:1;transform:translateY(0)}.play-hover-btn:hover{background-color:var(--color-green-hover);transform:scale(1.06)}.section-block{flex-direction:column;gap:1rem;display:flex}.section-title{font-family:var(--font-title);letter-spacing:-.2px;font-size:1.3rem;font-weight:700}.list-tracks-table{flex-direction:column;display:flex}.track-table-row{cursor:pointer;transition:var(--transition-fast);border:1px solid #0000;border-radius:6px;align-items:center;gap:1rem;padding:.5rem 1rem;display:flex}.track-table-row:hover{background-color:#ffffff0d}.track-table-row.active-row{background-color:#1db95414;border-color:#1db95426}.track-table-row.active-row .row-title{color:var(--color-green)}.row-index{color:var(--text-secondary);text-align:center;width:24px;font-size:.9rem}.row-thumb{object-fit:cover;border-radius:4px;width:40px;height:40px}.row-title-box{flex-direction:column;flex:1;display:flex;overflow:hidden}.row-title{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.row-artist{color:var(--text-secondary);margin-top:2px;font-size:.78rem}.row-duration{color:var(--text-secondary);text-align:right;width:40px;font-size:.85rem}.search-bar-container{border:1px solid var(--border-subtle);max-width:450px;transition:var(--transition-fast);background-color:#ffffff08;border-radius:500px;align-items:center;gap:.75rem;padding:.75rem 1.25rem;display:flex}.search-bar-container:focus-within{background-color:#ffffff0d;border-color:#fff3}.search-icon{color:var(--text-secondary);font-size:1.1rem}.search-input{color:#fff;background:0 0;border:none;outline:none;width:100%;font-size:.95rem}.search-loading{color:var(--text-secondary);align-items:center;gap:.75rem;padding:2rem 0;font-size:.95rem;display:flex}.search-explore{margin-top:1rem}.browse-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin-top:1rem;display:grid}.browse-card{height:120px;font-family:var(--font-title);cursor:pointer;transition:var(--transition-fast);border-radius:8px;padding:1rem;font-size:1.3rem;font-weight:800;box-shadow:0 4px 10px #00000026}.browse-card:hover{filter:brightness(1.1);transform:translateY(-4px)}.playlist-header{border-radius:8px 8px 0 0;align-items:flex-end;gap:1.5rem;padding:3rem 1.5rem 1.5rem;display:flex}.custom-playlist-gradient{background:linear-gradient(#535353,#18181b)}.liked-songs-gradient{background:linear-gradient(#2b115b,#18181b)}.playlist-art{background-color:var(--bg-dark-surface);width:160px;height:160px;color:var(--text-secondary);border-radius:8px;justify-content:center;align-items:center;font-size:4rem;display:flex;box-shadow:0 8px 24px #00000080}.liked-art{color:#fff;background:linear-gradient(135deg,#450e71,#c51162)}.playlist-details{flex-direction:column;gap:.5rem;display:flex}.playlist-type{text-transform:uppercase;font-size:.75rem;font-weight:700}.playlist-title{font-family:var(--font-title);letter-spacing:-1.5px;font-size:3rem;font-weight:800;line-height:1}.playlist-desc{color:var(--text-secondary);font-size:.85rem}.playlist-stats{align-items:center;gap:.25rem;font-size:.85rem;font-weight:600;display:flex}.stats-author{color:#fff}.stats-bullet,.stats-count{color:var(--text-secondary)}.playlist-body{padding:1.5rem 0}.playlist-empty-state{text-align:center;color:var(--text-secondary);padding:4rem 1rem}.playlist-empty-state i{margin-bottom:1rem;font-size:3rem}.playlist-empty-state h3{color:#fff;margin-bottom:.5rem;font-size:1.2rem}.row-actions{align-items:center;gap:.75rem;display:flex}.action-btn{color:var(--text-secondary);cursor:pointer;width:32px;height:32px;transition:var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;display:flex}.action-btn:hover{color:var(--text-primary);background-color:#ffffff0d}.heart-btn.liked{color:var(--color-green)}.trash-btn:hover{color:#ef4444}.dropdown-wrapper{position:relative}.playlist-dropdown{z-index:10;border-radius:8px;flex-direction:column;width:200px;padding:.25rem;display:flex;position:absolute;top:100%;right:0;box-shadow:0 8px 24px #0006}.dropdown-title{color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);padding:.5rem .75rem;font-size:.75rem;font-weight:700}.playlist-dropdown button{color:var(--text-primary);text-align:left;cursor:pointer;transition:var(--transition-fast);white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;border-radius:4px;padding:.5rem .75rem;font-size:.85rem;overflow:hidden}.playlist-dropdown button:hover{background-color:#ffffff14}.dropdown-empty{color:var(--text-secondary);text-align:center;padding:.5rem .75rem;font-size:.78rem}.footer-player-container{background-color:var(--bg-dark-player);border-top:1px solid var(--border-subtle);z-index:100;justify-content:space-between;align-items:center;width:100vw;height:90px;padding:0 1.5rem;display:flex}.hidden-iframe{visibility:hidden;opacity:0;width:0;height:0;position:absolute;top:-9999px;left:-9999px}.player-left{align-items:center;gap:1rem;width:30%;min-width:180px;display:flex}.player-thumb{object-fit:cover;border-radius:4px;width:56px;height:56px;box-shadow:0 4px 10px #0000004d}.player-meta-box{flex-direction:column;display:flex;overflow:hidden}.player-title{white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:600;overflow:hidden}.player-artist{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:.75rem;overflow:hidden}.player-like-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;padding:.25rem;font-size:1rem}.player-like-btn:hover{color:var(--text-primary);transform:scale(1.06)}.player-like-btn.liked{color:var(--color-green)}.no-track-loaded{color:var(--text-muted);font-size:.85rem}.player-center{flex-direction:column;align-items:center;gap:.5rem;width:40%;max-width:600px;display:flex}.control-buttons{align-items:center;gap:1.5rem;display:flex}.ctrl-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.05rem;display:flex}.ctrl-btn:hover{color:var(--text-primary)}.ctrl-btn.active{color:var(--color-green)}.play-pause-btn{color:#000;cursor:pointer;width:38px;height:38px;transition:var(--transition-fast);background-color:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.95rem;display:flex;box-shadow:0 2px 8px #0003}.play-pause-btn:hover{background-color:#f4f4f5;transform:scale(1.05)}.play-pause-btn:active{transform:scale(.96)}.progress-bar-wrapper{align-items:center;gap:.5rem;width:100%;display:flex}.time-lbl{color:var(--text-secondary);text-align:center;width:32px;font-size:.72rem}.seek-slider,.volume-slider{appearance:none;background-color:var(--bg-dark-surface-hover);cursor:pointer;width:100%;height:4px;transition:var(--transition-fast);border-radius:2px;outline:none}.seek-slider::-webkit-slider-runnable-track{border-radius:2px;width:100%;height:4px}.volume-slider::-webkit-slider-runnable-track{border-radius:2px;width:100%;height:4px}.seek-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;width:12px;height:12px;transition:var(--transition-fast);opacity:0;background-color:#fff;border-radius:50%;margin-top:-4px}.volume-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;width:12px;height:12px;transition:var(--transition-fast);opacity:0;background-color:#fff;border-radius:50%;margin-top:-4px}.seek-slider:hover::-webkit-slider-thumb{opacity:1}.volume-slider:hover::-webkit-slider-thumb{opacity:1}.seek-slider:hover,.volume-slider:hover{background-color:var(--color-green)}.player-right{justify-content:flex-end;align-items:center;gap:.75rem;width:30%;min-width:140px;display:flex}.volume-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;font-size:1rem}.volume-btn:hover{color:var(--text-primary)}.volume-slider{max-width:120px}
