/* ══════════════════════════════════════════════ VARIABLES ══════════════════════════════════════════════ */:root{--bg:#0d0d0d;--bg2:#0a0a0a;--s1:#1a1a1a;--s2:#222;--border:rgba(255,255,255,0.07);--text:#fff;--text2:rgba(255,255,255,0.5);--text3:rgba(255,255,255,0.22);--green:#1db954;--green2:#1aa34a;--tr:0.32s cubic-bezier(0.16,1,0.3,1);--glass-bg:rgba(255,255,255,0.055);--glass-border:rgba(255,255,255,0.10);--glass-blur:blur(28px) saturate(1.8);--glass-shadow:0 8px 32px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.08);--glass-shine:linear-gradient(135deg, rgba(255,255,255,0.10) 0%, rgba(255,255,255,0.02) 50%, rgba(255,255,255,0.06) 100%);}*{box-sizing:border-box;margin:0;padding:0;}html,body{height:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;}::-webkit-scrollbar{width:3px;}::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:3px;}button{font-family:inherit;cursor:pointer;}input{font-family:inherit;}/* ══════════════════════════════════════════════ LAYOUT ══════════════════════════════════════════════ */ #app{display:flex;height:100%;flex-direction:column;}#main-row{display:flex;flex:1;overflow:hidden;}/* ══════════════════════════════════════════════ SIDEBAR — glass, icon-only when collapsed ══════════════════════════════════════════════ */ #sidebar{width:185px;background:rgba(12,12,12,0.85);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-right:1px solid var(--glass-border);display:flex;flex-direction:column;flex-shrink:0;transition:width var(--tr);overflow:hidden;position:relative;z-index:10;}#sidebar::before{content:'';position:absolute;inset:0;background:var(--glass-shine);pointer-events:none;z-index:0;}#sidebar > *{position:relative;z-index:1;}#sidebar.collapsed{width:46px;}#sidebar.collapsed #sb-logo, #sidebar.collapsed .sb-label, #sidebar.collapsed .nl{opacity:0;width:0;overflow:hidden;pointer-events:none;}.sb-header{display:flex;align-items:center;gap:9px;padding:13px 10px 12px;border-bottom:1px solid var(--glass-border);flex-shrink:0;min-height:46px;}#sb-logo{font-size:13px;font-weight:800;white-space:nowrap;transition:opacity .2s,width .32s cubic-bezier(0.16,1,0.3,1);letter-spacing:-.2px;overflow:hidden;}.sb-body{padding:8px 5px;flex:1;overflow:hidden;}.sb-label{font-size:8px;color:var(--text3);letter-spacing:2px;font-weight:700;padding:0 8px;margin-bottom:4px;white-space:nowrap;transition:opacity .2s,width .2s;}.sb-footer{padding:6px 5px;border-top:1px solid var(--glass-border);}.nav-item{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:9px;color:var(--text2);font-size:12px;cursor:pointer;white-space:nowrap;transition:background .18s,color .18s;border:none;background:none;width:100%;text-align:left;min-height:33px;}.nav-item:hover{color:var(--text);background:rgba(255,255,255,0.06);}.nav-item.active{background:rgba(29,185,84,0.14);color:var(--green);font-weight:600;}.nav-item svg{flex-shrink:0;width:15px;height:15px;}.nl{transition:opacity .2s;}#sidebar.collapsed .nav-item{justify-content:center;padding:7px 0;}#sidebar.collapsed .sb-header{justify-content:center;padding:13px 0 12px;}/* ══════════════════════════════════════════════ CONTENT ══════════════════════════════════════════════ */ #content{flex:1;overflow-y:auto;padding:24px 24px 100px;min-width:0;}/* ══════════════════════════════════════════════ RIGHT PANEL — glass, slides out cleanly ══════════════════════════════════════════════ */ #right-panel{width:200px;background:rgba(10,10,10,0.82);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-left:1px solid var(--glass-border);display:flex;flex-direction:column;flex-shrink:0;transform:translateX(0);transition:transform var(--tr), opacity var(--tr), width 0s;overflow:hidden;position:relative;z-index:10;}#right-panel::before{content:'';position:absolute;inset:0;background:var(--glass-shine);pointer-events:none;z-index:0;}#right-panel > *{position:relative;z-index:1;}#right-panel.collapsed{transform:translateX(100%);width:0;border-left:none;transition:transform var(--tr), opacity var(--tr), width 0s var(--tr);}.rp-header{display:flex;align-items:center;border-bottom:1px solid var(--glass-border);flex-shrink:0;padding:9px 10px 9px;gap:8px;min-height:46px;}.tab-pill-wrap{flex:1;display:flex;align-items:center;position:relative;background:rgba(255,255,255,0.07);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:50px;padding:3px;border:1px solid rgba(255,255,255,0.10);box-shadow:inset 0 1px 0 rgba(255,255,255,0.08), 0 2px 8px rgba(0,0,0,0.25);}.tab-pill-wrap::before{content:'';position:absolute;top:3px;bottom:3px;left:3px;width:calc(50% - 3px);background:linear-gradient(160deg, rgba(255,255,255,0.26) 0%, rgba(255,255,255,0.11) 55%, rgba(255,255,255,0.18) 100% );border-radius:50px;box-shadow:0 2px 10px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.30), inset 0 -1px 0 rgba(0,0,0,0.15);transition:transform 0.36s cubic-bezier(0.34,1.4,0.64,1);z-index:0;pointer-events:none;}/* Move to right half:pill is calc(50%-3px) wide, starts at left:3px right half starts at 50% from container left so we need to move:(50% of container) - 3px (left inset) = exactly its own width i.e. translateX(100%) lands flush */ .tab-pill-wrap.on-queue::before{transform:translateX(100%);}.tab-btn{flex:1;background:none;border:none;color:rgba(255,255,255,0.40);font-size:11px;font-weight:600;padding:5px 0;cursor:pointer;transition:color .22s;white-space:nowrap;letter-spacing:.2px;position:relative;z-index:1;border-radius:50px;text-align:center;}.tab-btn.active{color:#fff;font-weight:700;}.slide-wrap{flex:1;overflow:hidden;position:relative;}.slide-track{display:flex;height:100%;transition:transform .38s cubic-bezier(0.16,1,0.3,1);will-change:transform;}.slide-pane{min-width:100%;height:100%;overflow-y:auto;padding:12px;}/* ══════════════════════════════════════════════ MINI PLAYER — liquid glass capsule ══════════════════════════════════════════════ */ #mini-player{position:fixed;bottom:14px;left:50%;transform:translateX(-50%);z-index:200;background:rgba(20,20,20,0.72);backdrop-filter:blur(40px) saturate(2.2);-webkit-backdrop-filter:blur(40px) saturate(2.2);border:1px solid rgba(255,255,255,0.12);border-radius:50px;padding:7px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 16px 48px rgba(0,0,0,0.7), 0 2px 0 rgba(255,255,255,0.06) inset, 0 -1px 0 rgba(0,0,0,0.4) inset;white-space:nowrap;transition:opacity .3s, transform .3s;position:fixed;}#mini-player::before{content:'';position:absolute;inset:0;border-radius:50px;background:linear-gradient(180deg,rgba(255,255,255,0.08) 0%,transparent 60%);pointer-events:none;}#mini-player.hidden{opacity:0;pointer-events:none;transform:translateX(-50%) translateY(18px);}/* ══════════════════════════════════════════════ COMPONENTS ══════════════════════════════════════════════ */ .icon-btn{background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.08);border-radius:8px;color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0;}.icon-btn:hover{background:rgba(255,255,255,0.12);color:var(--text);}.play-btn-g{border-radius:50%;background:var(--green);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;box-shadow:0 4px 16px rgba(29,185,84,0.4), inset 0 1px 0 rgba(255,255,255,0.25);transition:transform .18s cubic-bezier(.16,1,.3,1), background .15s, box-shadow .15s;}.play-btn-g:hover{transform:scale(1.08);background:var(--green2);box-shadow:0 6px 24px rgba(29,185,84,0.55), inset 0 1px 0 rgba(255,255,255,0.2);}.play-btn-g:active{transform:scale(.93);}.ctrl-g{background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text2);transition:color .15s,transform .15s;padding:4px;}.ctrl-g:hover{color:var(--text);transform:scale(1.12);}.ctrl-g:active{transform:scale(.92);}.prog-wrap{width:100%;height:3px;background:rgba(255,255,255,0.10);border-radius:4px;cursor:pointer;position:relative;transition:height .15s;}.prog-wrap:hover{height:5px;}.prog-fill{height:100%;background:var(--green);border-radius:4px;position:relative;}.prog-fill::after{content:'';position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:12px;height:12px;border-radius:50%;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.5);opacity:0;transition:opacity .15s;}.prog-wrap:hover .prog-fill::after{opacity:1;}.vol-wrap{flex:1;height:3px;background:rgba(255,255,255,.10);border-radius:3px;cursor:pointer;transition:height .15s;}.vol-wrap:hover{height:5px;}.vol-fill{height:100%;background:rgba(255,255,255,.45);border-radius:3px;}.cover{border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--s1);display:flex;align-items:center;justify-content:center;}.cover img{width:100%;height:100%;object-fit:cover;}.rp-cover{width:100%;aspect-ratio:1;border-radius:12px;overflow:hidden;background:rgba(255,255,255,0.05);margin-bottom:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,0.06);}.rp-cover img{width:100%;height:100%;object-fit:cover;display:block;}/* ══════════════════════════════════════════════ CARDS & LISTS ══════════════════════════════════════════════ */ .section-title{font-size:9px;color:var(--text3);letter-spacing:2px;font-weight:700;margin-bottom:10px;}.section-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}.pill-btn{background:rgba(29,185,84,.12);border:none;border-radius:20px;color:var(--green);font-size:10px;font-weight:700;padding:4px 10px;cursor:pointer;transition:background .15s;}.pill-btn:hover{background:rgba(29,185,84,.22);}.song-row{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:8px;cursor:pointer;transition:background .15s;}.song-row:hover{background:rgba(255,255,255,.05);}.h-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;}.h-scroll::-webkit-scrollbar{display:none;}.quick-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.05);border-radius:10px;padding:9px;display:flex;align-items:center;gap:9px;cursor:pointer;transition:background .18s, border-color .18s;}.quick-card:hover{background:rgba(255,255,255,0.07);border-color:rgba(255,255,255,0.09);}.song-card{flex-shrink:0;width:105px;cursor:pointer;}.song-card-cover{width:105px;height:105px;border-radius:10px;background:var(--s1);margin-bottom:7px;overflow:hidden;display:flex;align-items:center;justify-content:center;}.song-card-cover img{width:100%;height:100%;object-fit:cover;}.song-card-title{font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}.song-card-sub{font-size:10px;color:var(--text2);margin-top:1px;}.artist-card{display:flex;flex-direction:column;align-items:center;gap:7px;cursor:pointer;flex-shrink:0;width:75px;}.artist-av{width:62px;height:62px;border-radius:50%;background:var(--s1);display:flex;align-items:center;justify-content:center;overflow:hidden;}.artist-av img{width:100%;height:100%;object-fit:cover;}.artist-nm{font-size:10px;color:var(--text2);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;}.card-grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;}.empty-st{text-align:center;padding:60px 20px;color:var(--text3);}.empty-st p{font-size:13px;font-weight:600;}.page-title{font-size:22px;font-weight:800;letter-spacing:-.3px;margin-bottom:2px;}.page-sub{font-size:12px;color:var(--text3);}/* ══════════════════════════════════════════════ FULLSCREEN LYRICS ══════════════════════════════════════════════ */ #lyrics-screen{position:fixed;inset:0;z-index:500;display:flex;overflow:hidden;opacity:0;pointer-events:none;transition:opacity .3s ease;}#lyrics-screen.open{opacity:1;pointer-events:all;}#lbg{position:absolute;inset:0;z-index:0;}#lbg-img{position:absolute;inset:-20%;background-size:cover;background-position:center;filter:blur(60px) saturate(1.8) brightness(0.6);transform:scale(1.2);}#lbg-ov{position:absolute;inset:0;background:rgba(0,0,0,.5);}#lrc-content{position:relative;z-index:1;display:flex;height:100%;width:100%;}#lp-left{width:360px;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding:28px 32px;overflow:hidden;}#lp-cover{width:100%;aspect-ratio:1 / 1;max-width:min(100%, calc(100vh - 320px));border-radius:16px;overflow:hidden;flex-shrink:0;box-shadow:0 24px 64px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,0.06);background:var(--s1);display:flex;align-items:center;justify-content:center;margin-bottom:18px;}#lp-cover img{width:100%;height:100%;object-fit:cover;display:block;}#lp-title{font-size:17px;font-weight:800;margin-bottom:3px;letter-spacing:-.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;text-align:left;}#lp-artist{font-size:12px;color:rgba(255,255,255,.45);margin-bottom:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;text-align:left;}#lp-prog{width:100%;height:4px;background:rgba(255,255,255,.18);border-radius:4px;margin-bottom:6px;cursor:pointer;position:relative;transition:height .15s;}#lp-prog:hover{height:6px;}#lp-prog-fill{height:100%;background:#fff;border-radius:4px;position:relative;}#lp-prog-fill::after{content:'';position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:13px;height:13px;border-radius:50%;background:#fff;box-shadow:0 2px 6px rgba(0,0,0,.3);opacity:0;transition:opacity .15s;}#lp-prog:hover #lp-prog-fill::after{opacity:1;}.lp-time{display:flex;justify-content:space-between;font-size:10px;color:rgba(255,255,255,.3);font-weight:600;margin-bottom:18px;width:100%;}#lp-ctrls{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;padding:0 4px;width:100%;}.lp-extra{width:34px;height:34px;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.55);transition:all .15s;}.lp-extra:hover{color:#fff;transform:scale(1.1);}.lp-extra.on{color:#fff;}.lp-side{width:42px;height:42px;background:rgba(255,255,255,.12);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .18s;}.lp-side:hover{background:rgba(255,255,255,.2);transform:scale(1.06);}#lp-play{width:54px;height:54px;background:rgba(255,255,255,0.92);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,0.5);transition:all .18s;}#lp-play:hover{transform:scale(1.07);}.lp-vol{display:flex;align-items:center;gap:9px;padding:0 4px;width:100%;}.lp-vol-track{flex:1;height:3px;background:rgba(255,255,255,.14);border-radius:3px;cursor:pointer;transition:height .15s;}.lp-vol-track:hover{height:5px;}.lp-vol-fill{height:100%;width:80%;background:rgba(255,255,255,.5);border-radius:3px;}#lp-right{flex:1;overflow-y:auto;padding:80px 52px 80px 44px;display:flex;flex-direction:column;justify-content:flex-start;scrollbar-width:none;}#lp-right::-webkit-scrollbar{display:none;}.lyric-line{font-weight:800;line-height:1.4;cursor:pointer;padding:3px 0;transition:all .42s cubic-bezier(.16,1,.3,1);letter-spacing:-.3px;margin-bottom:16px;}.lyric-line.lrc-active{font-size:30px;color:#fff;margin-bottom:20px;}.lyric-line.lrc-near{font-size:24px;color:rgba(255,255,255,.45);}.lyric-line.lrc-mid{font-size:20px;color:rgba(255,255,255,.28);}.lyric-line.lrc-far{font-size:18px;color:rgba(255,255,255,.14);}.lyric-line:hover{color:rgba(255,255,255,.65)!important;}.lyric-line.lrc-wait{display:flex;align-items:center;gap:7px;padding:6px 0;cursor:default;min-height:40px;}.lyric-line.lrc-wait:hover{color:unset!important;}.lrc-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.2);transition:background .3s;flex-shrink:0;}.lrc-wait .lrc-dot{background:rgba(255,255,255,0.15);animation:none;}.lrc-wait.lrc-wait-active .lrc-dot{background:rgba(255,255,255,0.7);animation:lrcDot .7s ease-in-out infinite alternate;}.lrc-wait.lrc-wait-active .lrc-dot:nth-child(2){animation-delay:.14s;}.lrc-wait.lrc-wait-active .lrc-dot:nth-child(3){animation-delay:.28s;}#lp-close{position:absolute;top:16px;left:20px;z-index:10;width:30px;height:30px;border-radius:50%;background:rgba(0,0,0,.3);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.1);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;}#lp-close:hover{background:rgba(0,0,0,.5);}#lp-no-lrc{font-size:16px;color:rgba(255,255,255,.25);font-weight:700;text-align:center;margin-top:80px;}/* ══════════════════════════════════════════════ SOUND CAPSULE ══════════════════════════════════════════════ */ .caps-hero{background:linear-gradient(135deg,var(--s1),rgba(29,185,84,.1));border:1px solid rgba(29,185,84,.2);border-radius:16px;padding:20px;margin-bottom:20px;position:relative;overflow:hidden;}.caps-hero::after{content:'';position:absolute;right:-20px;top:-20px;width:100px;height:100px;border-radius:50%;background:radial-gradient(circle,rgba(29,185,84,.15),transparent 70%);}.caps-stat{font-size:34px;font-weight:900;color:#fff;line-height:1;}.caps-lbl{font-size:9px;color:var(--green);letter-spacing:2px;font-weight:800;margin-bottom:8px;}.caps-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:12px;margin-bottom:8px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.04);}.caps-row.top{background:rgba(29,185,84,.08);border-color:rgba(29,185,84,.15);}.caps-rank{font-size:15px;font-weight:900;min-width:22px;text-align:center;}.month-nav{display:flex;align-items:center;gap:8px;margin-bottom:16px;}.mnav-btn{background:none;border:none;cursor:pointer;color:var(--text2);padding:4px 8px;border-radius:6px;transition:background .15s;}.mnav-btn:hover{background:var(--s1);}.mnav-btn:disabled{opacity:.3;cursor:default;}.mnav-lbl{flex:1;font-size:13px;font-weight:700;text-align:center;}/* ══════════════════════════════════════════════ SETTINGS ══════════════════════════════════════════════ */ .settings-section{background:var(--s1);border-radius:12px;overflow:hidden;margin-bottom:12px;}.settings-row{display:flex;align-items:center;gap:12px;padding:13px 16px;transition:background .15s;}.settings-row:not(:last-child){border-bottom:1px solid var(--border);}.s-lbl{flex:1;font-size:13px;font-weight:500;}.s-sub{font-size:11px;color:var(--text2);margin-top:1px;}.toggle{width:38px;height:22px;background:var(--s2);border-radius:11px;position:relative;cursor:pointer;transition:background .2s;border:none;flex-shrink:0;}.toggle.on{background:var(--green);}.toggle::after{content:'';position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.3);}.toggle.on::after{transform:translateX(16px);}.lang-opt{display:flex;align-items:center;gap:10px;padding:11px 16px;cursor:pointer;transition:background .15s;}.lang-opt:hover{background:rgba(255,255,255,.03);}.lang-opt.sel{background:rgba(29,185,84,.1);}.lang-opt:not(:last-child){border-bottom:1px solid var(--border);}/* ══════════════════════════════════════════════ CONTEXT MENU ══════════════════════════════════════════════ */ #ctx-menu{position:fixed;z-index:800;background:rgba(22,22,22,0.88);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,0.10);border-radius:12px;padding:4px;min-width:160px;box-shadow:0 12px 40px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,0.06);opacity:0;pointer-events:none;transition:opacity .15s;}#ctx-menu.open{opacity:1;pointer-events:all;}.ctx-item{padding:9px 12px;border-radius:8px;font-size:12px;cursor:pointer;transition:background .1s;white-space:nowrap;}.ctx-item:hover{background:rgba(255,255,255,.07);}/* ══════════════════════════════════════════════ TOAST ══════════════════════════════════════════════ */ #toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%);background:rgba(22,22,22,0.9);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,0.10);color:#fff;padding:10px 20px;border-radius:24px;font-size:13px;font-weight:600;z-index:1000;opacity:0;transition:opacity .3s;pointer-events:none;box-shadow:0 4px 20px rgba(0,0,0,.5);white-space:nowrap;}#toast.show{opacity:1;}/* ══════════════════════════════════════════════ MOBILE BLOCK ══════════════════════════════════════════════ */ #mobile-block{display:none;position:fixed;inset:0;z-index:9999;background:#0a0a0a;flex-direction:column;align-items:center;justify-content:center;padding:32px;text-align:center;}@media(max-width:768px){#mobile-block{display:flex;}#app{display:none;}}/* ══════════════════════════════════════════════ ANIMATIONS ══════════════════════════════════════════════ */ @keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes lrcDot{from{transform:translateY(0);opacity:0.25}to{transform:translateY(-9px);opacity:1}}.fade-in{animation:fadeIn .25s ease;}.slide-up{animation:slideUp .28s ease;}