@charset "UTF-8";
@font-face{font-family:'SF Pro Display';src:url('/api/font/SF-Pro-Display-Regular.woff2') format('woff2'),url('/api/font/SF-Pro-Display-Regular.otf') format('opentype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'SF Pro Display';src:url('/api/font/SFPRODISPLAYMEDIUM.woff2') format('woff2'),url('/api/font/SFPRODISPLAYMEDIUM.OTF') format('opentype');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'SF Pro Display';src:url('/api/font/SFPRODISPLAYBOLD.woff2') format('woff2'),url('/api/font/SFPRODISPLAYBOLD.OTF') format('opentype');font-weight:700;font-style:normal;font-display:swap}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  --bg:#0d0d0f;--surface:#16161a;--surface2:#1e1e24;--surface3:#26262e;
  --border:rgba(255,255,255,0.06);--border2:rgba(255,255,255,0.12);
  --text:#f0f0f5;--muted:#7a7a8e;--accent:#c8a86b;--accent2:#e8c88b;
  --danger:#e05252;--radius:12px;--player-h:85px; 
}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:'SF Pro Display',-apple-system,sans-serif;overscroll-behavior:none}
#app{display:flex;flex-direction:column;height:100%;height:100dvh}
#header{padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0;display:flex;align-items:center;gap:10px}
#header h1{font-size:17px;font-weight:500;letter-spacing:0.02em;flex:1}
#search-wrap{position:relative;display:flex;align-items:center}
#search{background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:13px;padding:6px 10px 6px 28px;width:160px;outline:none;transition:border-color .2s,width .2s}
#search:focus{border-color:var(--border2);width:200px}
#search-icon{position:absolute;left:9px;color:var(--muted);pointer-events:none;font-size:13px}
#sort-btn{background:var(--surface2);border:1px solid var(--border);color:var(--muted);border-radius:8px;padding:6px 9px;font-size:11px;cursor:pointer;font-family:'SF Pro Display',-apple-system,sans-serif;white-space:nowrap;transition:color .15s}
#sort-btn:hover{color:var(--text)}
#tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}
.tab{flex:1;padding:10px;font-size:13px;text-align:center;cursor:pointer;color:var(--muted);border-bottom:2px solid transparent;transition:color .15s,border-color .15s}
.tab.active{color:var(--accent);border-bottom-color:var(--accent)}
#main{flex:1;overflow-y:auto;padding-bottom:calc(var(--player-h) + 20px)}
#main::-webkit-scrollbar{width:4px}
#main::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:4px}
#view-library,#view-playlists{display:none}
#view-library.active,#view-playlists.active{display:block}
#loading,#empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:50vh;color:var(--muted);font-size:14px}
.spinner{width:28px;height:28px;border:2px solid var(--surface3);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.group-header{padding:16px 16px 6px;font-size:10px;font-family:'SF Pro Display',-apple-system,sans-serif;letter-spacing:0.1em;color:var(--muted);text-transform:uppercase;position:sticky;top:0;background:var(--bg);z-index:2;border-bottom:1px solid var(--border)}
.track{display:grid;grid-template-columns:40px 1fr auto;align-items:center;gap:10px;padding:8px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s;position:relative;user-select:none;-webkit-user-select:none}
.track:hover{background:var(--surface)}
.track:hover .track-menu-btn{opacity:1}
.track.active{background:var(--surface2)}
.track.active .track-title{color:var(--accent)}
.track.selected{background-color:var(--surface3) !important;}
.track.active.selected .track-title{color:var(--accent) !important;}
.thumb{width:40px;height:40px;border-radius:7px;background:var(--surface3);flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb-icon{font-size:16px;color:var(--muted)}
.track-info{min-width:0}
.track-title{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.track-sub{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.track-right{display:flex;align-items:center;gap:6px;flex-shrink:0}
.track-dur{font-family:'SF Pro Display',-apple-system,sans-serif;font-size:11px;color:var(--muted)}
.track-menu-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;opacity:0;transition:opacity .15s;font-size:16px;line-height:1;border-radius:4px}
.track-menu-btn:hover{color:var(--text);background:var(--surface3)}
#ctx-menu{position:fixed;background:var(--surface2);border:1px solid var(--border2);border-radius:10px;padding:6px;z-index:200;min-width:180px;display:none;box-shadow:0 8px 24px rgba(0,0,0,.4);user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}
#ctx-menu.open{display:block}
.ctx-item{padding:8px 12px;font-size:13px;cursor:pointer;border-radius:6px;display:flex;align-items:center;gap:8px;color:var(--text);user-select:none;-webkit-user-select:none}
.ctx-item:hover{background:var(--surface3)}
.ctx-item.danger{color:var(--danger)}
.ctx-sep{height:1px;background:var(--border);margin:4px 0}
.ctx-label{padding:6px 12px 2px;font-size:10px;font-family:'SF Pro Display',-apple-system,sans-serif;letter-spacing:0.08em;color:var(--muted);text-transform:uppercase;user-select:none;-webkit-user-select:none}
#playlists-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 8px}
#playlists-header h2{font-size:15px;font-weight:500}
#new-playlist-btn{background:var(--accent);color:#000;border:none;border-radius:8px;padding:6px 12px;font-size:12px;font-family:inherit;font-weight:500;cursor:pointer;transition:background .15s}
#new-playlist-btn:hover{background:var(--accent2)}
.playlist-card{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}
.playlist-card:hover{background:var(--surface)}
.playlist-icon{width:40px;height:40px;border-radius:8px;background:var(--surface3);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.playlist-info{flex:1;min-width:0}
.playlist-name{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.playlist-count{font-size:11px;color:var(--muted);margin-top:2px}
.playlist-del{background:none;border:none;color:var(--muted);cursor:pointer;padding:6px;font-size:18px;opacity:0;transition:opacity .15s}
.playlist-card:hover .playlist-del{opacity:1}
.playlist-del:hover{color:var(--danger)}
#playlist-detail{display:none}
#playlist-detail.active{display:block}
#playlist-back{display:flex;align-items:center;gap:8px;padding:12px 16px;cursor:pointer;color:var(--muted);font-size:13px;border-bottom:1px solid var(--border)}
#playlist-back:hover{color:var(--text)}
#playlist-detail-name{padding:12px 16px 4px;font-size:18px;font-weight:500}
#playlist-detail-count{padding:0 16px 12px;font-size:12px;color:var(--muted)}
#playlist-play-btn{margin:0 16px 12px;background:var(--accent);color:#000;border:none;border-radius:8px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}
#playlist-play-btn:hover{background:var(--accent2)}
#playlist-tracks{border-top:1px solid var(--border)}

/* -- Desktop player -- */
#player{position:fixed;bottom:0;left:0;right:0;height:auto;background:var(--surface);border-top:1px solid var(--border2);display:flex;flex-direction:column;padding:8px 16px calc(8px + env(safe-area-inset-bottom, 12px));gap:8px;z-index:100;touch-action:pan-y}
#player.hidden{display:none}
#expand-handle{width:36px;height:28px;margin:0 auto 2px auto;cursor:pointer;transition:color .2s,transform .2s;background:none;border:none;color:var(--muted);display:flex;align-items:center;justify-content:center;border-radius:8px}
#expand-handle:hover{color:var(--text);transform:translateY(-1px)}
#player-main{display:flex;align-items:center;justify-content:space-between;width:100%;gap:12px}
#player-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0;cursor:pointer}
#player-thumb{width:44px;height:44px;border-radius:8px;background:var(--surface3);object-fit:cover;flex-shrink:0}
#player-info{min-width:0;display:flex;flex-direction:column}
#player-title{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--accent)}
#player-artist{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#player-center{display:flex;flex-direction:column;align-items:center;gap:4px;flex:0 0 auto}
#controls{display:flex;align-items:center;gap:12px}
.ctrl-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:6px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}
.ctrl-btn:hover{color:var(--text);background:var(--surface3)}
.ctrl-btn.main{background:var(--accent);color:#000;border-radius:50%;width:40px;height:40px}
.ctrl-btn.main:hover{background:var(--accent2)}
#player-right{display:flex;align-items:center;gap:16px;flex:1;min-width:0;justify-content:flex-end}
#volume-row{display:none;align-items:center;gap:8px;width:120px;min-width:60px}
#volume-row input{height:4px;-webkit-appearance:none;appearance:none;border-radius:2px;background:var(--surface3);outline:none;cursor:pointer;flex:1;min-width:0}
#volume-row input::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:var(--accent);cursor:pointer;margin-top:-3px}
#volume-icon{font-size:14px;color:var(--muted);width:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transform:translateY(1px)}
#player-utils{display:flex;align-items:center;gap:6px;flex-shrink:0}

#progress-row{display:flex;align-items:center;gap:10px;width:100%}
#progress-row input{height:4px;-webkit-appearance:none;appearance:none;border-radius:2px;background:var(--surface3);outline:none;cursor:pointer;flex:1}
#progress-row input::-webkit-slider-runnable-track{height:4px;border-radius:2px}
#progress-row input::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--accent);cursor:pointer;margin-top:-4px;box-shadow:0 0 4px rgba(0,0,0,0.3)}
.time-label{font-family:'SF Pro Display',-apple-system,sans-serif;font-size:11px;color:var(--muted);min-width:32px}

#exp-lyrics-card-controls,
#lyrics-timing-row{display:flex;align-items:center;gap:8px}
.lyrics-timing{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 12px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.lyrics-timing-actions{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  justify-content:center;
}
.lyrics-timing-btn{
  -webkit-appearance:none;
  appearance:none;
  background:var(--surface2);
  border:1px solid var(--border);
  color:var(--muted);
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  font-family:'SF Pro Display',-apple-system,sans-serif;
  cursor:pointer;
  transition:color .15s,border-color .15s,background .15s,transform .15s;
}
.lyrics-timing-btn:hover{
  color:var(--text);
  border-color:var(--border2);
  background:var(--surface3);
}
.lyrics-timing-btn:focus,
.lyrics-timing-btn:focus-visible{
  outline:none;
  color:var(--text);
  border-color:var(--accent);
  background:var(--surface3);
}
.lyrics-timing-btn:active{
  color:var(--text);
  border-color:var(--accent);
  background:var(--surface3);
  transform:scale(.98);
}
.lyrics-timing-btn.reset{display:none}
.lyrics-timing.has-offset .lyrics-timing-btn.reset{display:inline-flex}
.lyrics-offset-display{
  font-size:11px;
  color:var(--muted);
  min-width:88px;
  text-align:center;
  white-space:nowrap;
}
  
/* -- Mobile overrides -- */
@media(max-width:768px){

html,body,#main,#expanded-player,#queue-panel,#exp-lyrics-card-scroll{
  scrollbar-width:none !important;
  -ms-overflow-style:none !important;
}
html::-webkit-scrollbar,
body::-webkit-scrollbar,
#main::-webkit-scrollbar,
#expanded-player::-webkit-scrollbar,
#queue-panel::-webkit-scrollbar,
#exp-lyrics-card-scroll::-webkit-scrollbar{
  width:0 !important;
  height:0 !important;
  display:none !important;
}

button,
.tab,
.track,
.playlist-card,
#playlist-back,
.ctx-item,
.queue-item,
.lyric-line,
#player-left,
#exp-collapse,
#exp-lyrics-card-header{
  touch-action:manipulation;
}

.track:hover{
  background:transparent !important;
}
.track:hover .track-menu-btn{
  opacity:0 !important;
}
.playlist-card:hover{
  background:transparent !important;
}
.playlist-card:hover .playlist-del{
  opacity:0 !important;
}
#queue-btn:hover,
#lyrics-btn:hover{
  color:var(--muted) !important;
  border-color:var(--border) !important;
}
.queue-item:hover{
  background:transparent !important;
}
.queue-item:hover .queue-remove{
  opacity:0 !important;
}
.track-menu-btn:hover,
.playlist-del:hover,
.queue-remove:hover,
.queue-handle:hover,
#playlist-back:hover,
#playlist-play-btn:hover,
#lyrics-close-btn:hover,
#exp-collapse:hover,
.ctx-item:hover {
  background:inherit !important;
  color:inherit !important;
}

#player{
  display:flex !important;
  flex-direction:column !important;
  height:auto !important;
  padding:12px 16px calc(10px + env(safe-area-inset-bottom, 0px)) !important;
  gap:12px !important;
  align-items:center !important;
  /* Smooth transform for swipe-to-expand animation */
  transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);
  will-change:transform;
}

/* Bigger seek thumb on mobile */
#progress-row input::-webkit-slider-thumb{
  width:20px !important;
  height:20px !important;
  margin-top:-8px !important;
  box-shadow:0 2px 8px rgba(0,0,0,.5) !important;
}
#progress-row input{
  height:4px;
  touch-action:none;
  padding:12px 0;
  margin:-12px 0;
  box-sizing:content-box;
}

