/* ═══════════════════════════════════════════════════════════════
   Crushe Music v5 — Auth + Likes + Playlists + Spotify UI
   ═══════════════════════════════════════════════════════════════ */
:root{
  --bg:#0a0a0f;--bg2:#141420;--bg3:#1c1c2e;
  --card:rgba(255,255,255,.04);--card-h:rgba(255,255,255,.08);
  --glass:rgba(255,255,255,.06);--border:rgba(255,255,255,.07);
  --text:#fff;--text2:#b0b0c0;--text3:#5a5a70;
  --accent:#8b5cf6;--accent-g:rgba(139,92,246,.25);
  --green:#1db954;--green-g:rgba(29,185,84,.3);
  --pink:#ec4899;--red:#ef4444;
  --r:14px;--t:.25s ease;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --sab:env(safe-area-inset-bottom,0px);
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100dvh;overflow-x:hidden;padding-bottom:calc(70px + var(--sab))}
body.fp-open{overflow:hidden}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:3px}
.bg-orb{position:fixed;border-radius:50%;filter:blur(100px);opacity:.1;pointer-events:none;z-index:0;animation:orbF 20s ease-in-out infinite}
.bg-orb-1{width:450px;height:450px;background:var(--accent);top:-180px;right:-80px}
.bg-orb-2{width:350px;height:350px;background:var(--pink);bottom:-100px;left:-80px;animation-delay:-10s}
@keyframes orbF{0%,100%{transform:translate(0,0)}50%{transform:translate(30px,-20px)}}

/* ═══ Header ═══ */
header{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:rgba(10,10,15,.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);gap:8px}
.logo{display:flex;align-items:center;gap:8px;cursor:pointer;flex-shrink:0}
.logo-icon{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--pink));display:flex;align-items:center;justify-content:center;font-size:14px;color:#fff}
.logo h1{font-size:14px;font-weight:800;background:linear-gradient(135deg,#fff,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
nav{display:flex;gap:2px;background:var(--glass);border-radius:8px;padding:3px;border:1px solid var(--border);overflow-x:auto;flex-shrink:1}
.nav-btn{background:none;border:none;color:var(--text2);font-family:var(--font);font-size:11px;font-weight:600;padding:5px 10px;border-radius:6px;cursor:pointer;transition:var(--t);white-space:nowrap}
.nav-btn:hover{color:#fff;background:rgba(255,255,255,.05)}
.nav-btn.active{color:#fff;background:var(--accent)}

/* Header User */
.header-user{display:flex;align-items:center;gap:8px;flex-shrink:0}
.auth-btn{background:var(--green);border:none;color:#fff;font-family:var(--font);font-size:11px;font-weight:700;padding:6px 14px;border-radius:20px;cursor:pointer;transition:var(--t)}
.auth-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px var(--green-g)}
.user-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--green));display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;cursor:pointer;color:#fff;border:2px solid rgba(255,255,255,.15)}
.user-menu{position:absolute;top:50px;right:12px;background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:8px;min-width:160px;z-index:110;display:none;box-shadow:0 8px 32px rgba(0,0,0,.4)}
.user-menu.open{display:block}
.um-item{display:block;width:100%;padding:8px 12px;background:none;border:none;color:var(--text2);font-family:var(--font);font-size:12px;text-align:left;border-radius:6px;cursor:pointer;transition:var(--t)}
.um-item:hover{background:rgba(255,255,255,.06);color:#fff}

/* ═══ Auth Modal ═══ */
.auth-modal{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center}
.auth-overlay{position:absolute;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(8px)}
.auth-card{position:relative;width:92%;max-width:380px;background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:32px 28px;z-index:1;text-align:center}
.auth-close{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--text3);font-size:18px;cursor:pointer;padding:4px}
.auth-logo{font-size:36px;margin-bottom:12px}
.auth-card h2{font-size:18px;font-weight:800;margin-bottom:4px}
.auth-sub{font-size:12px;color:var(--text3);margin-bottom:20px}
.auth-field{margin-bottom:12px;text-align:left}
.auth-field label{display:block;font-size:11px;font-weight:600;color:var(--text2);margin-bottom:4px}
.auth-field input{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font);font-size:13px;outline:none;transition:var(--t)}
.auth-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-g)}
.auth-error{color:var(--red);font-size:12px;margin:8px 0;min-height:16px}
.auth-submit{width:100%;padding:11px;background:var(--green);border:none;border-radius:24px;color:#fff;font-family:var(--font);font-size:14px;font-weight:700;cursor:pointer;transition:var(--t)}
.auth-submit:hover{box-shadow:0 4px 16px var(--green-g);transform:scale(1.02)}
.auth-submit:disabled{opacity:.5;cursor:not-allowed}
.auth-switch{font-size:12px;color:var(--text3);margin-top:16px}
.auth-switch a{color:var(--accent);text-decoration:none;font-weight:600}

/* ═══ Add to Playlist Modal ═══ */
.atp-modal{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center}
.atp-overlay{position:absolute;inset:0;background:rgba(0,0,0,.6)}
.atp-card{position:relative;width:92%;max-width:340px;background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:20px;z-index:1}
.atp-card h3{font-size:16px;margin-bottom:12px}
.atp-list{max-height:240px;overflow-y:auto}
.atp-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:var(--t);margin-bottom:4px}
.atp-item:hover{background:rgba(255,255,255,.06)}
.atp-item-icon{font-size:16px}
.atp-item-name{font-size:13px;font-weight:500}
.atp-new,.atp-cancel{width:100%;padding:10px;border:1px solid var(--border);border-radius:10px;background:transparent;color:var(--text2);font-family:var(--font);font-size:12px;font-weight:600;cursor:pointer;margin-top:6px;transition:var(--t)}
.atp-new:hover{background:var(--green);color:#fff;border-color:var(--green)}
.atp-cancel:hover{background:rgba(255,255,255,.05)}

/* ═══ Playlist Header ═══ */
.pl-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:-8px;padding:0 20px}
.pl-header .section-title{margin-bottom:0}
.create-pl-btn{background:var(--accent);border:none;color:#fff;font-family:var(--font);font-size:11px;font-weight:700;padding:7px 16px;border-radius:20px;cursor:pointer;transition:var(--t)}
.create-pl-btn:hover{transform:scale(1.05)}
.pl-view-header{display:flex;align-items:center;gap:12px;padding:0 20px;margin-bottom:12px}
.back-btn{background:none;border:none;color:var(--text2);font-family:var(--font);font-size:13px;cursor:pointer}
.pl-del-btn{background:none;border:1px solid var(--border);color:var(--text3);font-size:12px;font-family:var(--font);padding:5px 12px;border-radius:8px;cursor:pointer;margin-left:auto;transition:var(--t)}
.pl-del-btn:hover{border-color:var(--red);color:var(--red)}

/* Playlist card */
.pl-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:16px;cursor:pointer;transition:var(--t);text-align:center}
.pl-card:hover{background:var(--card-h);transform:translateY(-2px)}
.pl-card-icon{font-size:32px;margin-bottom:8px}
.pl-card-name{font-size:13px;font-weight:600}
.pl-card-count{font-size:11px;color:var(--text3)}

