.app{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:radial-gradient(circle at 16% 18%,rgba(83,230,190,.1),transparent 32%),linear-gradient(135deg,rgba(255,255,255,.018),transparent 42%)}.app-body{display:flex;flex:1;overflow:hidden;padding:12px 12px 0;gap:12px}.sidebar{width:240px;min-width:240px;background:var(--bg-sidebar);border:1px solid var(--border-color);border-radius:22px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);display:flex;flex-direction:column;padding-top:18px;overflow-y:auto;transition:width .2s,min-width .2s;z-index:10}.sidebar.collapsed{width:64px;min-width:64px}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:0 18px;margin-bottom:22px;color:var(--text-primary)}.sidebar.collapsed .sidebar-logo{justify-content:center;padding:0}.sidebar-logo-text{font-size:17px;font-weight:800;letter-spacing:0}.sidebar-logo-mark{width:34px;height:34px;border-radius:10px;box-shadow:0 8px 24px #53e6be29;flex-shrink:0}.sidebar-nav{display:flex;flex-direction:column;gap:6px;padding:0 10px}.sidebar-nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:14px;color:var(--text-secondary);font-size:14px;font-weight:600;transition:color .2s,background .2s,transform .2s}.sidebar.collapsed .sidebar-nav-item{justify-content:center;padding:8px}.sidebar-nav-item:hover{color:var(--text-primary);background:#ffffff0e;transform:translate(2px)}.sidebar-nav-item.active{color:var(--text-primary);background:linear-gradient(135deg,#53e6be2e,#ffffff0f);box-shadow:inset 0 0 0 1px #53e6be38}.sidebar-divider{height:1px;background:var(--border-color);margin:18px}.sidebar-section-title{padding:0 18px;margin-bottom:12px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary)}.sidebar-actions{display:flex;flex-direction:column;gap:2px;padding:0 8px;margin-bottom:16px}.sidebar-action-btn{display:flex;align-items:center;gap:12px;padding:8px 16px;border-radius:4px;color:var(--text-secondary);font-size:14px;font-weight:600;transition:color .2s,background .2s}.sidebar-action-btn:hover{color:var(--text-primary);background:var(--bg-highlight)}.sidebar-create-input{display:flex;gap:8px;padding:0 16px 12px}.sidebar-create-input input{flex:1;padding:6px 10px;border-radius:12px;border:1px solid var(--border-color);background:var(--bg-elevated);color:var(--text-primary);font-size:13px;outline:none}.sidebar-create-input input:focus{border-color:var(--accent)}.sidebar-create-input button{padding:6px 12px;border-radius:12px;background:var(--accent);color:#000;font-size:13px;font-weight:600}.sidebar-empty{padding:8px 16px;font-size:12px;color:var(--text-subdued)}.sidebar-playlists{flex:1;overflow-y:auto;padding:0 10px 12px}.sidebar-playlist-item{display:block;width:100%;text-align:left;padding:9px 12px;font-size:14px;color:var(--text-secondary);border-radius:12px;transition:color .2s,background .2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-playlist-item:hover{color:var(--text-primary);background:var(--bg-highlight)}.sidebar-toggle{position:fixed;top:8px;left:8px;z-index:100;padding:6px;border-radius:12px;color:var(--text-secondary);background:#00000080;display:none;transition:color .2s}.sidebar-toggle:hover{color:var(--text-primary)}.main-content{flex:1;overflow-y:auto;background:radial-gradient(circle at 50% -10%,rgba(83,230,190,.13),transparent 32%),linear-gradient(180deg,#ffffff0e,#ffffff05 320px,#ffffff03);border:1px solid var(--border-color);border-radius:22px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding-bottom:16px}.home-view{padding:0 32px}.hero-section{position:relative;padding:64px 0 48px;overflow:hidden}.hero-title{font-size:48px;font-weight:800;line-height:1.1;letter-spacing:0;background:linear-gradient(135deg,#f6fbf7,#8ff0d2 55%,#53e6be);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{margin-top:16px;font-size:18px;color:var(--text-secondary);font-weight:400}.home-section{margin-top:40px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.section-title{font-size:24px;font-weight:700;letter-spacing:-.02em}.playlist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:24px}.playlist-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;cursor:pointer;transition:background .3s,transform .2s,border-color .2s,box-shadow .2s;padding:16px;box-shadow:0 14px 36px #00000029}.playlist-card:hover{background:var(--bg-card-hover);border-color:#53e6be3d;box-shadow:var(--glow);transform:translateY(-2px)}.playlist-card:hover .playlist-card-overlay{opacity:1;transform:translateY(0)}.playlist-card-cover{position:relative;width:100%;aspect-ratio:1;border-radius:12px;overflow:hidden;box-shadow:0 12px 28px #00000047;margin-bottom:16px}.playlist-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 35%,rgba(5,12,17,.72));display:flex;align-items:flex-end;justify-content:flex-end;padding:12px;opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s}.play-button{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#9df7dc);color:#071016;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 28px #53e6be47;transition:transform .15s,background .15s}.play-button:hover{transform:scale(1.06);background:var(--accent-hover)}.playlist-card-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-card-desc{font-size:13px;color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.search-view{padding:24px 32px}.search-bar{display:flex;align-items:center;gap:12px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:18px;padding:12px 20px;margin-bottom:32px;color:var(--text-secondary);transition:background .2s,outline .2s;outline:1px solid transparent}.search-bar:focus-within{outline:1px solid rgba(83,230,190,.45);background:var(--bg-elevated-hover);color:var(--text-primary)}.search-input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:14px;font-family:inherit}.search-input::placeholder{color:var(--text-secondary)}.search-clear{padding:4px;border-radius:50%;color:var(--text-secondary);transition:color .2s}.search-clear:hover{color:var(--text-primary)}.search-section{margin-bottom:40px}.search-song-list .track-row{padding:8px 12px}.search-empty{text-align:center;padding:48px 0;color:var(--text-secondary);font-size:16px}.search-browse{margin-top:8px}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:24px;margin-top:20px}.category-card{aspect-ratio:1;border-radius:16px;display:flex;align-items:flex-end;padding:16px;cursor:pointer;transition:transform .2s,opacity .2s;position:relative;overflow:hidden}.category-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.4) 100%)}.category-card:hover{transform:scale(1.02)}.category-name{font-size:18px;font-weight:700;position:relative;z-index:1}.library-view{padding:24px 32px}.library-header{display:flex;flex-direction:column;gap:20px;margin-bottom:32px}.library-header-top{display:flex;align-items:center;gap:16px}.import-music-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:20px;font-size:13px;font-weight:500;background:var(--bg-elevated);color:var(--text-secondary);transition:all .2s}.import-music-btn:hover{color:var(--text-primary);background:var(--bg-elevated-hover)}.library-title{font-size:32px;font-weight:700}.library-tabs{display:flex;gap:8px}.library-tab{padding:8px 16px;border-radius:999px;font-size:14px;font-weight:500;background:var(--bg-elevated);color:var(--text-primary);transition:background .2s}.library-tab:hover{background:var(--bg-elevated-hover)}.library-tab.active{background:linear-gradient(135deg,var(--accent),#9df7dc);color:#071016}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:24px}.playlist-detail{padding-bottom:32px}.playlist-detail-hero{position:relative;padding:64px 32px 32px;display:flex;align-items:flex-end;gap:32px;min-height:340px}.playlist-detail-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0003,#0009)}.back-button{position:absolute;top:24px;left:32px;width:32px;height:32px;border-radius:50%;background:#00000080;display:flex;align-items:center;justify-content:center;color:#fff;z-index:2;transition:background .2s,transform .2s}.back-button:hover{background:#000000b3;transform:scale(1.05)}.playlist-cover-edit-btn{position:absolute;bottom:20px;right:20px;width:32px;height:32px;border-radius:50%;background:#00000059;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;color:#fff;z-index:2;transition:background .2s,transform .2s;border:1px solid rgba(255,255,255,.15)}.playlist-cover-edit-btn:hover{background:#0000008c;transform:scale(1.08)}.playlist-cover-editor{position:absolute;bottom:60px;right:20px;background:var(--bg-elevated);border-radius:12px;padding:16px;z-index:3;box-shadow:0 8px 32px #00000080;min-width:240px}.playlist-cover-editor-section{margin-bottom:12px}.playlist-cover-editor-section:last-child{margin-bottom:0}.playlist-cover-editor-label{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.playlist-cover-editor .cover-upload-btn{justify-content:flex-start;width:100%}.playlist-cover-editor .color-picker{display:flex;flex-wrap:wrap;gap:6px}.playlist-detail-info{position:relative;z-index:1}.playlist-detail-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;display:block}.playlist-detail-title{font-size:48px;font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-bottom:16px}.playlist-detail-desc{font-size:14px;color:var(--text-secondary);margin-bottom:8px}.playlist-detail-meta{font-size:14px;color:var(--text-secondary)}.playlist-detail-actions{padding:24px 32px;display:flex;align-items:center;gap:24px}.playlist-play-all{width:56px;height:56px;border-radius:50%;background:var(--accent);color:#000;display:flex;align-items:center;justify-content:center;transition:transform .15s,background .15s}.playlist-play-all:hover{transform:scale(1.06);background:var(--accent-hover)}.playlist-detail-tracks{padding:0 32px}.track-list{margin-top:8px}.track-list-header{display:grid;grid-template-columns:40px 1fr 1fr 1fr 36px 60px 40px;gap:16px;padding:8px 16px;border-bottom:1px solid var(--border-color);font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary)}.track-list-body{margin-top:4px}.track-row{display:grid;grid-template-columns:40px 1fr 1fr 1fr 36px 60px 40px;gap:16px;padding:8px 16px;border-radius:12px;align-items:center;cursor:pointer;transition:background .15s,transform .15s;font-size:14px}.track-row:hover{background:var(--bg-card-hover);transform:translate(2px)}.track-row.active{color:var(--accent)}.track-col-num{text-align:center;color:var(--text-secondary);font-size:14px}.track-row.active .track-col-num{color:var(--accent)}.track-col-title{display:flex;align-items:center;gap:12px;min-width:0}.track-cover-mini{width:40px;height:40px;border-radius:10px;flex-shrink:0}.track-title-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-row.active .track-title-text{color:var(--accent)}.track-col-artist,.track-col-album{color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-col-like{text-align:center}.track-like-btn{display:inline-flex;align-items:center;justify-content:center;padding:4px;color:var(--text-secondary);transition:color .2s,transform .15s}.track-like-btn:hover{transform:scale(1.2)}.track-like-btn.liked{color:#ec4141}.track-like-btn.liked:hover{color:#d03030}.track-col-duration{color:var(--text-secondary);text-align:right}.equalizer{display:inline-flex;align-items:center;gap:2px;height:16px}.equalizer span{width:3px;background:var(--accent);border-radius:2px;animation:equalize .8s infinite ease-in-out}.equalizer span:nth-child(1){height:8px;animation-delay:0s}.equalizer span:nth-child(2){height:14px;animation-delay:.15s}.equalizer span:nth-child(3){height:6px;animation-delay:.3s}@keyframes equalize{0%,to{transform:scaleY(1)}50%{transform:scaleY(.5)}}.player-bar{display:grid;grid-template-columns:1fr 2fr 1fr;align-items:center;margin:0 12px 12px;padding:10px 18px;background:var(--bg-player);border:1px solid var(--border-color);border-radius:22px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);height:78px;min-height:78px;z-index:20}.player-left{display:flex;align-items:center;min-width:0}.player-current-song{display:flex;align-items:center;gap:8px;min-width:0}.player-current-song-clickable{display:flex;align-items:center;gap:12px;min-width:0;cursor:pointer}.player-cover{width:48px;height:48px;border-radius:12px;flex-shrink:0;box-shadow:0 10px 28px #00000038}.player-cover-empty{background:var(--bg-elevated);display:flex;align-items:center;justify-content:center}.player-song-info{min-width:0}.player-song-title{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-song-artist{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-muted{color:var(--text-subdued)}.player-center{display:flex;flex-direction:column;align-items:center;gap:8px;max-width:600px;margin:0 auto;width:100%}.player-controls{display:flex;align-items:center;gap:14px}.player-control-btn{display:flex;align-items:center;justify-content:center;color:var(--text-secondary);width:30px;height:30px;border-radius:50%;transition:color .2s,background .2s,transform .2s;position:relative}.player-control-btn:hover{color:var(--text-primary);background:var(--bg-highlight);transform:translateY(-1px)}.player-control-btn.active{color:var(--accent)}.player-play-btn{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#9df7dc);color:#071016;display:flex;align-items:center;justify-content:center;transition:transform .15s,background .15s}.player-play-btn:hover{transform:scale(1.05);background:var(--accent-hover);box-shadow:var(--glow)}.player-progress{display:flex;align-items:center;gap:8px;width:100%}.player-time{font-size:11px;color:var(--text-secondary);min-width:40px;text-align:center;font-variant-numeric:tabular-nums}.progress-bar{flex:1;height:16px;display:flex;align-items:center;cursor:pointer;position:relative}.progress-track{width:100%;height:5px;background:#ffffff1f;border-radius:999px;position:relative;overflow:visible}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#9df7dc);border-radius:999px;position:relative;transition:background .1s}.progress-bar:hover .progress-fill{background:linear-gradient(90deg,var(--accent),var(--accent-hover))}.progress-thumb{position:absolute;top:50%;width:12px;height:12px;background:var(--accent-hover);border-radius:50%;transform:translate(-50%,-50%) scale(0);transition:transform .1s;pointer-events:none}.progress-bar:hover .progress-thumb{transform:translate(-50%,-50%) scale(1)}.player-right{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding-right:8px}.volume-icon{color:var(--text-secondary);flex-shrink:0}.volume-bar{width:100px;height:16px;display:flex;align-items:center;cursor:pointer}.volume-bar .progress-track{height:4px}.volume-bar .progress-fill{background:var(--text-primary)}.volume-bar:hover .progress-fill{background:var(--accent)}.volume-bar:hover .progress-thumb{transform:translate(-50%,-50%) scale(1)}.home-empty{display:flex;justify-content:center;padding:80px 0}.empty-state{text-align:center;max-width:400px}.empty-icon{color:var(--text-subdued);margin-bottom:24px;opacity:.5}.empty-title{font-size:28px;font-weight:700;margin-bottom:12px}.empty-desc{font-size:16px;color:var(--text-secondary);line-height:1.6}.history-view{padding-top:8px}.history-group{margin-bottom:32px}.history-group-title{font-size:20px;font-weight:700;margin-bottom:12px;color:var(--text-primary)}.library-empty{text-align:center;padding:64px 0;color:var(--text-secondary);font-size:15px}.create-playlist-btn{display:flex;align-items:center;gap:12px;padding:12px 20px;border-radius:8px;background:var(--bg-card);color:var(--text-primary);font-size:15px;font-weight:600;margin-bottom:16px;transition:background .2s;width:100%}.create-playlist-btn:hover{background:var(--bg-card-hover)}.create-playlist-input{display:flex;gap:8px;align-items:center;margin-bottom:16px;padding:8px 12px;background:var(--bg-card);border-radius:8px}.create-playlist-input input{flex:1;padding:8px 12px;border-radius:4px;border:1px solid var(--border-color);background:var(--bg-elevated);color:var(--text-primary);font-size:14px;outline:none}.create-playlist-input input:focus{border-color:var(--accent)}.create-confirm{padding:8px 16px;border-radius:4px;background:var(--accent);color:#000;font-weight:600;font-size:13px}.create-cancel{padding:8px 16px;border-radius:4px;color:var(--text-secondary);font-size:13px}.create-cancel:hover{color:var(--text-primary)}.playlist-rename{display:flex;gap:8px;align-items:center;margin-bottom:16px}.playlist-rename input{padding:8px 12px;border-radius:4px;border:1px solid var(--border-color);background:#0000004d;color:#fff;font-size:24px;font-weight:700;outline:none;min-width:200px}.playlist-rename input:focus{border-color:var(--accent)}.playlist-rename button{padding:8px 16px;border-radius:4px;font-weight:600;font-size:13px}.playlist-rename button:first-of-type{background:var(--accent);color:#000}.playlist-rename button:last-of-type{color:var(--text-secondary)}.playlist-action-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:4px;color:var(--text-secondary);font-size:14px;font-weight:500;transition:color .2s,background .2s}.playlist-action-btn:hover{color:var(--text-primary);background:#ffffff0d}.playlist-action-btn.danger:hover{color:#e74c3c}.add-songs-panel{margin:0 32px 16px;padding:16px;background:var(--bg-card);border-radius:8px}.add-songs-panel h3{font-size:16px;font-weight:700;margin-bottom:12px}.add-songs-list{max-height:300px;overflow-y:auto}.add-songs-list .track-row{padding:6px 8px;border-radius:4px}.add-songs-list .track-col-num{color:var(--accent)}.track-list-empty{text-align:center;padding:32px 0;color:var(--text-secondary);font-size:14px}.track-col-action{text-align:center;min-width:40px}.track-list-header .track-col-action,.track-row .track-col-action{display:inline-flex;align-items:center;justify-content:center;gap:6px}.row-action-btn{display:inline-flex;align-items:center;justify-content:center;padding:4px;border-radius:4px;color:var(--text-secondary);opacity:0;transition:opacity .2s,color .2s}.track-row:hover .row-action-btn{opacity:1}.row-action-btn:hover{color:#e74c3c}.search-hint{margin-top:16px;font-size:16px;color:var(--text-secondary)}.hot-search-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.hot-search-tag{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:20px;background:var(--card-bg);color:var(--text-primary);font-size:14px;cursor:pointer;transition:background .2s,transform .2s}.hot-search-tag:hover{background:var(--hover-bg);transform:scale(1.03)}.hot-search-rank{font-size:12px;font-weight:700;color:var(--text-secondary);min-width:16px}.hot-search-tag:nth-child(-n+3) .hot-search-rank{color:#ec4141}.hot-search-content{font-size:11px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;animation:fadeIn .15s ease}.modal-content{background:var(--bg-elevated);border-radius:12px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 16px 48px #00000080;animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}.modal-title{font-size:22px;font-weight:700}.modal-close{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:background .2s,color .2s}.modal-close:hover{background:var(--bg-card-hover);color:var(--text-primary)}.modal-form{padding:20px 24px 24px}.modal-form-row{display:flex;gap:20px;margin-bottom:20px}.modal-cover-section{display:flex;flex-direction:column;align-items:center;gap:8px;flex-shrink:0}.modal-cover-preview{width:140px;height:140px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000004d;position:relative;overflow:hidden}.cover-upload-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;background:var(--bg-card);color:var(--text-secondary);font-size:12px;font-weight:500;transition:background .2s,color .2s;width:100%;justify-content:center}.cover-upload-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.cover-remove-btn{position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:50%;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.modal-cover-preview:hover .cover-remove-btn{opacity:1}.modal-cover-icon{opacity:.6}.modal-form-fields{flex:1;display:flex;flex-direction:column;gap:16px}.modal-field{display:flex;flex-direction:column;gap:6px}.modal-label{font-size:13px;font-weight:600;color:var(--text-secondary)}.modal-input{padding:10px 14px;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}.modal-input:focus{border-color:var(--accent)}.modal-input::placeholder{color:var(--text-subdued)}.modal-textarea{padding:10px 14px;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);font-size:14px;font-family:inherit;outline:none;resize:vertical;min-height:72px;transition:border-color .2s}.modal-textarea:focus{border-color:var(--accent)}.modal-textarea::placeholder{color:var(--text-subdued)}.modal-error{font-size:12px;color:#e74c3c}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:16px;border-top:1px solid var(--border-color)}.modal-btn-secondary{padding:10px 24px;border-radius:6px;font-size:14px;font-weight:600;color:var(--text-primary);background:var(--bg-card);transition:background .2s}.modal-btn-secondary:hover{background:var(--bg-card-hover)}.modal-btn-primary{padding:10px 24px;border-radius:6px;font-size:14px;font-weight:600;background:var(--accent);color:#000;transition:background .2s,transform .15s}.modal-btn-primary:hover{background:var(--accent-hover);transform:scale(1.02)}.color-picker{display:flex;flex-wrap:wrap;gap:8px}.color-swatch{width:32px;height:32px;border-radius:50%;border:2px solid transparent;transition:border-color .2s,transform .15s;cursor:pointer}.color-swatch:hover{transform:scale(1.15)}.color-swatch.active{border-color:var(--text-primary);transform:scale(1.15)}.nowplaying-active .app-body{position:relative}.nowplaying-main{padding:0!important;background:transparent!important}.nowplaying-view{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.nowplaying-view-bg{position:absolute;top:0;right:0;bottom:0;left:0;filter:blur(60px) brightness(.4);transform:scale(1.2);z-index:0}.nowplaying-view-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.3) 100%);z-index:1}.nowplaying-view-back{position:absolute;top:24px;left:24px;z-index:10;width:36px;height:36px;border-radius:50%;background:#0006;display:flex;align-items:center;justify-content:center;color:#fffc;transition:background .2s,transform .2s}.nowplaying-view-back:hover{background:#0009;transform:scale(1.05)}.nowplaying-view-inner{position:relative;z-index:2;display:flex;align-items:center;gap:64px;max-width:900px;width:100%;padding:40px}.nowplaying-view-left{flex-shrink:0}.nowplaying-view-cover{position:relative;width:320px;height:320px}.nowplaying-view-cover-art{width:100%;height:100%;border-radius:12px;box-shadow:0 12px 48px #0009;position:relative;z-index:2}.nowplaying-view-cover-ring{position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:20px;border:1px solid rgba(255,255,255,.08);z-index:1}.nowplaying-view-right{flex:1;min-width:0;min-height:0;overflow:hidden;display:flex;flex-direction:column;gap:20px}.nowplaying-view-text{min-width:0}.nowplaying-view-title-row{display:flex;align-items:center;gap:16px}.nowplaying-view-title{font-size:36px;font-weight:800;letter-spacing:-.02em;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 2px 8px rgba(0,0,0,.3)}.nowplaying-view-artist{font-size:18px;color:#fffc;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 4px rgba(0,0,0,.2)}.artist-link-btn{padding:0;border:none;background:transparent;color:inherit;font:inherit;cursor:pointer;text-align:inherit}.artist-link-btn:hover{color:#fff;text-decoration:underline;text-underline-offset:3px}.artist-link-btn:disabled{cursor:default;text-decoration:none}.artist-link-separator{color:#ffffff73}.nowplaying-view-album{font-size:14px;color:#ffffff80;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nowplaying-view-progress-section{display:flex;flex-direction:column;gap:6px}.nowplaying-view-progress{width:100%;height:20px;display:flex;align-items:center;cursor:pointer}.nowplaying-view-time{display:flex;justify-content:space-between;font-size:12px;color:#fff9;font-variant-numeric:tabular-nums}.nowplaying-view-controls{display:flex;align-items:center;gap:20px}.nowplaying-view-btn{display:flex;align-items:center;justify-content:center;color:#ffffffb3;transition:color .2s;position:relative}.nowplaying-view-btn:hover{color:#fff}.nowplaying-view-btn.active{color:var(--accent)}.nowplaying-view-play{width:52px;height:52px;border-radius:50%;background:#ffffffe6;color:#000;display:flex;align-items:center;justify-content:center;transition:transform .15s,background .15s}.nowplaying-view-play:hover{transform:scale(1.05);background:#fff}.nowplaying-volume-section{display:flex;align-items:center;gap:8px;max-width:200px}.np-volume-icon{color:#fff9;flex-shrink:0}.np-volume-bar{flex:1;height:16px;display:flex;align-items:center;cursor:pointer}.nowplaying-view-meta{display:flex;flex-direction:column;gap:8px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.np-meta-item{display:flex;justify-content:space-between;align-items:center}.np-meta-label{font-size:13px;color:#ffffff80}.np-meta-value{font-size:13px;font-weight:500;color:#fffc;text-align:right;max-width:60%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nowplaying-none{color:var(--text-secondary);font-size:16px}.clickable{cursor:pointer}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.skeleton-loading-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:24px;padding-top:8px}@media(max-width:1024px){.playlist-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.hero-title{font-size:36px}.nowplaying-view-inner{flex-direction:column;gap:32px;padding:24px}.nowplaying-view-cover{width:240px;height:240px}.nowplaying-view-title{font-size:28px}.download-hero,.download-platform-grid{grid-template-columns:1fr}.download-hero-copy{min-height:auto}.download-note-panel{align-items:flex-start;flex-direction:column}.download-note-steps{justify-content:flex-start}}@media(max-width:768px){.sidebar{width:64px;min-width:64px}.sidebar .sidebar-logo{justify-content:center;padding:0}.sidebar .sidebar-logo-text,.sidebar .sidebar-divider,.sidebar .sidebar-section-title,.sidebar .sidebar-playlists{display:none}.sidebar .sidebar-nav-item{justify-content:center;padding:8px}.sidebar-toggle{display:flex}.home-view,.search-view,.library-view,.download-view{padding:0 16px}.download-hero-copy,.download-version-panel,.download-platform-card,.download-note-panel{border-radius:18px}.download-hero-copy{padding:28px 22px}.download-title{font-size:32px}.download-subtitle{font-size:15px}.download-platform-header{grid-template-columns:46px 1fr}.download-platform-badge{grid-column:2;width:fit-content}.playlist-detail-hero{flex-direction:column;padding:48px 16px 24px;min-height:auto}.playlist-detail-title{font-size:32px}.playlist-detail-tracks,.playlist-detail-actions{padding:0 16px}.player-bar{grid-template-columns:1fr 1fr;height:auto;padding:8px 12px;gap:8px}.player-left{grid-column:1}.player-center{grid-column:1 / -1;order:-1}.player-right{grid-column:2}.player-progress{max-width:100%}.track-list-header,.track-row{grid-template-columns:40px 2fr 1fr 36px 60px 40px}.track-col-album{display:none}.volume-bar{width:60px}.hero-title{font-size:28px}}@media(max-width:480px){.player-right .volume-bar{display:none}.track-list-header,.track-row{grid-template-columns:36px 2fr 36px 60px 36px}.track-col-artist{display:none}.download-primary-btn,.download-secondary-btn{width:100%}.download-version-number{font-size:32px}}.like-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;transition:transform .15s,opacity .15s;opacity:.6;padding:0}.like-btn:hover{opacity:1;transform:scale(1.1)}.like-btn.liked{opacity:1;color:var(--accent)}.player-like-btn{flex-shrink:0}.nowplaying-view-top-bar{position:absolute;top:24px;left:24px;right:24px;z-index:10;display:flex;justify-content:space-between;align-items:center}.nowplaying-view-top-actions{display:flex;align-items:center;gap:8px}.nowplaying-lyrics-edit-btn{width:36px;height:36px;border-radius:50%;background:#0006;display:flex;align-items:center;justify-content:center;color:#fff9;transition:background .2s,color .2s,transform .2s}.nowplaying-lyrics-edit-btn:hover{background:#0009;color:#fff;transform:scale(1.05)}.nowplaying-lyrics-toggle{width:36px;height:36px;border-radius:50%;background:#0006;display:flex;align-items:center;justify-content:center;color:#fff9;transition:background .2s,color .2s,transform .2s}.nowplaying-lyrics-toggle:hover{background:#0009;color:#fff;transform:scale(1.05)}.nowplaying-lyrics-toggle.active{color:var(--accent)}.np-lyrics-section{flex:1;display:flex;flex-direction:column;gap:12px;min-height:0}.nowplaying-view-text-compact{flex-shrink:0}.nowplaying-view-title-small{font-size:22px}.nowplaying-view-artist-small{font-size:14px}.np-lyrics-container{position:relative;flex:1;overflow-y:auto;min-height:0;padding:60px 0;overscroll-behavior:contain;touch-action:pan-y;cursor:grab}.np-lyrics-container.dragging{cursor:grabbing;-webkit-user-select:none;user-select:none}.np-lyric-line{margin:0;font-size:17px;line-height:2.4;color:#ffffff4d;transition:color .25s,transform .25s,font-weight .25s,opacity .25s;padding:0 4px;cursor:pointer;transform-origin:left center}.np-lyric-line.past{color:#ffffff73}.np-lyric-line.active{color:var(--accent);transform:scale(1.16);font-weight:700;text-shadow:0 0 12px rgba(83,230,190,.32);cursor:default}.nowplaying-view-progress-mini{flex-shrink:0}.nowplaying-view-controls-mini{flex-shrink:0;justify-content:center}.nowplaying-view-controls-mini .nowplaying-view-play{width:40px;height:40px}.am-lyrics-container{flex:1;overflow-y:auto;overscroll-behavior:contain;scroll-behavior:smooth;scrollbar-width:none;mask-image:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,1) 15%,rgba(0,0,0,1) 85%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,1) 15%,rgba(0,0,0,1) 85%,transparent 100%)}.am-lyrics-container::-webkit-scrollbar{display:none}.am-lyrics-spacer{height:40vh;flex-shrink:0}.am-lyric-line{padding:10px 18px;margin:1px 0;border-radius:10px;cursor:pointer;transition:background .2s;-webkit-user-select:none;user-select:none}.am-lyric-line:hover{background:#ffffff0f}.am-lyric-text{display:block;font-size:30px;font-weight:600;line-height:1.4;color:#ffffff40;transform-origin:left center;transform:scale(.92);transition:all .2s cubic-bezier(.25,.46,.45,.94)}.am-lyric-line.active .am-lyric-text{color:#fff;opacity:1;transform:scale(1);transition:all .15s ease-out}.np-lyrics-mode-layout{position:relative;z-index:2;display:flex;width:100%;height:100%;padding:20px 40px 40px;gap:48px}.np-lyrics-left{flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;width:320px}.np-lyrics-left .nowplaying-view-cover{width:240px;height:240px;cursor:pointer}.np-lyrics-cover-hint{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;align-items:center;justify-content:center;font-size:14px;color:#fff0;border-radius:12px;transition:all .25s}.np-lyrics-left .nowplaying-view-cover:hover .np-lyrics-cover-hint,.nowplaying-view-left .nowplaying-view-cover:hover .np-lyrics-cover-hint{color:#fffc;background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.np-lyrics-left .np-lyrics-info{text-align:center;min-width:0}.np-lyrics-left .np-lyrics-title{font-size:20px;font-weight:700;color:#fff;margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.np-lyrics-left .np-lyrics-artist{font-size:14px;color:#ffffff80;margin:0}.np-lyrics-left .np-lyrics-controls-section{width:100%;display:flex;flex-direction:column;gap:16px;align-items:center}.np-lyrics-left .np-lyrics-progress{width:100%}.np-lyrics-left .np-lyrics-time{display:flex;justify-content:space-between;font-size:12px;color:#fff6;margin-top:6px}.np-lyrics-left .np-lyrics-ctrls{display:flex;align-items:center;gap:16px}.np-lyrics-right{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.np-lyrics-right-actions{display:flex;justify-content:flex-end;gap:8px;padding-bottom:12px;flex-shrink:0}.nowplaying-lyrics-editor{flex:1;display:flex;flex-direction:column;gap:12px}.nowplaying-lyrics-editor-hint{font-size:13px;color:#ffffff80}.nowplaying-lyrics-textarea{flex:1;min-height:200px;padding:12px 16px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#0000004d;color:#fff;font-size:14px;font-family:SF Mono,Menlo,Consolas,monospace;line-height:1.6;resize:vertical;outline:none;transition:border-color .2s}.nowplaying-lyrics-textarea:focus{border-color:var(--accent)}.nowplaying-lyrics-textarea::placeholder{color:#fff3}.nowplaying-lyrics-editor-actions{display:flex;justify-content:flex-end;gap:12px}.nowplaying-lyrics-btn-cancel{padding:8px 20px;border-radius:6px;font-size:13px;font-weight:600;color:#fff9;background:#ffffff14;transition:background .2s}.nowplaying-lyrics-btn-cancel:hover{background:#ffffff26}.nowplaying-lyrics-btn-save{padding:8px 20px;border-radius:6px;font-size:13px;font-weight:600;background:var(--accent);color:#000;transition:background .2s,transform .15s}.nowplaying-lyrics-btn-save:hover{background:var(--accent-hover);transform:scale(1.02)}.nowplaying-no-lyrics{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:32px 0;color:#ffffff59;font-size:14px;flex:1;min-height:120px}.nowplaying-add-lyrics-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:6px;background:#ffffff0f;color:#fff6;font-size:13px;font-weight:500;transition:background .2s,color .2s;width:fit-content}.nowplaying-add-lyrics-btn:hover{background:#ffffff1f;color:#fffc}.settings-view{padding:24px 32px}.settings-title{font-size:32px;font-weight:700;margin-bottom:32px}.settings-section{margin-bottom:32px}.settings-section-label{font-size:13px;font-weight:600;color:#ffffff80;text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}.settings-options{display:flex;gap:8px}.settings-option{padding:10px 24px;border-radius:999px;border:1px solid var(--border-color);font-size:14px;font-weight:500;background:#ffffff14;color:#fff;cursor:pointer;transition:background .2s}.settings-option:hover{background:#ffffff24}.settings-option.active{background:linear-gradient(135deg,var(--accent),#9df7dc);color:#071016;border-color:transparent}.download-view{padding:28px 32px 40px}.download-hero{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr);gap:24px;align-items:stretch;margin-bottom:24px}.download-hero-copy,.download-version-panel,.download-platform-card,.download-note-panel{border:1px solid var(--border-color);background:radial-gradient(circle at 16% 10%,rgba(83,230,190,.12),transparent 34%),linear-gradient(180deg,#ffffff16,#ffffff0a);border-radius:20px;box-shadow:0 18px 50px #00000038}.download-hero-copy{padding:36px;min-height:300px;display:flex;flex-direction:column;justify-content:center}.download-eyebrow{color:var(--accent);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}.download-title{max-width:760px;font-size:44px;line-height:1.08;font-weight:800;letter-spacing:0;background:linear-gradient(135deg,#f6fbf7,#8ff0d2 58%,#53e6be);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.download-subtitle{max-width:650px;margin-top:16px;color:var(--text-secondary);font-size:16px;line-height:1.65}.download-hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}.download-primary-btn,.download-secondary-btn,.download-variant{min-height:46px;display:inline-flex;align-items:center;justify-content:center;gap:10px;text-decoration:none;transition:transform .18s,background .2s,border-color .2s,box-shadow .2s,color .2s}.download-primary-btn{padding:0 20px;border-radius:999px;background:linear-gradient(135deg,var(--accent),#9df7dc);color:#071016;font-size:14px;font-weight:800;box-shadow:0 14px 32px #53e6be38}.download-secondary-btn{padding:0 18px;border-radius:999px;border:1px solid var(--border-color);background:var(--bg-elevated);color:var(--text-primary);font-size:14px;font-weight:700}.download-primary-btn:hover,.download-secondary-btn:hover,.download-variant:hover{transform:translateY(-2px)}.download-primary-btn:hover{background:linear-gradient(135deg,var(--accent-hover),#c5ffef);box-shadow:var(--glow)}.download-secondary-btn:hover{background:var(--bg-elevated-hover);border-color:#53e6be47}.download-primary-btn:focus-visible,.download-secondary-btn:focus-visible,.download-variant:focus-visible{outline:2px solid rgba(83,230,190,.72);outline-offset:3px}.download-version-panel{padding:26px;display:grid;align-content:center;gap:18px;background:radial-gradient(circle at 50% 0%,rgba(137,196,244,.16),transparent 42%),linear-gradient(180deg,#ffffff17,#ffffff0a)}.download-version-mark{width:74px;height:74px;border-radius:22px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent),#89c4f4);color:#071016;box-shadow:0 18px 42px #53e6be33}.download-version-label{color:var(--text-secondary);font-size:13px;font-weight:700;margin-bottom:4px}.download-version-number{font-size:38px;font-weight:800;line-height:1;font-variant-numeric:tabular-nums}.download-version-note{color:var(--text-secondary);font-size:14px;line-height:1.55}.download-platform-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.download-platform-card{padding:20px;overflow:hidden}.download-platform-card.macos{background:radial-gradient(circle at 18% 10%,rgba(83,230,190,.15),transparent 38%),linear-gradient(180deg,#ffffff16,#ffffff09)}.download-platform-card.windows{background:radial-gradient(circle at 18% 10%,rgba(137,196,244,.14),transparent 38%),linear-gradient(180deg,#ffffff16,#ffffff09)}.download-platform-card.linux{background:radial-gradient(circle at 18% 10%,rgba(246,211,101,.12),transparent 38%),linear-gradient(180deg,#ffffff16,#ffffff09)}.download-platform-header{display:grid;grid-template-columns:46px 1fr auto;gap:14px;align-items:start}.download-platform-icon{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:#ffffff14;color:var(--accent);font-size:11px;font-weight:900;text-transform:uppercase}.download-platform-header h2{font-size:20px;font-weight:800;margin-bottom:6px}.download-platform-header p{color:var(--text-secondary);font-size:13px;line-height:1.45}.download-platform-badge{padding:5px 9px;border-radius:999px;background:#53e6be29;color:var(--accent);font-size:11px;font-weight:800;white-space:nowrap}.download-variant-list{display:grid;gap:10px;margin-top:18px}.download-variant{justify-content:space-between;padding:10px 12px;border-radius:14px;border:1px solid rgba(255,255,255,.09);background:#ffffff0f;color:var(--text-primary)}.download-variant:hover{border-color:#53e6be3d;background:#ffffff1a;color:var(--accent-hover)}.download-variant strong,.download-variant small{display:block}.download-variant strong{font-size:14px;font-weight:800}.download-variant small{margin-top:3px;color:var(--text-secondary);font-size:12px}.download-note-panel{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-top:18px;padding:22px 24px}.download-note-panel h2{font-size:20px;font-weight:800;margin-bottom:6px}.download-note-panel p{color:var(--text-secondary);font-size:14px;line-height:1.55;max-width:760px}.download-note-steps{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.download-note-steps span{padding:8px 12px;border-radius:999px;background:#53e6be1f;color:var(--accent);font-size:12px;font-weight:800;white-space:nowrap}.nowplaying-share-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:999px;background:linear-gradient(135deg,#53e6be2e,#53e6be0f);color:var(--accent);font-size:13px;font-weight:600;transition:background .2s,transform .15s;width:fit-content}.nowplaying-share-btn:hover{background:linear-gradient(135deg,#1ed76040,#1ed7601a);transform:scale(1.02)}.share-modal{background:var(--bg-elevated);border-radius:12px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 16px 48px #00000080;animation:slideUp .2s ease}.share-card-preview{padding:0 24px 16px}.share-card-preview img{width:100%;border-radius:12px;box-shadow:0 4px 20px #0000004d}.share-modal-actions{display:flex;justify-content:center;padding:0 24px 20px}.share-download-btn{display:flex;align-items:center;gap:8px;padding:10px 28px;border-radius:8px;font-size:14px;font-weight:600;background:var(--accent);color:#000;transition:background .2s,transform .15s}.share-download-btn:hover{background:var(--accent-hover);transform:scale(1.02)}.share-loading{background:var(--bg-elevated);border-radius:12px;padding:40px 32px;text-align:center;color:var(--text-secondary);font-size:15px;box-shadow:0 16px 48px #00000080;animation:slideUp .2s ease;display:flex;flex-direction:column;align-items:center;gap:16px}.share-spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.discover-view{padding:24px;overflow-y:auto}.discover-tabs{display:flex;gap:8px;margin-bottom:24px}.discover-tab{padding:8px 20px;border-radius:999px;border:1px solid var(--border-color);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:500;transition:background .2s,color .2s}.discover-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.discover-tab.active{background:linear-gradient(135deg,var(--accent),#9df7dc);border-color:transparent;color:#071016}.discover-loading{display:flex;justify-content:center;align-items:center;padding:64px 0;color:var(--text-secondary);font-size:15px}.discover-sub-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.discover-sub-header h2{font-size:22px;font-weight:700;color:var(--text-primary)}.discover-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:none;background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;transition:background .2s;flex-shrink:0}.discover-back-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.charts-list{display:flex;flex-direction:column;gap:2px}.charts-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-radius:8px;cursor:pointer;transition:background .15s}.charts-item:hover{background:var(--bg-elevated)}.charts-name{font-size:15px;color:var(--text-primary);font-weight:500}.search-result-tabs{display:flex;gap:8px;margin-bottom:16px}.search-result-tab{padding:6px 14px;border-radius:999px;border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .15s}.search-result-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.search-result-tab.active{background:linear-gradient(135deg,var(--accent),#9df7dc);border-color:var(--accent);color:#071016}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-header .section-title{margin-bottom:0}.browse-all-btn{padding:6px 14px;border-radius:999px;border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .15s;white-space:nowrap}.browse-all-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.category-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.category-tag{padding:6px 16px;border-radius:999px;border:1px solid var(--border-color);background:var(--bg-elevated);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .15s}.category-tag:hover{background:linear-gradient(135deg,var(--accent),#9df7dc);border-color:var(--accent);color:#071016}.artist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.artist-card{display:flex;flex-direction:column;align-items:center;gap:10px;padding:16px;border-radius:16px;border:1px solid transparent;cursor:pointer;transition:background .15s}.artist-card:hover{background:var(--bg-elevated);border-color:var(--border-color)}.artist-card-img{width:120px;height:120px;border-radius:50%;flex-shrink:0}.artist-card-name{font-size:14px;font-weight:600;color:var(--text-primary);text-align:center}.artist-card-meta{font-size:12px;color:var(--text-secondary)}.charts-arrow{color:var(--text-secondary);flex-shrink:0}.add-queue-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border-color);border-radius:50%;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s}.track-row:hover .add-queue-btn{background:linear-gradient(135deg,var(--accent),#9df7dc);border-color:var(--accent);color:#071016}.add-queue-btn:hover{background:linear-gradient(135deg,var(--accent),#9df7dc);border-color:var(--accent);color:#071016;transform:scale(1.1)}.badge-downloaded{font-size:10px;padding:1px 6px;border-radius:8px;background:var(--accent);color:#000;font-weight:600;margin-left:6px;vertical-align:middle}.add-to-playlist-modal{width:360px;max-height:480px;overflow-y:auto}.add-to-playlist-modal h3{margin:0 0 16px;font-size:16px;font-weight:600;color:var(--text-primary)}.playlist-select-list{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.playlist-select-item{display:block;width:100%;text-align:left;padding:12px 14px;border:none;border-radius:8px;background:var(--bg-base);color:var(--text-primary);font-size:14px;cursor:pointer;transition:background .15s}.playlist-select-item:hover{background:var(--bg-hover)}.playlist-select-empty{color:var(--text-secondary);font-size:14px;text-align:center;padding:24px 0}.modal-cancel{display:block;width:100%;padding:10px;border:1px solid var(--border-color);border-radius:8px;background:transparent;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:background .15s}.modal-cancel:hover{background:var(--bg-hover)}.queue-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:50%;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s;margin-left:4px}.queue-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.queue-subtitle{margin:2px 0 0;font-size:13px;color:var(--text-secondary)}.queue-clear-btn{padding:8px 14px;border:1px solid var(--border-color);border-radius:999px;background:var(--bg-elevated);color:var(--text-secondary);font-size:13px;font-weight:600;transition:background .2s,color .2s,border-color .2s}.queue-clear-btn:hover{background:var(--bg-elevated-hover);color:var(--text-primary);border-color:#53e6be47}.queue-section-title{padding:8px 16px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary)}.queue-playing-indicator{display:flex;align-items:center;justify-content:center;color:var(--accent)}.queue-remove-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:50%;background:transparent;color:var(--text-secondary);cursor:pointer;opacity:0;transition:all .15s}.track-row:hover .queue-remove-btn{opacity:1}.queue-remove-btn:hover{background:var(--bg-hover);color:#e23b3b}.queue-list{margin-top:8px}.discover-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.discover-header .discover-tabs{margin-bottom:0}.discover-login-area{display:flex;align-items:center;flex-shrink:0}.source-selector{display:flex;gap:4px;flex-shrink:0}.source-option{padding:5px 12px;border-radius:14px;border:1.5px solid;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;opacity:.6}.source-option:hover{opacity:.9}.source-option.active{color:#fff;opacity:1}.login-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:20px;border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.login-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-secondary)}.login-user-badge{display:flex;align-items:center;gap:8px;padding:4px 12px 4px 4px;border-radius:20px;background:var(--bg-elevated);color:var(--text-primary);font-size:13px;font-weight:500}.login-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.login-modal{width:360px;text-align:center}.login-modal h3{margin:0 0 20px;font-size:18px;font-weight:600;color:var(--text-primary)}.login-loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px 0;color:var(--text-secondary);font-size:14px}.login-spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.login-error{padding:32px 16px;color:var(--text-secondary)}.login-error p{margin:0 0 16px;font-size:14px}.login-retry-btn{padding:8px 24px;border-radius:20px;border:none;background:var(--accent);color:#fff;font-size:14px;cursor:pointer}.login-success{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px 0;color:var(--text-primary);font-size:16px;font-weight:500}.login-qr-container{display:flex;flex-direction:column;align-items:center;gap:12px}.login-qr-img{width:200px;height:200px;border-radius:12px;border:1px solid var(--border-color)}.login-qr-placeholder{width:200px;height:200px;border-radius:12px;background:var(--bg-base)}.login-qr-status{font-size:14px;color:var(--text-secondary)}.login-hint{margin:16px 0 20px;font-size:13px;color:var(--text-secondary)}.login-modal .modal-cancel{width:100%}.album-list-view{display:flex;flex-direction:column;height:100%;overflow-y:auto;padding:24px}.album-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;flex:1;color:var(--text-secondary);font-size:15px;padding:80px 0}.album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:20px;padding:16px 24px}.album-card{cursor:pointer;border-radius:8px;padding:12px;transition:background .2s}.album-card:hover{background:#ffffff0f}.album-card-cover{width:100%;aspect-ratio:1;border-radius:6px;position:relative;margin-bottom:10px}.album-card-remove{position:absolute;top:6px;right:6px;width:28px;height:28px;border-radius:50%;background:#0009;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.album-card:hover .album-card-remove{opacity:1}.album-card-remove:hover{background:#000000d9}.album-card-name{font-size:14px;font-weight:600;color:#fff;margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.album-card-artist{font-size:12px;color:var(--text-secondary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.album-save-btn{width:36px;height:36px;border-radius:50%;background:#00000080;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;opacity:0}.playlist-card:hover .album-save-btn{opacity:1}.album-save-btn:hover{background:#000000bf;transform:scale(1.1)}.album-save-btn.saved{color:#ec4141}.album-toggle-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;border:1px solid rgba(255,255,255,.2);background:transparent;color:#fff;font-size:13px;cursor:pointer;transition:all .2s;margin-left:auto}.album-toggle-btn:hover{background:#ffffff1a}.album-toggle-btn.saved{border-color:#ec4141;color:#ec4141}.sidebar-albums-btn{margin:0 8px 4px;width:auto;justify-content:flex-start}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-base: #071016;--bg-highlight: rgba(255, 255, 255, .075);--bg-elevated: rgba(255, 255, 255, .085);--bg-elevated-hover: rgba(255, 255, 255, .13);--bg-card: rgba(255, 255, 255, .064);--bg-card-hover: rgba(255, 255, 255, .105);--bg-sidebar: rgba(8, 17, 28, .82);--bg-player: rgba(8, 17, 28, .9);--text-primary: #f6fbf7;--text-secondary: #aebfba;--text-subdued: #6f8380;--accent: #53e6be;--accent-hover: #7bf6d7;--accent-active: #24b995;--border-color: rgba(255, 255, 255, .105);--shadow: 0 18px 50px rgba(0, 0, 0, .38);--glow: 0 0 34px rgba(83, 230, 190, .2)}html,body,#root{height:100%;overflow:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:radial-gradient(circle at 18% 12%,rgba(83,230,190,.12),transparent 28%),radial-gradient(circle at 78% 18%,rgba(137,196,244,.08),transparent 28%),linear-gradient(135deg,#071016,#0d1b24 52%,#0a151a);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6,.hero-title,.section-title,.sidebar-logo-text,.playlist-detail-title,.nowplaying-view-title,.library-title,.playlist-card-title,.settings-title,.empty-title,.modal-title{font-family:Outfit,Inter,-apple-system,BlinkMacSystemFont,sans-serif}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}button:focus:not(:focus-visible){outline:none}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton-shimmer{background:linear-gradient(90deg,var(--bg-card) 0%,rgba(255,255,255,.12) 40%,var(--bg-card) 80%);background-size:800px 100%;animation:shimmer 1.6s infinite linear}.skeleton-card{display:flex;flex-direction:column;gap:8px}.skeleton-mt{margin-top:8px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.skeleton-shimmer{animation:none;background:var(--bg-card)}.equalizer span{animation:none}}button{cursor:pointer;border:none;background:none;color:inherit;font:inherit}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#aebfba3d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#53e6be6b}::selection{background:#53e6be47}