/* Title hidden from mini player on mobile - tap art/handle to expand */
#player-meta-mobile{display:none !important}

#player-left,#player-center,#player-right{order:2 !important}
#player-left{
  flex:0 0 auto;
  min-width:44px;
}
#player-center{
  flex:1 1 auto;
  min-width:0;
  display:flex;
  justify-content:center;
}
#player-right{
  flex:0 0 auto;
  display:flex !important;
  flex-direction:row !important;
  gap:10px !important;
  flex-shrink:0 !important;
}

#player-utils{
  display:flex !important;
  flex-direction:row !important;
  gap:10px !important;
  flex-shrink:0 !important;
}

/* Bigger control buttons on mobile */
#controls .ctrl-btn{
  padding:8px !important;
  min-width:40px !important;
  min-height:40px !important;
}
#controls .ctrl-btn.main{
  width:48px !important;
  height:48px !important;
}

#btn-shuffle,
#btn-repeat{
  display:none !important;
}

#player-main{
  order:3 !important;
  width:100% !important;
  padding:0 4px !important;
  gap:8px !important;
}

#player-info,#volume-row{display:none !important}
.track.active,
.track.selected{
  background:transparent !important;
}
.track.active .track-title,
.track.active.selected .track-title{
  color:var(--text) !important;
}
.track,
.track *{
  -webkit-user-select:none !important;
  user-select:none !important;
  -webkit-touch-callout:none;
}