/* Recent Searches */
.recent-searches{position:absolute;top:100%;left:0;right:0;background:var(--bg2);border:1px solid var(--border);border-radius:12px;margin-top:4px;padding:8px;z-index:10;max-height:200px;overflow-y:auto}
.rs-title{font-size:10px;font-weight:700;color:var(--text3);padding:4px 8px;letter-spacing:1px;text-transform:uppercase}
.rs-item{display:block;width:100%;padding:8px 10px;background:none;border:none;color:var(--text2);font-family:var(--font);font-size:12px;text-align:left;border-radius:6px;cursor:pointer;transition:var(--t)}
.rs-item:hover{background:rgba(255,255,255,.06);color:#fff}

/* ═══ Search ═══ */
.search-section{padding:16px 16px 8px;position:relative;z-index:10}
.search-container{max-width:540px;margin:0 auto;position:relative}
.search-box{display:flex;align-items:center;gap:10px;background:var(--bg3);border:1px solid var(--border);border-radius:24px;padding:9px 14px;transition:var(--t)}
.search-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-g)}
.search-icon{width:16px;height:16px;color:var(--text3);flex-shrink:0}
#search-input{flex:1;background:none;border:none;outline:none;color:var(--text);font-family:var(--font);font-size:13px}
#search-input::placeholder{color:var(--text3)}
.search-loader{width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;display:none;animation:spin .7s linear infinite}
.search-loader.visible{display:block}
@keyframes spin{to{transform:rotate(360deg)}}

/* ═══ Sections ═══ */
main section{padding:0 16px 20px;position:relative;z-index:1}
.section-title{font-size:18px;font-weight:800;margin-bottom:12px}

/* ═══ Grid ═══ */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px}

