:root {
  --bg:#0a0a0a; --surface:#111; --surface2:#1a1a1a; --surface3:#222;
  --accent:#1db954; --accent-rgb:29, 185, 84; --accent2:#16a34a;
  --accent-secondary:#00ffa3; --accent-secondary-rgb:0, 255, 163;
  --page-bg-gradient:linear-gradient(135deg,#071a0a 0%,#0a2e10 40%,#0d1f0d 70%,#050d05 100%);
  --avatar-gradient:linear-gradient(135deg,#1a3a1a,#0d2b0d);
  --sheet-gradient:linear-gradient(180deg,#0f1a14 0%,#0B0F0E 100%);
  --text:#fff; --text2:#888; --r:16px;
  --card:#141414; --border:#1e1e1e;
  --player-h:0px;
  --nav-h:64px;
  --bottom-pad:calc(var(--nav-h) + var(--player-h) + 16px);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
img{-webkit--webkit-user-select:none;user-select:none}
a img,button img,.track-thumb,.track-ph,.player-thumb,.fs-cover,.r-thumb,.pl-card-img img{pointer-events:auto}
body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;min-height:100vh;overflow-x:hidden;-webkit-tap-highlight-color:transparent;max-width:480px;margin:0 auto}
button,a,input{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}
.nav{display:flex;background:rgba(10,10,10,.95);border-top:1px solid var(--border);border-radius:20px 20px 0 0;position:fixed;bottom:0;left:0;right:0;z-index:400;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.nb{flex:1;padding:10px 4px 8px;background:none;border:none;color:var(--text2);font-size:10px;font-weight:500;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;transition:color .2s;letter-spacing:.3px}
.nb.active{color:var(--accent)}
.nb svg{width:24px;height:24px}
.nb-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);margin-top:2px;opacity:0}
.nb.active .nb-dot{opacity:1}
.page{display:none;padding:16px 16px var(--bottom-pad);overflow-y:auto;position:relative}
.page.active{display:block}
.search-bar{display:flex;gap:8px;margin-bottom:16px}
.search-input{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:14px;padding:12px 16px;color:var(--text);font-size:15px;outline:none}
.search-input:focus{border-color:var(--accent)}
.search-btn{background:var(--accent);border:none;border-radius:14px;padding:12px 16px;color:#000;font-weight:700;cursor:pointer;font-size:15px}
.track-list{display:flex;flex-direction:column;gap:4px}
.track-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:transparent;border-radius:12px;cursor:pointer;transition:background .15s;border:none;width:100%;text-align:left}
.track-item:active{background:var(--surface2)}

.track-thumb{width:48px;height:48px;border-radius:8px;object-fit:cover;background:var(--surface2);flex-shrink:0}
.track-ph{width:48px;height:48px;border-radius:8px;background:var(--surface2);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:20px}
.track-info{flex:1;min-width:0}
.track-title{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}
.track-artist{font-size:12px;color:var(--text2);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}
.track-artist-link{cursor:pointer}
@media(hover:hover){.track-artist-link:hover{color:var(--accent);text-decoration:underline}}
.track-dur{font-size:11px;color:var(--text2);flex-shrink:0}
.section-title{font-size:17px;font-weight:700;margin-bottom:12px;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;letter-spacing:-.2px}
.back-btn{background:none;border:none;color:var(--accent);font-size:14px;cursor:pointer;margin-bottom:12px;display:flex;align-items:center;gap:4px;padding:0}
.genre-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.genre-btn{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:16px 12px;color:var(--text);font-size:14px;font-weight:600;cursor:pointer;text-align:center;transition:all .15s}
.genre-btn:active,.genre-btn.active{background:var(--accent);color:#000;border-color:var(--accent)}
.profile-tabs{display:flex;gap:6px;padding:4px;background:var(--surface2);border-radius:12px;margin-bottom:20px}
.profile-tab{flex:1;background:none;border:none;color:var(--text2);font-size:12px;font-weight:600;padding:8px 4px;cursor:pointer;border-radius:9px;transition:all .2s}
.profile-tab.active{background:var(--surface3);color:#fff}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);width:100%;background:none;border-left:none;border-right:none;border-top:none;cursor:default;text-align:left;gap:12px}
.settings-row-info{flex:1;min-width:0}
.settings-row-title{font-size:14px;font-weight:600;color:#fff}
.settings-row-sub{font-size:12px;color:var(--text2);margin-top:2px}
.accent-theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%}
.accent-theme-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 6px;background:var(--surface2);border:2px solid transparent;border-radius:14px;cursor:pointer;transition:border-color .2s,background .2s}
.accent-theme-btn .sw{width:28px;height:28px;border-radius:50%;border:2px solid rgba(255,255,255,.15);box-shadow:0 2px 8px rgba(0,0,0,.4)}
.accent-theme-btn .lb{font-size:10px;font-weight:600;color:var(--text2);text-align:center;line-height:1.2}
.accent-theme-btn.active{border-color:var(--accent);background:rgba(var(--accent-rgb),0.12)}
.accent-theme-btn:active{transform:scale(.96)}
.settings-toggle{position:relative;display:inline-block;width:44px;height:26px;flex-shrink:0}
.settings-toggle input{opacity:0;width:0;height:0}
.settings-slider{position:absolute;inset:0;background:#333;border-radius:26px;transition:.25s;cursor:pointer}
.settings-slider:before{content:'';position:absolute;width:20px;height:20px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.25s}
.settings-toggle input:checked+.settings-slider{background:var(--accent)}
.settings-toggle input:checked+.settings-slider:before{transform:translateX(18px)}
.loader{text-align:center;padding:32px;color:var(--text2)}
.spinner{width:32px;height:32px;border:3px solid #333;border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 12px}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes bbBar1{from{height:4px}to{height:14px}}
@keyframes bbBar2{from{height:14px}to{height:5px}}
@keyframes bbBar3{from{height:7px}to{height:18px}}
.toast{position:fixed;top:60px;left:50%;transform:translateX(-50%);background:var(--surface2);color:var(--text);padding:10px 20px;border-radius:20px;font-size:13px;z-index:100000;opacity:0;transition:opacity .3s;pointer-events:none;white-space:nowrap}
.toast.show{opacity:1}
.adm-card{background:var(--card);border-radius:14px;padding:14px 16px;border-left:3px solid var(--accent)}
.adm-card-label{font-size:11px;color:var(--text2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}
.adm-card-val{font-size:26px;font-weight:700;color:#fff;line-height:1}
.adm-card.adm-hidden{display:none}
.adm-view-btn{display:flex;align-items:center;gap:5px;background:none;border:none;color:rgba(255,255,255,.5);cursor:pointer;padding:5px 10px;border-radius:8px;font-size:12px;font-weight:600;transition:all .2s}
.adm-view-active{background:rgba(255,255,255,.12)!important;color:#fff!important}
.adm-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text2);cursor:pointer;user-select:none;transition:opacity .2s}
.adm-legend-item.adm-series-off{opacity:.35}
.adm-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.adm-field-check{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;color:#fff}
.adm-field-check input{width:20px;height:20px;accent-color:#4fc3f7;cursor:pointer;flex-shrink:0}
.player{position:fixed;bottom:76px;left:8px;right:8px;background:#111;border:1px solid #1e1e1e;border-radius:18px;padding:12px 16px 14px;z-index:399;display:none;box-shadow:0 8px 40px rgba(0,0,0,.7)}
.player.visible{display:block}
#player-bg-glow{position:absolute;top:0;left:0;right:0;bottom:0;z-index:-1;-webkit-transform:translateZ(0);transform:translateZ(0);will-change:background;filter:blur(60px);opacity:0.6;transition:background 0.5s ease;border-radius:18px;pointer-events:none}
.player-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.player-thumb{width:44px;height:44px;border-radius:8px;object-fit:cover;background:var(--surface2);flex-shrink:0}
.player-info{flex:1;min-width:0;-webkit-perspective:1000;perspective:1000;-webkit-transform-style:preserve-3d;transform-style:preserve-3d}
.player-title{font-size:14px;font-weight:600;line-height:1.3;-webkit-text-size-adjust:none;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}
.player-title-wrap{overflow:hidden;position:relative;white-space:nowrap;-webkit-transform:translateZ(0);transform:translateZ(0)}
.player-title-wrap.marquee{-webkit-mask:linear-gradient(to right,transparent 0%,#000 8%,#000 82%,transparent 100%);mask:linear-gradient(to right,transparent 0%,#000 8%,#000 82%,transparent 100%)}
.player-title-wrap.marquee .player-title{font-size:14px;font-weight:600;line-height:1.3;width:max-content;display:inline-block;-webkit-transform:translateZ(0);transform:translateZ(0);backface-visibility:hidden;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-font-smoothing:antialiased;animation:marquee-scroll var(--marquee-dur,8s) linear infinite}
@keyframes marquee-scroll{0%{transform:translate3d(0,0,0)}100%{transform:translate3d(-50%,0,0)}}
.player-artist{font-size:12px;color:var(--text2);-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}
.player-controls{display:flex;align-items:center;gap:12px}
.ctrl-btn{background:none;border:none;color:var(--text);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}
.ctrl-btn svg{width:26px;height:26px}
.ctrl-btn.play-btn{background:var(--accent);border-radius:50%;width:52px;height:52px;color:#000;box-shadow:0 4px 16px rgba(var(--accent-rgb),.4)}
.ctrl-btn.play-btn svg{width:24px;height:24px}
.progress-wrap{flex:1;display:flex;align-items:center;gap:8px}
.progress{flex:1;height:3px;background:#2a2a2a;border-radius:2px;cursor:pointer;position:relative}
.progress-fill{height:100%;background:var(--accent);border-radius:2px;width:0%;transition:width .1s linear;box-shadow:0 0 6px rgba(var(--accent-rgb),.5)}
.time{font-size:11px;color:var(--text2);min-width:32px}
.fav-btn{background:none;border:none;color:#666;cursor:pointer;padding:6px;transition:color .2s}
.fs-player{position:fixed;inset:0;z-index:500;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);background:#111;overflow:hidden}
.fs-player.open{transform:translateY(0)}
.fs-bg{position:absolute;inset:-40px;background-size:cover;background-position:center;filter:blur(60px) brightness(.35) saturate(1.5);z-index:0;transition:opacity .4s ease}
.fs-player.vis-on .fs-bg { opacity: 0; }
.fs-content{position:relative;z-index:10;display:flex;flex-direction:column;height:100%;padding:0 28px;overflow:hidden;-webkit-transform:translateZ(0);transform:translateZ(0);flex:1}
.fs-header{display:flex;align-items:center;justify-content:space-between;padding:20px 0 8px;flex-shrink:0}
.fs-close{background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;padding:4px;line-height:0}
.fs-close svg{width:26px;height:26px}
.fs-cover-wrap{display:flex;align-items:center;justify-content:center;padding:12px 0;flex-shrink:0}
.fs-cover{width:min(68vw,260px);height:min(68vw,260px);border-radius:16px;object-fit:cover;box-shadow:0 20px 60px rgba(0,0,0,.7)}
.fs-cover-ph{width:min(68vw,260px);height:min(68vw,260px);border-radius:16px;background:#333;display:flex;align-items:center;justify-content:center;font-size:64px}
.fs-info{text-align:center;margin-bottom:14px;flex-shrink:0}
.fs-title{font-size:20px;font-weight:700;margin-bottom:4px;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}
.fs-title-wrap{overflow:hidden;position:relative;white-space:nowrap;-webkit-transform:translateZ(0);transform:translateZ(0)}
.fs-title-wrap.marquee{-webkit-mask:linear-gradient(to right,transparent 0%,#000 6%,#000 84%,transparent 100%);mask:linear-gradient(to right,transparent 0%,#000 6%,#000 84%,transparent 100%)}
.fs-title-wrap.marquee .fs-title{width:max-content;display:inline-block;-webkit-transform:translateZ(0);transform:translateZ(0);backface-visibility:hidden;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-font-smoothing:antialiased;animation:marquee-scroll var(--marquee-dur,10s) linear infinite}
.fs-artist{font-size:14px;color:rgba(255,255,255,.6);-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;cursor:pointer}
.fs-artist:hover{color:rgba(255,255,255,.9);text-decoration:underline}
.fs-prog-wrap{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;flex-shrink:0}
.fs-prog{width:100%;height:20px;background:transparent;border-radius:2px;cursor:pointer;position:relative;touch-action:manipulation;display:flex;align-items:center}
.fs-prog-fill{height:4px;background:#fff;border-radius:2px;width:0%;pointer-events:none;position:relative}
.fs-prog::before{content:'';position:absolute;top:50%;left:0;right:0;height:4px;background:rgba(255,255,255,.2);border-radius:2px;transform:translateY(-50%)}
.fs-times{display:flex;justify-content:space-between;font-size:12px;color:rgba(255,255,255,.45)}
.fs-controls{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-shrink:0}
.fs-btn{background:none;border:none;color:rgba(255,255,255,.8);cursor:pointer;padding:8px;line-height:0}
.fs-btn svg{width:30px;height:30px}
#vis-list-btn{display:none !important}
.vis-immersive #vis-list-btn{display:inline-flex !important}
.fs-play-btn{background:#fff;border:none;border-radius:50%;width:64px;height:64px;color:#000;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.5);flex-shrink:0}
.fs-play-btn svg{width:28px;height:28px}
.fs-vol-wrap{display:flex;align-items:center;gap:10px;padding:0 8px;margin-bottom:8px;flex-shrink:0}
.fs-vol-input{flex:1;-webkit-appearance:none;appearance:none;height:4px;background:linear-gradient(to right,var(--accent) 100%,rgba(255,255,255,.2) 100%);border-radius:2px;outline:none;cursor:pointer}
.fs-vol-input::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 0 6px rgba(var(--accent-rgb),.5)}
.fs-actions{display:flex;justify-content:space-around;padding-bottom:max(20px,env(safe-area-inset-bottom));flex-shrink:0;margin-top:16px}
.fs-action-btn{background:none;border:none;color:rgba(255,255,255,.6);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:5px;font-size:12px;padding:4px 12px;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}
.fs-action-btn svg{width:24px;height:24px}
.fs-action-btn.on{color:var(--accent);text-shadow:0 0 8px rgba(var(--accent-rgb),.5)}

/* Visualizations */
#mini-vis {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  opacity: 0.35;
  border-radius: 18px;
  pointer-events: none;
}
#fs-vis-2d, #fs-vis-webgl {
  z-index: 1;
  display: none;
  opacity: 1;
}
#fs-vis-2d.active, #fs-vis-webgl.active {
  display: block;
}
#vis-toggle-btn.active {
  color: var(--accent);
  filter: drop-shadow(0 0 8px rgba(var(--accent-rgb), 0.6));
}

.sheet{position:fixed;bottom:0;left:0;right:0;z-index:450;background:var(--sheet-gradient);border-radius:20px 20px 0 0;transform:translateY(110%);transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .4s ease;max-height:80vh;display:flex;flex-direction:column;box-shadow:none;pointer-events:none}
.sheet.open{transform:translateY(0);pointer-events:auto}
#sheet-menu.open{box-shadow:0 -8px 50px rgba(var(--accent-secondary-rgb),0.06)}
.sheet-handle{width:36px;height:4px;background:rgba(var(--accent-secondary-rgb),0.2);border-radius:2px;margin:10px auto 0;flex-shrink:0}
.sheet-header{display:flex;align-items:center;padding:12px 16px 0;flex-shrink:0}
.sheet-close{background:none;border:none;color:rgba(255,255,255,.6);cursor:pointer;margin-left:auto;font-size:20px;line-height:1;padding:4px}
.sheet-tabs{display:flex;border-bottom:1px solid rgba(var(--accent-secondary-rgb),0.1);margin:8px 16px 0;flex-shrink:0}
.sheet-tab{flex:1;background:none;border:none;color:rgba(255,255,255,.4);font-size:13px;font-weight:600;padding:10px 0;cursor:pointer;border-bottom:2px solid transparent;letter-spacing:.5px}
.sheet-tab.active{color:var(--accent-secondary);border-bottom-color:var(--accent-secondary)}
.sheet-body{overflow-y:auto;flex:1;padding:12px 16px}
.r-track{display:flex;align-items:center;gap:12px;padding:8px 0;cursor:pointer;border:none;background:none;width:100%;text-align:left}
.r-track:active{opacity:.7}
.r-thumb{width:48px;height:48px;border-radius:8px;object-fit:cover;background:#333;flex-shrink:0}
.r-ph{width:48px;height:48px;border-radius:8px;background:#333;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.r-info{flex:1;min-width:0}
.r-title{font-size:14px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.r-artist{font-size:12px;color:rgba(255,255,255,.5);margin-top:2px}
.tm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}
.tm-icon-btn{background:rgba(var(--accent-secondary-rgb),0.06);border:1px solid rgba(var(--accent-secondary-rgb),0.12);border-radius:14px;padding:14px 8px 10px;color:rgba(var(--accent-secondary-rgb),0.85);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:6px;font-size:11px;text-align:center;transition:all .2s}
.tm-icon-btn:active{background:rgba(var(--accent-secondary-rgb),0.14);border-color:rgba(var(--accent-secondary-rgb),0.3)}
.tm-row-btn{display:flex;align-items:center;gap:14px;width:100%;background:none;border:none;border-bottom:1px solid rgba(255,255,255,0.06);padding:14px 0;color:#fff;cursor:pointer;font-size:14px;transition:color .15s}
.tm-row-btn:active{color:var(--accent-secondary)}
.eq-presets{display:flex;gap:6px;flex-wrap:wrap}
.eq-preset-btn{background:rgba(var(--accent-secondary-rgb),0.03);border:1px solid rgba(var(--accent-secondary-rgb),0.12);border-radius:20px;color:rgba(255,255,255,.4);cursor:pointer;font-size:12px;padding:6px 14px;white-space:nowrap;transition:all .25s;position:relative;overflow:hidden}
.eq-preset-btn::after{content:'';position:absolute;inset:0;border-radius:20px;background:radial-gradient(circle at 50% 0%,rgba(var(--accent-secondary-rgb),0.15),transparent 70%);opacity:0;transition:opacity .25s}
.eq-preset-btn:hover{border-color:rgba(var(--accent-secondary-rgb),0.35);color:rgba(var(--accent-secondary-rgb),.7)}
.eq-preset-btn:hover::after{opacity:1}
.eq-preset-btn.active{background:rgba(var(--accent-secondary-rgb),0.10);border-color:var(--accent-secondary);color:var(--accent-secondary);box-shadow:0 0 12px rgba(var(--accent-secondary-rgb),0.5),inset 0 0 10px rgba(var(--accent-secondary-rgb),0.12);animation:eq-preset-pulse 2.5s ease-in-out infinite}
.eq-preset-btn.active::after{opacity:1}
@keyframes eq-preset-pulse{0%,100%{box-shadow:0 0 10px rgba(var(--accent-secondary-rgb),0.4),inset 0 0 8px rgba(var(--accent-secondary-rgb),0.1)}50%{box-shadow:0 0 18px rgba(var(--accent-secondary-rgb),0.7),inset 0 0 14px rgba(var(--accent-secondary-rgb),0.2)}}

/* Playlist horizontal scroll */
.pl-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;scrollbar-width:none;-ms-overflow-style:none;cursor:grab}
.pl-scroll::-webkit-scrollbar{display:none}
.pl-scroll:active{cursor:grabbing}
.pl-scroll img,.pl-scroll *{-webkit--webkit-user-select:none;user-select:none}
.pl-scroll .pl-card,.pl-scroll .pl-card-img,.pl-scroll .pl-card-info,.pl-scroll .pl-card-play{pointer-events:auto}
.pl-card{flex-shrink:0;width:140px;cursor:pointer;background:var(--card);border:1px solid var(--border);border-radius:16px;text-align:left;padding:0;overflow:hidden}
.pl-card-img{width:140px;height:130px;object-fit:cover;background:var(--surface2);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:40px}
.pl-card-img img{width:100%;height:100%;object-fit:cover}
.pl-card-play{position:absolute;bottom:8px;right:8px;width:36px;height:36px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,.4);pointer-events:auto;cursor:pointer}
.pl-card-info{padding:8px 10px 10px}
.pl-card-title{font-size:13px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.pl-card-sub{font-size:11px;color:var(--text2);margin-top:3px}
/* Stat card */
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px 10px;text-align:center}
/* Name dialog */
.dialog-overlay{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;transition:opacity .2s;pointer-events:none}
.dialog-overlay.open{opacity:1;pointer-events:all}
.dialog-box{background:#1e1e1e;border-radius:16px;padding:20px;width:100%;max-width:360px;transform:scale(.95);transition:transform .2s}
.dialog-overlay.open .dialog-box{transform:scale(1)}
.dialog-title{font-size:16px;font-weight:700;color:#fff;margin-bottom:14px}
.dialog-input{width:100%;background:#2a2a2a;border:1px solid #444;border-radius:10px;padding:12px 14px;color:#fff;font-size:15px;outline:none}
.dialog-input:focus{border-color:var(--accent)}
.dialog-actions{display:flex;gap:10px;margin-top:14px}
.dialog-btn{flex:1;padding:11px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer}
.dialog-btn.cancel{background:#333;color:var(--text2)}
.dialog-btn.confirm{background:var(--accent);color:#000}

/* ── Accent glow effects ─────────────────────────────────────────────────── */
/* Play button */
.ctrl-btn.play-btn{box-shadow:0 0 16px rgba(var(--accent-rgb),.45),0 4px 20px rgba(0,0,0,.4)}
.fs-play-btn{box-shadow:0 0 20px rgba(var(--accent-rgb),.5),0 4px 24px rgba(0,0,0,.5)}
/* Progress fill */
.progress-fill{box-shadow:0 0 8px rgba(var(--accent-rgb),.6)}
.fs-prog-fill{box-shadow:0 0 8px rgba(var(--accent-rgb),.6)}
/* Active nav item */
.nb.active svg{filter:drop-shadow(0 0 6px rgba(var(--accent-rgb),.7))}
/* Active track */

/* Search button */
.search-btn{box-shadow:0 0 12px rgba(var(--accent-rgb),.3)}
/* Wave banner arrow */
#page-profile [style*="background:var(--accent)"],
.player [style*="background:var(--accent)"]{box-shadow:0 0 10px rgba(var(--accent-rgb),.5)}
/* Accent text glow for active tabs */
.nb.active{text-shadow:0 0 8px rgba(var(--accent-rgb),.4)}
/* EQ preset active — handled in main rule above */

/* ── Playing track highlight ─────────────────────────────────────────────── */
.track-item.playing {
  background: transparent;
  border: none;
  box-shadow: none;
  position: relative;
  -webkit-transform-style: preserve-3d;transform-style:preserve-3d;
}
.track-item.playing .track-title {
  color: var(--accent);
  text-shadow: 0 0 5px rgba(var(--accent-rgb),.8), 0 0 12px rgba(var(--accent-rgb),.4);
  padding: 2px 4px;
  margin: -2px -4px;
  -webkit-backface-visibility: hidden;backface-visibility:hidden;
}
.track-item.playing .track-info {
  filter: none;
}
/* Playlist page playing track */
.pl-page-track.playing .pl-track-title {
  color: var(--accent) !important;
  text-shadow: 0 0 5px rgba(var(--accent-rgb),.8), 0 0 12px rgba(var(--accent-rgb),.4);
  padding: 2px 4px;
  margin: -2px -4px;
  -webkit-backface-visibility: hidden;backface-visibility:hidden;
}
.pl-page-track.playing > div:first-child {
  position: relative;
  -webkit-backface-visibility: hidden;backface-visibility:hidden;
  transform: translate3d(0,0,0);
  will-change: transform;
}
.pl-page-track.playing > div:first-child::after {
  content: '';
  position: absolute;
  inset: -8px;
  background: rgba(var(--accent-rgb),.45);
  filter: blur(12px);
  border-radius: 50%;
  z-index: -1;
  pointer-events: none;
  -webkit-backface-visibility: hidden;backface-visibility:hidden;
  transform: translate3d(0,0,0);
}
.track-item.playing .track-thumb,
.track-item.playing .track-ph {
  -webkit-transform: translate3d(0,0,0);
  transform: translate3d(0,0,0);
}
.track-item.playing > div:first-child {
  position: relative;
  -webkit-transform: translate3d(0,0,0);
  transform: translate3d(0,0,0);
}
.track-item.playing > div:first-child::before {
  content: '';
  position: absolute;
  inset: -10px;
  background: rgba(var(--accent-rgb),.4);
  filter: blur(14px);
  border-radius: 50%;
  z-index: -1;
  pointer-events: none;
  transform: translate3d(0,0,0);
}
@keyframes playing-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: .6; }
}
.track-item.playing .track-dur {
  color: var(--accent);
  animation: playing-pulse 2s ease-in-out infinite;
}

/* Volume control (desktop) */
.vol-wrap{position:relative;display:flex;align-items:center}
.vol-popup{display:none;position:absolute;bottom:48px;right:0;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;padding:10px 8px;box-shadow:0 4px 20px rgba(0,0,0,.6);width:44px;z-index:500}
.vol-popup.open{display:flex;flex-direction:column;align-items:center;gap:8px}
.vol-slider-wrap{height:90px;width:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;user-select:none;position:relative}
.vol-track{position:relative;width:4px;height:90px;background:#333;border-radius:2px;overflow:hidden;flex-shrink:0}
.vol-fill{position:absolute;bottom:0;left:0;width:100%;background:var(--accent);border-radius:2px}
.vol-thumb{position:absolute;left:50%;width:12px;height:12px;background:var(--accent);border-radius:50%;transform:translateX(-50%);box-shadow:0 0 6px rgba(var(--accent-rgb),.5);pointer-events:none}
.vol-pct{font-size:10px;color:var(--text2);width:100%;text-align:center}
.vol-slider-wrap{height:80px;display:flex;align-items:center;justify-content:center}
.vol-slider{-webkit-appearance:none;appearance:none;width:80px;height:4px;background:#333;border-radius:2px;outline:none;cursor:pointer;transform:rotate(-90deg)}
.vol-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 0 6px rgba(var(--accent-rgb),.5)}
.vol-pct{font-size:11px;color:var(--text2);width:100%;text-align:center}

/* Dynamic accent color from album art */
.player{transition:background .5s ease}
.fs-bg{transition:background .5s ease}

/* 📱 SMARTPHONE RESPONSIVENESS & iOS SAFARI FIXES */
html.is-mobile .vol-wrap, html.is-mobile .fs-vol-wrap { display: none !important; }

html.is-mobile .player.playing::before {
  inset: -10px;
  background: rgba(var(--accent-rgb),.4);
  filter: blur(14px);
  -webkit-filter: blur(14px);
  transform: translate3d(0,0,0);
  -webkit-transform: translate3d(0,0,0);
}
html.is-mobile .fs-cover-wrap.playing::before {
  transform: translate3d(0,0,0);
  -webkit-transform: translate3d(0,0,0);
  filter: blur(35px);
  -webkit-filter: blur(35px);
}
html.is-mobile .track-thumb-wrap.playing::before {
  transform: translate3d(0,0,0);
  -webkit-transform: translate3d(0,0,0);
}
html.is-mobile .player {
  overflow: hidden;
  left: 4px; right: 4px; bottom: 74px; /* Slightly wider on mobile */
}

/* Settings helpers */
body.no-animations *, 
body.no-animations *::before, 
body.no-animations *::after {
  transition: none !important;
  animation: none !important;
}
body.hide-dur .track-dur {
  display: none !important;
}

/* Admin Password Modal (Neon Accent) */
.admin-modal-overlay {
  position: fixed; inset: 0; z-index: 2000;
  background: rgba(0,0,0,0.85); backdrop-filter: blur(10px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none; transition: opacity .3s ease;
}
.admin-modal-overlay.open { opacity: 1; pointer-events: all; }
.admin-modal-box {
  background: #111; border: 1px solid rgba(var(--accent-rgb), 0.3);
  border-radius: 24px; padding: 28px; width: 90%; max-width: 340px;
  box-shadow: 0 0 40px rgba(var(--accent-rgb), 0.15), inset 0 0 20px rgba(var(--accent-rgb), 0.05);
  transform: translateY(20px); transition: transform .4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  text-align: center;
}
.admin-modal-overlay.open .admin-modal-box { transform: translateY(0); }
.admin-modal-icon {
  width: 56px; height: 56px; background: rgba(var(--accent-rgb), 0.1);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  margin: 0 auto 16px; color: var(--accent);
  box-shadow: 0 0 15px rgba(var(--accent-rgb), 0.3);
}
.admin-modal-title { font-size: 18px; font-weight: 800; color: #fff; margin-bottom: 8px; letter-spacing: -0.02em; }
.admin-modal-sub { font-size: 13px; color: var(--text2); margin-bottom: 20px; line-height: 1.4; }
.admin-modal-input {
  width: 100%; background: #1a1a1a; border: 1.5px solid #333;
  border-radius: 14px; padding: 14px; color: #fff; font-size: 16px;
  outline: none; text-align: center; margin-bottom: 16px;
  transition: border-color .2s, box-shadow .2s;
}
.admin-modal-input:focus { border-color: var(--accent); box-shadow: 0 0 12px rgba(var(--accent-rgb), 0.3); }
.admin-modal-btn {
  width: 100%; background: var(--accent); color: #000;
  border: none; border-radius: 14px; padding: 14px;
  font-size: 15px; font-weight: 700; cursor: pointer;
  transition: transform .2s, opacity .2s;
  box-shadow: 0 4px 15px rgba(var(--accent-rgb), 0.3);
}
.admin-modal-btn:active { transform: scale(0.97); opacity: 0.9; }

/* ── Milkdrop Preset Menu ────────────────────────────────────────────────── */
.preset-category {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text2);
  margin-top: 20px;
  margin-bottom: 8px;
  padding: 0 4px;
  font-weight: 700;
}
.preset-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.7);
  font-size: 14px;
  cursor: pointer;
  transition: all 0.2s;
  margin: 0 -16px;
}
.preset-item:active { color: var(--accent); background: rgba(255,255,255,0.02); }
.preset-item.active {
  color: var(--accent);
  font-weight: 700;
  background: rgba(var(--accent-rgb), 0.08);
  border-left: 3px solid var(--accent);
}
.preset-item.current {
  border-left: 3px solid var(--accent-secondary);
  background: rgba(var(--accent-secondary-rgb), 0.05);
  color: #fff;
}
.preset-item.auto {
  color: var(--accent-secondary);
  font-weight: 700;
  border-bottom: 1px solid rgba(var(--accent-secondary-rgb), 0.2);
  background: rgba(var(--accent-secondary-rgb), 0.03);
  padding: 14px 16px;
}
.preset-item:last-child { border-bottom: none; }

.preset-fav-btn {
  background: none !important;
  border: none !important;
  color: rgba(255,255,255,0.2) !important;
  font-size: 20px;
  cursor: pointer;
  padding: 4px 8px;
  line-height: 1;
  transition: all 0.2s;
  -webkit-tap-highlight-color: transparent;
  outline: none;
  box-shadow: none !important;
}
.preset-fav-btn.active {
  color: #ffb300 !important;
  text-shadow: 0 0 10px rgba(255,179,0,0.4);
  transform: scale(1.1);
}
.preset-fav-btn:active { transform: scale(0.9); }