/* Queue/lyrics buttons visible on mobile mini player */
#player-utils{display:flex !important;flex-direction:row !important;gap:10px !important}

/* -- Mobile expanded player -- */
#expanded-player{
  /* Full-screen overlay, slides up from bottom */
  display:block !important;
  position:fixed;
  inset:0;
  background:var(--bg);
  z-index:200;
  overflow-y:auto;
  /* Hidden by default - transform off-screen */
  transform:translateY(100%);
  transition:transform 0.4s cubic-bezier(0.4,0,0.2,1);
  will-change:transform;
  padding:0;
  /* When open, slide in */
}
#expanded-player.open{
  transform:translateY(0) !important;
}

/* Collapse indicator pill at top */
#exp-collapse{
  display:block !important;
  position:static;
  width:40px;height:5px;
  background:var(--surface3);
  border-radius:3px;
  margin:16px auto 8px auto;
  font-size:0;
  /* override default close button */
  border:none;
  cursor:pointer;
  padding:0;
  color:transparent;
}

#exp-content{
  padding:0 20px calc(40px + env(safe-area-inset-bottom,0px));
  gap:0;
  align-items:center !important;
  width:100% !important;
  box-sizing:border-box !important;
}

#exp-main-left{
  width:100% !important;
  align-items:center !important;
}