/* ═══ Card ═══ */
.song-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:var(--t);cursor:pointer;position:relative}
.song-card:hover{background:var(--card-h);transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.25)}
.song-card.active-card{border-color:var(--green);box-shadow:0 0 0 1px var(--green-g)}
.card-top{position:relative;aspect-ratio:16/9;overflow:hidden}
.card-img{width:100%;height:100%;object-fit:cover;transition:var(--t)}
.song-card:hover .card-img{transform:scale(1.05);filter:brightness(.6)}
.card-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--t)}
.song-card:hover .card-overlay{opacity:1}
.card-play{width:40px;height:40px;border-radius:50%;background:var(--green);border:none;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px var(--green-g);transition:var(--t)}
.card-play:active{transform:scale(.9)}
.card-dur{position:absolute;bottom:4px;right:4px;background:rgba(0,0,0,.75);color:#fff;font-size:9px;padding:2px 5px;border-radius:3px;font-weight:500}
.card-heart{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.5);border:none;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:var(--t);z-index:2}
.song-card:hover .card-heart{opacity:1}
.card-heart svg{width:14px;height:14px}
.card-heart.liked{opacity:1}
.card-heart.liked svg path{fill:var(--red);stroke:var(--red)}
.card-body{padding:8px 10px 3px}
.card-title{font-size:11px;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-artist{font-size:10px;color:var(--text2);margin-top:2px}
.card-btns{display:flex;gap:3px;padding:3px 8px 6px}
.card-btn{flex:1;padding:4px 2px;border-radius:5px;border:1px solid var(--border);background:transparent;color:var(--text2);font-family:var(--font);font-size:9px;font-weight:600;cursor:pointer;transition:var(--t);text-align:center}
.card-btn:active{transform:scale(.95)}
.card-btn:hover{background:var(--green);color:#fff;border-color:var(--green)}
.card-btn.hv-pink:hover{background:var(--pink);border-color:var(--pink)}

/* ═══ Mini Player ═══ */
.mini-player{position:fixed;bottom:0;left:0;right:0;z-index:200;background:rgba(18,18,28,.97);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--border);display:none;padding-bottom:var(--sab)}
.mini-player.visible{display:block}
.mini-progress{height:2px;background:rgba(255,255,255,.06)}
.mini-progress-fill{height:100%;background:var(--green);width:0%;transition:width .4s linear}
.mini-content{display:flex;align-items:center;padding:6px 12px;gap:8px;cursor:pointer}
.mini-thumb{width:40px;height:40px;border-radius:6px;object-fit:cover;flex-shrink:0}
.mini-info{flex:1;min-width:0}
.mini-title{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-artist{font-size:10px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-like{background:none;border:none;color:var(--text3);padding:4px;cursor:pointer;display:flex;transition:var(--t)}
.mini-like.liked svg path{fill:var(--red);stroke:var(--red)}

/* Mini Equalizer */
.eq-bars{display:flex;align-items:flex-end;gap:2px;height:18px;margin-right:2px}
.eq-bars span{width:3px;background:var(--green);border-radius:1px;animation:eqBar 1.1s ease-in-out infinite}
.eq-bars span:nth-child(1){height:5px;animation-delay:0s}
.eq-bars span:nth-child(2){height:12px;animation-delay:.15s}
.eq-bars span:nth-child(3){height:8px;animation-delay:.3s}
.eq-bars span:nth-child(4){height:16px;animation-delay:.45s}
.eq-bars.paused span{animation-play-state:paused}
@keyframes eqBar{0%,100%{height:3px}50%{height:18px}}
.mini-ctrls{display:flex;align-items:center;gap:0}
.m-btn{background:none;border:none;color:var(--text2);padding:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--t)}
.m-btn:active{transform:scale(.85)}
.m-play{color:#fff}

/* ═══════════════════════════════════════════════════════════
   FULL PLAYER
   ═══════════════════════════════════════════════════════════ */
.full-player{position:fixed;inset:0;z-index:300;transform:translateY(100%);transition:transform .4s cubic-bezier(.32,.72,.32,1);overflow:hidden;display:flex;flex-direction:column}
.full-player.open{transform:translateY(0)}
.fp-bg{position:absolute;inset:-40px;background-size:cover;background-position:center;filter:blur(60px) saturate(1.8) brightness(.35);z-index:0;transition:background-image .5s}
.fp-bg-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.3) 0%,rgba(0,0,0,.6) 50%,rgba(0,0,0,.85) 100%);z-index:1}
.fp-scroll{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;overflow-y:auto;padding-bottom:var(--sab)}