#exp-cover-wrap{
  width:min(80vw,320px);
  margin:12px auto 20px auto !important;
  box-shadow:0 16px 48px rgba(0,0,0,.6);
  align-self:center !important;
}

#exp-info{
  text-align:center;
  width:100%;
  margin-bottom:12px !important;
  padding-bottom:0 !important;
}

#exp-title{font-size:22px}
#exp-artist{font-size:15px}

/* Fixed height lyrics area - stable for up to 4 wrapped lines */
#exp-lyrics-wrap{
  height:120px !important;
  min-height:unset !important;
  overflow:hidden !important;
  margin:4px 0 16px 0 !important;
  justify-content:flex-start !important;
  padding:4px 0 0 !important;
  flex-shrink:0 !important;
}
#exp-lyrics{
  padding-bottom:0 !important;
  overflow:visible !important;
}
#exp-lyric-current,
#exp-lyric-next{
  width:100%;
  text-align:center;
  line-height:1.3 !important;
  padding:0 8px;
}
#exp-lyric-current{
  margin-bottom:8px !important;
}

/* Hide desktop offset controls on mobile */
#exp-offset-controls{display:none !important}

#exp-utils{display:none !important}

/* Bigger expanded controls */
#exp-controls .ctrl-btn{
  padding:14px !important;
  min-width:52px !important;
  min-height:52px !important;
  border-radius:16px !important;
}
#exp-controls .ctrl-btn.main{
  width:72px !important;
  height:72px !important;
}
#exp-controls .ctrl-btn svg{
  width:28px !important;
  height:28px !important;
}
#exp-controls .ctrl-btn.main svg{
  width:34px !important;
  height:34px !important;
}

/* Bigger expanded seek thumb */
#exp-progress::-webkit-slider-thumb{
  width:20px !important;
  height:20px !important;
  margin-top:-8px !important;
}
#exp-progress{
  height:4px;
  touch-action:none;
  padding:12px 0;
  margin:-12px 0;
  box-sizing:content-box;
}

/* -- Mobile lyrics card (below controls in expanded player) -- */
#exp-lyrics-card{
  display:block;
  width:100%;
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:16px;
  overflow:hidden;
  margin-top:20px;
  margin-bottom:8px;
}
#exp-lyrics-card-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 14px;
  cursor:pointer;
}
#exp-lyrics-card-title{
  font-size:11px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--muted);
}
#exp-lyrics-card-chevron{
  color:var(--muted);
  transition:transform 0.25s ease;
  font-size:14px;
  line-height:1;
}
#exp-lyrics-card.open #exp-lyrics-card-chevron{
  transform:rotate(180deg);
}
  
.lyrics-timing.mobile{
  border-bottom:none;
  padding:10px 14px 0;
}
.lyrics-timing.mobile .lyrics-timing-actions{
  width:100%;
  justify-content:space-between;
}
.lyrics-timing.mobile .lyrics-timing-btn{
  min-height:36px;
  padding:7px 12px;
}
.lyrics-timing.mobile .lyrics-offset-display{
  min-width:92px;
  font-size:10px;
}
/* Collapsed: scroll area hidden */
#exp-lyrics-card-scroll{
  max-height:0;
  overflow:hidden;
  padding:0;
  transition:max-height 0.35s cubic-bezier(0.4,0,0.2,1);
}
/* Expanded: show lyrics */
#exp-lyrics-card.open #exp-lyrics-card-scroll{
  max-height:280px;
  overflow-y:auto;
  padding:8px 0 12px;
}
/* Border only when open */
#exp-lyrics-card.open #exp-lyrics-card-header{
  border-bottom:1px solid var(--border);
}
#exp-lyrics-card-scroll::-webkit-scrollbar{width:3px}
#exp-lyrics-card-scroll::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:3px}

}

@media(min-width:769px){
  #player-meta-mobile{display:none}
  #volume-row{display:flex}
  /* Desktop expanded player stays as original */
  #expanded-player{display:none;position:fixed;inset:0;background:var(--bg);z-index:200;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;overflow-y:auto}
  #expanded-player.open{display:flex}
  #exp-lyrics-card{display:none !important}
  #exp-offset-controls{display:flex}
  #exp-collapse{position:absolute;top:20px;right:24px;background:none;border:none;color:var(--muted);font-size:24px;cursor:pointer;padding:8px;border-radius:50%;line-height:1;z-index:10;transition:background .15s;width:auto;height:auto}
  #exp-collapse:hover{color:var(--text);background:var(--surface2)}
  #exp-cover-wrap{margin-top:0 !important}
}

.queue-item,.queue-handle{user-select:none;-webkit-user-select:none}
body.is-dragging{user-select:none;-webkit-user-select:none}