/* Header */
.fp-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 4px;flex-shrink:0}
.fp-close,.fp-menu{background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;padding:4px;display:flex;align-items:center;transition:var(--t)}
.fp-close:hover,.fp-menu:hover{color:#fff}
.fp-from{font-size:9px;font-weight:700;color:rgba(255,255,255,.5);letter-spacing:1.5px;text-transform:uppercase}
.fp-header-btns{display:flex;align-items:center;gap:2px}
.fp-menu.active{color:var(--green)}
.fp-menu.liked svg path{fill:var(--red);stroke:var(--red)}

/* Like heart animation */
@keyframes heartPop{0%{transform:scale(1)}30%{transform:scale(1.3)}60%{transform:scale(.9)}100%{transform:scale(1)}}
.heart-pop{animation:heartPop .4s ease}

/* Vinyl Disc */
.fp-art-section{flex:1;display:flex;align-items:center;justify-content:center;padding:6px 24px;min-height:0}
.fp-vinyl{width:100%;max-width:280px;aspect-ratio:1;position:relative}
.vinyl-disc{width:100%;height:100%;border-radius:50%;background:radial-gradient(circle,#1a1a2a 30%,#0d0d1a 31%,#1a1a2a 32%,#0d0d1a 50%,#1a1a2a 51%,#0d0d1a 70%,#1a1a2a 71%);box-shadow:0 0 60px rgba(0,0,0,.5),0 0 120px rgba(139,92,246,.1);animation:none;position:relative;overflow:hidden}
.vinyl-disc.spinning{animation:vinylSpin 3s linear infinite}
.vinyl-grooves{position:absolute;inset:0;border-radius:50%;background:repeating-radial-gradient(circle,transparent 0px,transparent 3px,rgba(255,255,255,.03) 3px,rgba(255,255,255,.03) 4px);pointer-events:none}
.vinyl-cover{position:absolute;top:50%;left:50%;width:55%;height:55%;transform:translate(-50%,-50%);border-radius:50%;object-fit:cover;border:3px solid rgba(255,255,255,.1);box-shadow:0 0 20px rgba(0,0,0,.4)}
@keyframes vinylSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}

/* Song Info */
.fp-info{padding:4px 24px 2px;flex-shrink:0;text-align:center}
.fp-title{font-size:18px;font-weight:800;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fp-artist{font-size:13px;color:rgba(255,255,255,.6);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Lyrics */
.fp-lyrics{display:none;flex:0;overflow:hidden;transition:all .3s ease}
.fp-lyrics.active{display:block;flex:1;min-height:100px;max-height:220px}
.lyrics-scroll{height:100%;overflow-y:auto;padding:0 24px;mask-image:linear-gradient(transparent 0%,#000 10%,#000 90%,transparent 100%);-webkit-mask-image:linear-gradient(transparent 0%,#000 10%,#000 90%,transparent 100%)}
.lyrics-content{padding:12px 0}
.lyrics-line{font-size:15px;font-weight:600;color:rgba(255,255,255,.2);padding:5px 0;transition:all .4s ease;cursor:pointer;line-height:1.5}
.lyrics-line.active-line{color:#fff;font-size:18px;transform:scale(1.02);text-shadow:0 0 20px rgba(29,185,84,.3)}
.lyrics-line.past-line{color:rgba(255,255,255,.35)}
.lyrics-line:hover{color:rgba(255,255,255,.5)}
.lyrics-placeholder{text-align:center;padding:20px;color:var(--text3);font-size:13px}
.lyrics-loading{text-align:center;padding:20px;color:var(--green);font-size:12px}
.fp-art-section.lyrics-mode{flex:0 0 auto;padding:6px 24px 0}
.fp-art-section.lyrics-mode .fp-vinyl{max-width:140px}

/* Equalizer */
.fp-equalizer{display:flex;align-items:flex-end;justify-content:center;gap:3px;height:28px;padding:6px 24px 2px;flex-shrink:0}
.fp-equalizer span{width:3px;border-radius:2px;background:var(--green);opacity:.6;animation:fpEq 1.3s ease-in-out infinite}
.fp-equalizer span:nth-child(1){height:6px;animation-delay:0s}
.fp-equalizer span:nth-child(2){height:16px;animation-delay:.07s}
.fp-equalizer span:nth-child(3){height:10px;animation-delay:.14s}
.fp-equalizer span:nth-child(4){height:24px;animation-delay:.21s}
.fp-equalizer span:nth-child(5){height:14px;animation-delay:.28s}
.fp-equalizer span:nth-child(6){height:20px;animation-delay:.35s}
.fp-equalizer span:nth-child(7){height:8px;animation-delay:.42s}
.fp-equalizer span:nth-child(8){height:18px;animation-delay:.49s}
.fp-equalizer span:nth-child(9){height:26px;animation-delay:.56s}
.fp-equalizer span:nth-child(10){height:12px;animation-delay:.63s}
.fp-equalizer span:nth-child(11){height:20px;animation-delay:.7s}
.fp-equalizer span:nth-child(12){height:6px;animation-delay:.77s}
.fp-equalizer span:nth-child(13){height:22px;animation-delay:.84s}
.fp-equalizer span:nth-child(14){height:10px;animation-delay:.91s}
.fp-equalizer span:nth-child(15){height:16px;animation-delay:.98s}
.fp-equalizer span:nth-child(16){height:26px;animation-delay:1.05s}
.fp-equalizer span:nth-child(17){height:8px;animation-delay:1.12s}
.fp-equalizer span:nth-child(18){height:20px;animation-delay:.06s}
.fp-equalizer span:nth-child(19){height:12px;animation-delay:.13s}
.fp-equalizer span:nth-child(20){height:18px;animation-delay:.2s}
.fp-equalizer.paused span{animation-play-state:paused;opacity:.2}
@keyframes fpEq{0%,100%{height:3px}50%{height:28px}}

/* Progress */
.fp-progress{padding:2px 24px;flex-shrink:0}
.fp-seek{width:100%;-webkit-appearance:none;appearance:none;height:3px;border-radius:2px;background:rgba(255,255,255,.15);outline:none;cursor:pointer}
.fp-seek::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 0 6px rgba(0,0,0,.3)}
.fp-times{display:flex;justify-content:space-between;font-size:10px;color:rgba(255,255,255,.4);margin-top:3px;font-weight:500}

/* Controls */
.fp-controls{display:flex;align-items:center;justify-content:center;gap:16px;padding:8px 24px 6px;flex-shrink:0}
.fp-ctrl{background:none;border:none;color:rgba(255,255,255,.6);cursor:pointer;padding:4px;transition:var(--t);display:flex;align-items:center;justify-content:center}
.fp-ctrl:active{transform:scale(.88)}
.fp-ctrl:hover{color:#fff}
.fp-ctrl-sm{opacity:.7}
.fp-ctrl.active-ctrl{color:var(--green)!important;opacity:1}
.fp-ctrl.active-ctrl svg{filter:drop-shadow(0 0 6px var(--green-g))}
.fp-ctrl-play{width:56px;height:56px;border-radius:50%;background:#fff;color:#000!important;box-shadow:0 4px 24px rgba(255,255,255,.15)}
.fp-ctrl-play:hover{transform:scale(1.05)}
.fp-ctrl-play:active{transform:scale(.92)}

/* Volume */
.fp-volume{display:flex;align-items:center;gap:6px;padding:0 24px 12px;justify-content:center}
.fp-vol-icon{color:rgba(255,255,255,.4);flex-shrink:0}
.fp-vol-slider{width:120px;-webkit-appearance:none;appearance:none;height:3px;border-radius:2px;background:rgba(255,255,255,.15);outline:none;cursor:pointer}
.fp-vol-slider::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:#fff;cursor:pointer}

/* ═══ Queue ═══ */
.fp-queue{position:absolute;inset:0;background:rgba(10,10,15,.97);z-index:10;transform:translateX(100%);transition:transform .3s ease;overflow-y:auto;display:flex;flex-direction:column;backdrop-filter:blur(20px)}
.fp-queue.open{transform:translateX(0)}
.fpq-head{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.fpq-head h3{font-size:16px;font-weight:700}
.fpq-close{background:none;border:none;color:var(--text2);cursor:pointer;display:flex;padding:4px}
.fpq-list{flex:1;overflow-y:auto;padding:6px 10px}
.q-item{display:flex;align-items:center;gap:8px;padding:6px;border-radius:8px;cursor:pointer;transition:var(--t)}
.q-item:hover{background:rgba(255,255,255,.05)}
.q-item.q-active{background:rgba(29,185,84,.1);border-left:3px solid var(--green)}
.q-num{width:18px;text-align:center;font-size:11px;color:var(--text3);font-weight:600;flex-shrink:0}
.q-item.q-active .q-num{color:var(--green)}
.q-thumb{width:36px;height:36px;border-radius:4px;object-fit:cover;flex-shrink:0}
.q-info{flex:1;min-width:0}
.q-title{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.q-artist{font-size:10px;color:var(--text3)}
.q-dur{font-size:10px;color:var(--text3);flex-shrink:0}
.q-rm{background:none;border:none;color:var(--text3);cursor:pointer;font-size:12px;padding:4px;opacity:0;transition:var(--t)}
.q-item:hover .q-rm{opacity:1}
.q-rm:hover{color:var(--red)}
.q-empty{text-align:center;padding:32px 16px;color:var(--text3);font-size:12px}

/* ═══ Video Modal ═══ */
.video-modal{position:fixed;inset:0;z-index:400;display:flex;align-items:center;justify-content:center}
.vm-bg{position:absolute;inset:0;background:rgba(0,0,0,.88);backdrop-filter:blur(6px)}
.vm-box{position:relative;width:92%;max-width:840px;background:var(--bg2);border-radius:var(--r);overflow:hidden;border:1px solid var(--border)}
.vm-close{position:absolute;top:10px;right:10px;z-index:10;width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,.6);border:none;color:#fff;font-size:14px;cursor:pointer}
#video-player{width:100%;max-height:70vh;background:#000}
.vm-info{padding:10px 14px;display:flex;align-items:center;gap:10px}
.vm-info h3{flex:1;font-size:13px;font-weight:600}
.vm-dl{padding:6px 14px;border-radius:8px;background:var(--green);color:#fff;text-decoration:none;font-size:11px;font-weight:600;white-space:nowrap}

/* ═══ Toast ═══ */
.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(16px);background:var(--bg3);color:#fff;padding:8px 20px;border-radius:20px;font-size:12px;font-weight:500;z-index:500;opacity:0;pointer-events:none;transition:all .3s;border:1px solid var(--border)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ═══ Utils ═══ */
.empty-state{grid-column:1/-1;text-align:center;padding:32px;color:var(--text3);font-size:13px}
.loading-ph{grid-column:1/-1;display:flex;flex-direction:column;align-items:center;gap:10px;padding:32px;color:var(--text3)}
.spinner{width:22px;height:22px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}

/* ═══ Responsive ═══ */
@media(max-width:768px){
  header{flex-wrap:wrap;padding:6px 10px;gap:6px}
  nav{width:100%;justify-content:center;overflow-x:auto}
  .search-section{padding:10px 10px 6px}
  main section{padding:0 10px 16px}
  .section-title{font-size:16px;margin-bottom:10px}
  .grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}
  .card-body{padding:6px 8px 2px}
  .card-title{font-size:10px}
  .card-btns{gap:2px;padding:2px 6px 4px}
  .card-btn{font-size:8px;padding:3px 1px}
  .fp-art-section{padding:6px 20px}
  .fp-vinyl{max-width:220px}
  .fp-info{padding:4px 20px 2px}
  .fp-title{font-size:16px}
  .fp-progress{padding:2px 20px}
  .fp-controls{padding:6px 20px;gap:14px}
  .fp-volume{padding:0 20px 10px}
  .lyrics-scroll{padding:0 20px}
  .lyrics-line{font-size:13px}
  .lyrics-line.active-line{font-size:16px}
  .pl-header{padding:0 10px}
  .pl-view-header{padding:0 10px}
}

@media(max-width:480px){
  .logo h1{font-size:12px}
  .logo-icon{width:28px;height:28px;font-size:12px}
  .nav-btn{font-size:10px;padding:4px 8px}
  #search-input{font-size:12px}
  .section-title{font-size:14px}
  .grid{grid-template-columns:1fr 1fr;gap:6px}
  .card-play{width:34px;height:34px;font-size:14px}
  .fp-vinyl{max-width:180px}
  .fp-title{font-size:14px}
  .fp-artist{font-size:11px}
  .fp-controls{gap:10px}
  .fp-ctrl-play{width:48px;height:48px}
  .fp-ctrl svg{width:22px;height:22px}
  .fp-equalizer{height:20px;gap:2px}
  .fp-equalizer span{width:2px}
  body{padding-bottom:calc(60px + var(--sab))}
  .fp-art-section.lyrics-mode .fp-vinyl{max-width:100px}
  .lyrics-line{font-size:12px}
  .lyrics-line.active-line{font-size:14px}
  .auth-card{padding:24px 20px}
}

@supports(padding:max(0px)){
  .mini-player{padding-bottom:max(var(--sab),2px)}
  body{padding-bottom:max(calc(70px + var(--sab)),72px)}
}