.ctx-item{padding:10px 12px;font-size:13px;cursor:pointer;border-radius:6px;display:flex;align-items:center;gap:10px;color:var(--text);line-height:1}
.ctx-item svg{flex-shrink:0}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:300;padding:20px}
.modal{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);padding:24px;width:100%;max-width:340px;display:flex;flex-direction:column;gap:14px}
.modal h3{font-size:16px;font-weight:500}
.modal input{background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:14px;padding:9px 12px;outline:none;transition:border-color .2s}
.modal input:focus{border-color:var(--accent)}
.modal-btns{display:flex;gap:8px;justify-content:flex-end}
.modal-btns button{border:none;border-radius:8px;padding:8px 16px;font-family:inherit;font-size:13px;cursor:pointer;transition:background .15s}
.btn-cancel{background:var(--surface3);color:var(--text)}
.btn-cancel:hover{background:var(--surface2)}
.btn-confirm{background:var(--accent);color:#000;font-weight:500}
.btn-confirm:hover{background:var(--accent2)}
#auth-overlay{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:400;padding:24px}
#auth-box{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);padding:28px;width:100%;max-width:340px;display:flex;flex-direction:column;gap:14px}
#auth-box h2{font-size:17px;font-weight:500}
#auth-box p{font-size:13px;color:var(--muted);line-height:1.6}
#auth-input{background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:'SF Pro Display',-apple-system,sans-serif;font-size:14px;padding:9px 12px;outline:none;transition:border-color .2s}
#auth-input:focus{border-color:var(--accent)}
#auth-submit{background:var(--accent);color:#000;border:none;border-radius:8px;padding:9px 16px;font-family:inherit;font-size:14px;font-weight:500;cursor:pointer}
#auth-submit:hover{background:var(--accent2)}
#auth-error{font-size:12px;color:var(--danger);display:none}
#queue-btn{background:none;border:1px solid var(--border);color:var(--muted);border-radius:6px;padding:4px 8px;font-size:11px;font-family:'SF Pro Display',-apple-system,sans-serif;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap}
#queue-btn:hover,#queue-btn.active{color:var(--accent);border-color:var(--accent)}
#queue-panel{display:none;flex-direction:column;position:fixed;bottom:var(--player-h);left:0;right:0;height:220px;background:var(--surface);border-top:1px solid var(--border2);overflow-y:auto;z-index:9}
#queue-panel.open{display:flex}
#queue-panel::-webkit-scrollbar{width:3px}
#queue-panel::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:3px}
#queue-header{padding:10px 16px;font-size:11px;font-family:'SF Pro Display',-apple-system,sans-serif;letter-spacing:0.08em;color:var(--muted);text-transform:uppercase;border-bottom:1px solid var(--border);flex-shrink:0}
.queue-item{display:flex;align-items:center;gap:10px;padding:7px 16px;font-size:13px;cursor:pointer;transition:background .1s,border-color .1s,border-radius .15s,transform .15s,opacity .15s,z-index;flex-shrink:0;border-bottom:1px solid var(--border);position:relative}
.queue-item:hover{background:var(--surface2)}
.queue-item.active{background:var(--surface2)}
.queue-item.active .queue-title{color:var(--accent)}
.queue-item.dragging{opacity:0.35;transform:scale(1.02);z-index:100;box-shadow:0 8px 24px rgba(0,0,0,.4);border-color:var(--accent)}
.queue-item.drag-over{border-top:2px solid var(--accent)}
.queue-handle{cursor:grab;color:var(--muted);font-size:14px;padding:0 2px;user-select:none;flex-shrink:0;transition:color .15s;line-height:1;touch-action:none}
.queue-handle:hover{color:var(--text)}
.queue-handle:active{cursor:grabbing}
.queue-num{font-family:'SF Pro Display',-apple-system,sans-serif;font-size:11px;color:var(--muted);min-width:20px;text-align:right;flex-shrink:0}
.queue-info{flex:1;min-width:0}
.queue-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.queue-sub{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.queue-remove{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;opacity:0;font-size:14px;border-radius:4px;flex-shrink:0}
.queue-item:hover .queue-remove{opacity:1}
.queue-remove:hover{color:var(--danger)}
#lyrics-btn{background:none;border:1px solid var(--border);color:var(--muted);border-radius:6px;padding:4px 8px;font-size:11px;font-family:'SF Pro Display',-apple-system,sans-serif;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap}
#lyrics-btn:hover,#lyrics-btn.active{color:var(--accent);border-color:var(--accent)}
/* Desktop floating lyrics panel */
#lyrics-panel{display:none;flex-direction:column;position:fixed;bottom:calc(var(--player-h) + 12px);right:16px;width:280px;height:200px;min-width:200px;min-height:120px;max-width:480px;max-height:420px;background:var(--surface);border:1px solid var(--border2);border-radius:12px;overflow:hidden;z-index:9;resize:both;box-shadow:0 8px 32px rgba(0,0,0,.4)}
#lyrics-panel.open{display:flex}
#lyrics-panel::-webkit-scrollbar{width:3px}
#lyrics-panel::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:3px}
#lyrics-panel-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border);flex-shrink:0;cursor:move;user-select:none}
#lyrics-panel-title{font-size:10px;font-family:'SF Pro Display',-apple-system,sans-serif;letter-spacing:0.08em;color:var(--muted);text-transform:uppercase}
#lyrics-close-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:14px;padding:0 2px;line-height:1;border-radius:3px}
#lyrics-close-btn:hover{color:var(--text)}
#lyrics-scroll{flex:1;overflow-y:auto;padding:8px 0}
#lyrics-scroll::-webkit-scrollbar{width:3px}
#lyrics-scroll::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:3px}
.lyric-line{padding:5px 14px;font-size:13px;color:var(--muted);cursor:pointer;transition:color .2s;line-height:1.5}
.lyric-line.active{color:var(--text);font-size:14px;font-weight:500}
.lyric-line:hover{color:var(--text)}
#lyrics-empty{padding:24px 14px;text-align:center;color:var(--muted);font-size:12px}
/* Desktop expanded player */
#expanded-player{display:none;position:fixed;inset:0;background:var(--bg);z-index:200;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;overflow-y:auto}
#expanded-player.open{display:flex}
#expanded-player::-webkit-scrollbar{width:3px}
#expanded-player::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:3px}
#exp-collapse{position:absolute;top:20px;right:24px;background:none;border:none;color:var(--muted);font-size:24px;cursor:pointer;padding:8px;border-radius:50%;line-height:1;z-index:10;transition:background .15s}
#exp-collapse:hover{color:var(--text);background:var(--surface2)}
#exp-content{width:100%;max-width:1100px;display:flex;flex-direction:column;align-items:center;gap:12px}
#exp-main-shell{width:100%;display:flex;flex-direction:column;align-items:center;gap:12px}
#exp-main-left{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;transition:transform .3s ease,width .3s ease,opacity .3s ease}
#exp-desktop-lyrics-panel{display:none}
#exp-cover-wrap{width:min(85vw,380px);aspect-ratio:1/1;border-radius:24px;overflow:hidden;flex-shrink:0;background:var(--surface3);display:flex;align-items:center;justify-content:center;box-shadow:0 20px 60px rgba(0,0,0,.5);position:relative;margin-top:-15px !important}
#exp-cover{width:100%;height:100%;object-fit:contain;display:block}
#exp-cover-icon{font-size:64px;color:var(--muted);position:absolute}
#exp-info{text-align:center;width:100%;margin-bottom:24px !important;padding-bottom:0 !important}
#exp-title{width:100%;font-size:26px;font-weight:700;color:var(--text);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
#exp-artist{font-size:17px;color:var(--muted);margin-bottom:0}
#exp-lyrics-wrap{width:100%;height:70px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;position:relative;overflow:hidden;margin-top:0 !important}
#exp-lyrics{width:100%;transition:transform .4s cubic-bezier(0.4,0,0.2,1);padding-bottom:20px}
#exp-lyric-current{font-size:19px;font-weight:600;color:var(--text);margin-bottom:4px;transition:opacity .3s,transform .3s}
#exp-lyric-next{font-size:15px;color:var(--muted);transition:opacity .3s,transform .3s}
#exp-controls-row{width:100%;display:flex;flex-direction:column;gap:20px;align-items:center}
#exp-controls{display:flex;align-items:center;gap:24px;justify-content:center}
#exp-utils{display:flex;align-items:center;justify-content:center;gap:10px}
#exp-lyrics-toggle{background:none;border:1px solid var(--border);color:var(--muted);border-radius:6px;padding:6px 10px;font-size:12px;font-family:'SF Pro Display',-apple-system,sans-serif;cursor:pointer;transition:color .15s,border-color .15s,background .15s}
#exp-lyrics-toggle:hover,#exp-lyrics-toggle.active{color:var(--accent);border-color:var(--accent)}
#exp-controls .ctrl-btn{padding:12px;border-radius:14px}
#exp-controls .ctrl-btn.main{width:68px;height:68px}
#exp-controls .ctrl-btn svg{width:30px;height:30px}
#exp-progress-wrap{width:100%;display:flex;align-items:center;gap:12px}
#exp-progress-wrap .time-label{font-size:12px;min-width:40px}
#exp-progress{flex:1;height:4px;-webkit-appearance:none;appearance:none;border-radius:2px;background:var(--surface3);outline:none;cursor:pointer}
#exp-progress::-webkit-slider-runnable-track{height:4px;border-radius:2px}
#exp-progress::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;margin-top:-5px;box-shadow:0 0 6px rgba(0,0,0,0.4)}
#exp-progress::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent);border:none;cursor:pointer;box-shadow:0 0 6px rgba(0,0,0,0.4)}
@media(min-width:769px){
#expanded-player.desktop-lyrics-open{
  justify-content:flex-start;
  align-items:center;
  padding-top:24px;
}
#exp-content.desktop-lyrics-open{align-items:center}
#exp-content.desktop-lyrics-open #exp-main-shell{flex-direction:row;align-items:center;justify-content:center;gap:28px}
#exp-content.desktop-lyrics-open #exp-main-left{width:min(46%,460px);align-items:center;transform:none}
#exp-content.desktop-lyrics-open #exp-lyrics-wrap{display:none !important}
#exp-content.desktop-lyrics-open #exp-info{text-align:center}
#exp-content.desktop-lyrics-open #exp-title,
#exp-content.desktop-lyrics-open #exp-artist{width:100%}
#exp-content.desktop-lyrics-open #exp-controls-row{align-items:center}
#exp-content.desktop-lyrics-open #exp-controls,
#exp-content.desktop-lyrics-open #exp-progress-wrap,
#exp-content.desktop-lyrics-open #exp-utils{justify-content:center}
#exp-content.desktop-lyrics-open #exp-desktop-lyrics-panel{display:flex}
#exp-desktop-lyrics-panel{width:min(42vw,520px);min-width:340px;max-width:520px;max-height:calc(100dvh - 64px);background:var(--surface);border:1px solid var(--border2);border-radius:18px;overflow:hidden;display:none;flex-direction:column;box-shadow:0 18px 48px rgba(0,0,0,.35)}
#exp-desktop-lyrics-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}
#exp-desktop-lyrics-title{font-size:11px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}
#exp-desktop-lyrics-tools{display:flex;align-items:center;gap:6px}
#exp-desktop-lyrics-body{display:flex;flex-direction:column;min-height:0;flex:1}
#exp-desktop-lyrics-scroll{flex:1;overflow-y:auto;padding:10px 0}
#exp-desktop-lyrics-scroll::-webkit-scrollbar{width:3px}
#exp-desktop-lyrics-scroll::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:3px}
}
@media(max-width:380px){#search{width:120px}#search:focus{width:150px}}

#lyrics-scroll, 
#exp-lyrics-card-scroll, 
#exp-desktop-lyrics-scroll {
    position: relative !important;
}

/* -- Disable hover effects on touch devices -- */
@media (hover: none), (pointer: coarse) {
  .track:hover { background: transparent !important; }
  .track:hover .track-menu-btn { opacity: 0 !important; }
  .playlist-card:hover { background: transparent !important; }
  .playlist-card:hover .playlist-del { opacity: 0 !important; }
  .ctrl-btn:hover { background: transparent !important; color: var(--muted) !important; }
  .ctrl-btn.main:hover { background: var(--accent) !important; }
  #sort-btn:hover { color: var(--muted) !important; }
  #new-playlist-btn:hover { background: var(--accent) !important; }
  #playlist-back:hover { color: var(--muted) !important; }
  #playlist-play-btn:hover { background: var(--accent) !important; }
  #expand-handle:hover { color: var(--muted) !important; transform: none !important; }
  .track-menu-btn:hover { background: transparent !important; color: var(--muted) !important; }
  .playlist-del:hover { color: var(--muted) !important; }
  .ctx-item:hover { background: transparent !important; }
  .queue-item:hover { background: transparent !important; }
  .queue-item:hover .queue-remove { opacity: 0 !important; }
  .queue-remove:hover { color: var(--muted) !important; }
  .queue-handle:hover { color: var(--muted) !important; }
  #queue-btn:hover, #lyrics-btn:hover { color: var(--muted) !important; border-color: var(--border) !important; }
  #lyrics-btn:hover, #lyrics-btn.active:hover { color: var(--muted) !important; }
  #exp-collapse:hover { background: transparent !important; color: var(--muted) !important; }
  #exp-lyrics-toggle:hover { color: var(--muted) !important; border-color: var(--border) !important; }
  .lyrics-timing-btn:hover { background: var(--surface2) !important; color: var(--muted) !important; border-color: var(--border) !important; }
  .lyric-line:hover { color: var(--muted) !important; }
  .btn-cancel:hover { background: var(--surface3) !important; }
  .btn-confirm:hover { background: var(--accent) !important; }
  #auth-submit:hover { background: var(--accent) !important; }
  
  /* Keep active states for touch feedback */

  /* Always show action buttons on touch - no hover needed */
  .track-menu-btn { 
    opacity: 1 !important; 
    color: var(--muted);
    padding: 8px !important; /* bigger tap target */
    min-width: 32px;
    min-height: 32px;
  }
  .playlist-del { 
    opacity: 1 !important;
    padding: 8px !important;
    min-width: 32px;
    min-height: 32px;
  }
  .queue-remove {
    opacity: 1 !important;
    padding: 8px !important;
  }
  
  /* Make them subtle but tappable */
  .track-menu-btn:active,
  .playlist-del:active,
  .queue-remove:active {
    background: var(--surface3) !important;
    color: var(--text) !important;
  }

  .track:active { background: var(--surface2) !important; }
  .ctrl-btn:active { background: var(--surface3) !important; transform: scale(0.96); }
  .ctrl-btn.main:active { background: var(--accent2) !important; }
}
