/* ----- reset & tokens ----- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
:root{
  --bg:#0a0a0c;
  --bg-2:#101014;
  --bg-3:#15151b;
  --panel:#17171d;
  --panel-2:#1c1c24;
  --line:#23232b;
  --text:#f3f3f5;
  --muted:#9b9ba6;
  --muted-2:#71717a;
  --accent:#5cf28a;     /* signature green */
  --accent-2:#39d871;
  --accent-glow:rgba(92,242,138,.18);
  --danger:#ef4444;
  --radius:14px;
  --radius-sm:10px;
  --shadow:0 10px 30px rgba(0,0,0,.45);
  --transition:160ms cubic-bezier(.4,0,.2,1);
  --sat:env(safe-area-inset-top,0px);
  --sab:env(safe-area-inset-bottom,0px);
}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  font-size:14px;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  overflow-x:hidden;
  text-size-adjust:100%;
  -webkit-text-size-adjust:100%;
  touch-action:manipulation;
}
@media (min-width:781px){
  body{overflow:hidden;overscroll-behavior:none}
  body.drawer-open,body.np-open{overflow:hidden}
}
@media (max-width:780px){
  body.drawer-open,body.np-open{overflow:hidden}
}
button,input,select,textarea{font-family:inherit}
button{cursor:pointer;border:0;background:transparent;color:inherit}
a{color:inherit;text-decoration:none}
.hidden{display:none !important}

/* ----- app shell ----- */
.app{
  display:grid;
  grid-template-columns:240px 1fr;
  height:100vh;
}
.topbar{display:none}
.bottomnav{display:none}
.sidebar-backdrop{display:none}
.sidebar{
  background:linear-gradient(180deg,var(--bg-2),var(--bg));
  border-right:1px solid var(--line);
  padding:22px 14px 14px;
  display:flex;
  flex-direction:column;
  gap:18px;
}
.brand{
  display:flex;align-items:center;gap:10px;
  padding:0 8px 6px;
  font-weight:800;font-size:18px;letter-spacing:-.01em;
}
.brand-dot{
  width:14px;height:14px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#9affb5,var(--accent) 60%,var(--accent-2));
  box-shadow:0 0 18px var(--accent-glow);
}
.brand-dot.big{width:42px;height:42px}
.sidebar nav{display:flex;flex-direction:column;gap:2px}
.nav-link{
  display:flex;align-items:center;gap:12px;
  padding:10px 12px;border-radius:10px;
  color:var(--muted);font-weight:500;
  transition:var(--transition);
}
.nav-link svg{width:18px;height:18px;stroke-linecap:round;stroke-linejoin:round}
.nav-link:hover{color:var(--text);background:var(--panel)}
.nav-link.active{color:var(--text);background:var(--panel-2)}
.sidebar-foot{margin-top:auto;padding:8px}
.logout{color:var(--muted-2);font-size:12px}
.logout:hover{color:var(--text)}

.content{
  overflow-y:auto;
  padding:28px 36px 150px;
  background:radial-gradient(1200px 600px at 70% -10%,#1a1a22 0%,transparent 60%),var(--bg);
}

/* ----- generic page head ----- */
.page-head{
  display:flex;align-items:end;justify-content:space-between;
  gap:16px;margin-bottom:28px;
}
.page-head h1{margin:0;font-size:34px;letter-spacing:-.02em;font-weight:800}
.page-head .muted{margin:6px 0 0;font-size:14px}
.head-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* ----- buttons / inputs ----- */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 14px;border-radius:10px;
  background:var(--panel);color:var(--text);
  font-weight:600;font-size:13px;
  transition:var(--transition);
  border:1px solid transparent;
}
.btn:hover{background:var(--panel-2)}
.btn svg{width:16px;height:16px;stroke-linecap:round;stroke-linejoin:round}
.btn.primary{
  background:var(--accent);color:#08120c;
  box-shadow:0 0 0 0 var(--accent-glow);
}
.btn.primary:hover{background:var(--accent-2);transform:translateY(-1px);
  box-shadow:0 8px 24px var(--accent-glow);
}
.btn.ghost{background:transparent;border:1px solid var(--line)}
.btn.ghost:hover{background:var(--panel)}
.btn.big{padding:12px 22px;font-size:14px;border-radius:999px}
.btn.danger{background:transparent;color:var(--danger);border:1px solid #3a1f23}
#btn-offline.is-offline{background:rgba(92,242,138,.15);border-color:rgba(92,242,138,.4);color:var(--accent)}
#btn-offline.is-offline svg{color:var(--accent)}
#btn-offline.downloading{background:rgba(92,242,138,.10);color:var(--accent);pointer-events:none}
#btn-offline.syncing{color:var(--accent)}
#btn-offline.syncing svg{animation:sync-pulse 1s ease-in-out infinite}

input[type="text"],input[type="password"],input[type="url"],input[type="number"],
select,textarea{
  width:100%;
  background:var(--panel);
  border:1px solid var(--line);
  color:var(--text);
  padding:10px 12px;border-radius:10px;font-size:14px;
  transition:var(--transition);
}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);
}
textarea{resize:vertical;min-height:80px;font-family:inherit}
label{display:block;font-size:12px;color:var(--muted);margin:10px 0 6px;font-weight:500}
.check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}
.check input{width:auto}

/* ----- login ----- */
.login-body{
  background:radial-gradient(1000px 600px at 50% -10%,#1f3829 0%,#0b0b10 50%,#0a0a0c 100%);
  height:100vh;
  display:flex;align-items:center;justify-content:center;
  font-family:'Inter',sans-serif;color:var(--text);
}
.login-card{
  width:min(380px,90vw);
  background:rgba(20,20,26,.85);
  backdrop-filter:blur(18px);
  border:1px solid var(--line);
  border-radius:20px;
  padding:36px 32px;
  box-shadow:var(--shadow);
}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.login-logo h1{margin:0;font-size:30px;letter-spacing:-.02em}
.login-card .muted{color:var(--muted);margin:0 0 20px}
.login-card form{display:flex;flex-direction:column;gap:12px}
.login-card button{
  background:var(--accent);color:#08120c;font-weight:700;
  padding:11px 14px;border-radius:10px;font-size:14px;
}
.login-card button:hover{background:var(--accent-2)}
.login-error{
  background:#2a1318;color:#fca5a5;
  padding:8px 12px;border-radius:8px;font-size:13px;text-align:center;
}

/* ----- library grid ----- */
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(190px,1fr));
  gap:20px;
}
.card{
  background:var(--panel);
  border-radius:var(--radius);
  padding:14px;
  position:relative;
  transition:var(--transition);
  display:block;
  overflow:hidden;
}
.card:hover{background:var(--panel-2);transform:translateY(-2px)}
.card-cover{
  aspect-ratio:1;
  border-radius:10px;
  background:linear-gradient(135deg,#2a2a36,#16161e);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:12px;
  position:relative;overflow:hidden;
  background-size:cover;background-position:center;
}
.card-cover-fallback{color:rgba(255,255,255,.25)}
.card-cover-fallback svg{width:48px;height:48px}
.card-cover.has-bg .card-cover-fallback{display:none}
.card-title{font-weight:700;font-size:15px;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-sub{font-size:12px;color:var(--muted);margin-top:4px}
.card-menu{
  position:absolute;top:8px;right:8px;display:flex;gap:4px;
  opacity:0;transition:var(--transition);
}
.card:hover .card-menu{opacity:1}
.icon-btn{
  width:32px;height:32px;border-radius:8px;
  background:rgba(0,0,0,.55);color:var(--text);
  display:flex;align-items:center;justify-content:center;
  transition:var(--transition);
}
.icon-btn:hover{background:rgba(0,0,0,.85);color:var(--accent)}
.icon-btn svg{width:15px;height:15px;stroke-linecap:round;stroke-linejoin:round}
.icon-btn.offline-btn .ic-on{display:none}
/* Auto-sync active: keep the same subtle, transparent look as the delete
   button next to it — just a green check, no solid fill. */
.icon-btn.offline-btn.is-offline{color:var(--accent)}
.icon-btn.offline-btn.is-offline .ic-off{display:none}
.icon-btn.offline-btn.is-offline .ic-on{display:block}
/* gentle pulse while a sync is running in the background */
.icon-btn.offline-btn.syncing{color:var(--accent)}
.icon-btn.offline-btn.syncing .ic-off{display:none}
.icon-btn.offline-btn.syncing .ic-on{display:block;animation:sync-pulse 1s ease-in-out infinite}
@keyframes sync-pulse{0%,100%{opacity:.35}50%{opacity:1}}
.icon-btn.offline-btn.downloading{
  background:conic-gradient(var(--accent) var(--p,0%), rgba(0,0,0,.55) 0);
  color:var(--text);
  pointer-events:none;
}
.icon-btn.offline-btn.downloading::after{
  content:attr(data-progress) "%";
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:9px;font-weight:700;color:var(--text);
}
.icon-btn.offline-btn.downloading svg{display:none}
.icon-btn.offline-btn{position:relative}

/* ----- modal ----- */
.modal{
  position:fixed;inset:0;background:rgba(0,0,0,.6);
  display:flex;align-items:center;justify-content:center;
  z-index:100;backdrop-filter:blur(6px);
}
.modal-card{
  width:min(440px,92vw);
  background:var(--bg-3);
  border:1px solid var(--line);
  border-radius:16px;padding:24px;box-shadow:var(--shadow);
}
.modal-card h2{margin:0 0 14px;font-size:20px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}

/* ----- playlist hero ----- */
.has-bg .content{padding-top:0}
.playlist-hero{
  position:relative;
  margin:-28px -36px 0;
  padding:40px 36px 28px;
  min-height:220px;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:blur(0px) saturate(1.1);
  z-index:0;
  background-color:#1a1a25;
  background-image:linear-gradient(135deg,#2c2c3a,#161620);
}
.hero-shade{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,10,12,.35) 0%,rgba(10,10,12,.85) 80%,#0a0a0c 100%);
  z-index:1;
}
.hero-inner{
  position:relative;z-index:2;
  display:flex;justify-content:space-between;align-items:end;gap:24px;flex-wrap:wrap;
}
.eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}
.hero-meta h1{font-size:44px;margin:6px 0 10px;letter-spacing:-.03em;font-weight:800;line-height:1.05}
.hero-desc{color:var(--muted);max-width:600px}
.hero-stats{margin-top:8px;color:var(--muted-2);font-size:13px}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap}

/* ----- songs list ----- */
.songs-wrap{margin-top:28px}
.songs-toolbar{
  display:flex;justify-content:space-between;align-items:center;
  padding:0 6px 14px;gap:14px;
}
.songs-search{
  display:flex;align-items:center;gap:8px;
  background:var(--panel);border:1px solid var(--line);
  padding:8px 12px;border-radius:10px;width:280px;
}
.songs-search svg{width:16px;height:16px;color:var(--muted)}
.songs-search input{border:0;background:transparent;padding:0;font-size:13px;width:100%}
.songs-search input:focus{box-shadow:none}

.songs-head, .song{
  display:grid;
  grid-template-columns:60px 1.4fr 1.6fr 90px 140px;
  gap:12px;
  padding:10px 14px;
  align-items:center;
}
.songs-head{
  color:var(--muted-2);font-size:11px;
  text-transform:uppercase;letter-spacing:.1em;
  border-bottom:1px solid var(--line);
}
.songs{list-style:none;margin:0;padding:0}
.song{
  border-radius:10px;
  transition:var(--transition);
  cursor:default;
}
.song:hover{background:var(--panel)}
.song.dragging{opacity:.4}
.song.drop-target{box-shadow:inset 0 -2px 0 var(--accent)}
.song.playing{background:var(--panel-2)}
.song.playing .col-title .title{color:var(--accent)}

.col-idx{display:flex;align-items:center;justify-content:flex-start;gap:0}
.col-idx .idx{color:var(--muted-2);font-variant-numeric:tabular-nums;width:24px}
.col-idx .play-row{
  display:none;width:30px;height:30px;border-radius:6px;align-items:center;justify-content:center;
  color:var(--text);
}
.col-idx .play-row svg{width:14px;height:14px}
.song:hover .col-idx .idx{display:none}
.song:hover .col-idx .play-row{display:flex}
.col-title .title{font-weight:600;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:340px}
.col-title .link{
  font-size:12px;color:var(--muted);margin-top:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:340px;
}
.col-title .link a{color:var(--muted);text-decoration:underline;text-decoration-color:rgba(255,255,255,.15)}
.col-title .link a:hover{color:var(--accent)}
.col-desc{color:var(--muted);font-size:13px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.col-size{color:var(--muted-2);font-size:13px;font-variant-numeric:tabular-nums}
.col-actions{display:flex;justify-content:flex-end;gap:4px;opacity:0;transition:var(--transition)}
.song:hover .col-actions{opacity:1}
.song .col-actions .icon-btn{background:transparent}
.song .col-actions .icon-btn:hover{background:var(--panel-2)}

/* ----- player ----- */
.player{
  position:fixed;bottom:0;left:0;right:0;
  height:96px;
  background:linear-gradient(180deg,#15151c 0%,#08080b 100%);
  border-top:1px solid #2a2a34;
  box-shadow:0 -8px 30px rgba(0,0,0,.55);
  display:grid;
  grid-template-columns:1fr 2fr 1fr;
  align-items:center;
  padding:0 22px;
  z-index:60;
  backdrop-filter:blur(12px);
}
/* Empty (no track loaded) — bar is fully visible, controls are dimmed. */
.player.empty .player-title{color:var(--muted)}
.player.empty .player-sub{color:var(--muted-2)}
.player.empty .ctrl{opacity:.5;cursor:default}
.player.empty .ctrl:hover{background:transparent;color:var(--muted)}
.player.empty .seek{pointer-events:none;opacity:.5}
.player.empty .player-cover{
  display:flex;align-items:center;justify-content:center;
  color:var(--muted-2);
}
.player.empty .player-cover::before{
  content:"";display:block;width:22px;height:22px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239b9ba6' stroke-width='2'><path d='M9 18V5l12-2v13'/><circle cx='6' cy='18' r='3'/><circle cx='18' cy='16' r='3'/></svg>");
  background-size:contain;background-repeat:no-repeat;
}
.player-mobile-progress{display:none}
/* Collapse handle for the mobile "now playing" overlay — hidden by default
   (incl. desktop). Only revealed inside the expanded mobile player. Without
   this base rule it stayed a visible grid item on desktop, blowing up the
   player grid and pushing the real controls below the viewport. */
.np-close{display:none}
#player > audio{display:none}
.player-info{display:flex;align-items:center;gap:12px;min-width:0}
.player-cover{
  width:54px;height:54px;border-radius:8px;
  background:linear-gradient(135deg,#2c2c3a,#16161e);
  background-size:cover;background-position:center;flex-shrink:0;
}
.player-text{min-width:0}
.player-title{font-weight:600;font-size:14px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}
.player-sub{font-size:12px;color:var(--muted);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}

.player-center{display:flex;flex-direction:column;align-items:center;gap:6px}
.player-controls{display:flex;align-items:center;gap:14px}
.ctrl{
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);transition:var(--transition);
}
.ctrl:hover{color:var(--text);background:var(--panel)}
.ctrl svg{width:18px;height:18px}
.ctrl.active{color:var(--accent)}
.ctrl-main{
  width:42px;height:42px;border-radius:50%;
  background:var(--text);color:#000;
}
.ctrl-main:hover{background:#fff;transform:scale(1.05)}
.ctrl-main svg{width:18px;height:18px}

.player-bar{
  display:flex;align-items:center;gap:10px;
  width:100%;max-width:540px;
  font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums;
}
.seek{flex:1;cursor:pointer;padding:8px 0}
.seek-bg{
  position:relative;height:4px;border-radius:2px;background:var(--panel-2);
}
.seek-fill{position:absolute;left:0;top:0;height:100%;border-radius:2px;background:var(--text);width:0%}
.seek:hover .seek-fill{background:var(--accent)}
.seek-thumb{
  position:absolute;top:50%;left:0;width:11px;height:11px;border-radius:50%;
  background:var(--text);transform:translate(-50%,-50%);opacity:0;transition:opacity var(--transition);
}
.seek:hover .seek-thumb{opacity:1}

.player-right{display:flex;align-items:center;gap:14px;justify-content:flex-end}
.vol{display:flex;align-items:center;gap:8px;color:var(--muted);width:160px}
.vol > svg{width:18px;height:18px;flex-shrink:0}
.vol input[type="range"]{
  -webkit-appearance:none;appearance:none;background:transparent;flex:1;
}
.vol input[type="range"]::-webkit-slider-runnable-track{
  height:4px;background:var(--panel-2);border-radius:2px;
}
.vol input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;width:12px;height:12px;border-radius:50%;
  background:var(--text);margin-top:-4px;cursor:pointer;
}

/* ----- import ----- */
.target-pl{display:flex;align-items:center;gap:10px;margin:0}
.target-pl > span{
  font-size:12px;color:var(--muted);text-transform:uppercase;
  letter-spacing:.1em;font-weight:600;
}
.target-pl select{width:auto;min-width:200px;padding:9px 12px}

.search-card{
  background:var(--panel);border:1px solid var(--line);
  border-radius:16px;padding:18px 20px;margin-bottom:24px;
}
.search-tabs{display:flex;gap:6px;margin-bottom:14px}
.search-tabs .tab{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:999px;
  background:var(--panel-2);color:var(--muted);
  font-size:13px;font-weight:600;
  border:1px solid transparent;
  transition:var(--transition);
}
.search-tabs .tab svg{width:16px;height:16px}
.search-tabs .tab:hover{color:var(--text)}
.search-tabs .tab.active{
  color:var(--text);background:var(--bg-3);
  border-color:var(--line);
  box-shadow:inset 0 0 0 1px var(--accent-glow);
}
.search-tabs .tab[data-source="youtube"].active svg{color:#ff3b3b}
.search-tabs .tab[data-source="spotify"].active svg{color:#1ed760}
.search-tabs .tab-config{
  padding:8px 10px;background:transparent;color:var(--muted-2);
}
.search-tabs .tab-config:hover{color:var(--text);background:var(--panel-2)}
.search-tabs .tab-config svg{width:16px;height:16px;stroke-linecap:round;stroke-linejoin:round}

.search-bar{
  display:flex;align-items:center;gap:10px;
  background:var(--bg-3);border:1px solid var(--line);
  border-radius:12px;padding:6px 10px 6px 14px;
}
.search-bar > svg{width:18px;height:18px;color:var(--muted);flex-shrink:0}
.search-bar input{
  flex:1;border:0;background:transparent;padding:10px 0;
  font-size:15px;color:var(--text);
}
.search-bar input:focus{box-shadow:none;outline:none}
.search-bar .btn{flex-shrink:0}

.link-detect{
  display:flex;align-items:center;gap:12px;
  margin-top:12px;padding:10px 14px;
  background:linear-gradient(135deg,rgba(92,242,138,.10),rgba(92,242,138,.04));
  border:1px solid rgba(92,242,138,.35);
  border-radius:12px;
  font-size:13px;
}
.link-detect.hidden{display:none}
.link-detect .ld-badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 10px;border-radius:999px;
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  color:#fff;flex-shrink:0;
}
.link-detect .ld-badge.youtube{background:#ff3b3b}
.link-detect .ld-badge.spotify{background:#1ed760;color:#08120c}
.link-detect .ld-text{flex:1;min-width:0}
.link-detect .ld-text b{display:block;color:var(--text);font-size:13px}
.link-detect .ld-text small{color:var(--muted);font-size:11px;
  display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.link-detect .btn{flex-shrink:0}

.search-results{
  display:flex;flex-direction:column;gap:8px;
  margin-top:14px;
}
.search-results:empty{display:none}
.search-loading,.search-empty{
  padding:18px;text-align:center;color:var(--muted);
  font-size:13px;
}
.result-card{
  display:grid;
  grid-template-columns:96px 1fr auto;
  gap:14px;align-items:center;
  background:var(--bg-3);border:1px solid var(--line);
  border-radius:12px;padding:8px;
  transition:var(--transition);
}
.result-card:hover{background:var(--panel-2);border-color:#2c2c36}
.result-thumb{
  position:relative;
  width:96px;height:72px;
  background:linear-gradient(135deg,#2c2c3a,#16161e);
  background-size:cover;background-position:center;
  border-radius:8px;flex-shrink:0;overflow:hidden;
}
.result-dur{
  position:absolute;bottom:4px;right:4px;
  background:rgba(0,0,0,.78);color:#fff;
  font-size:11px;padding:2px 6px;border-radius:4px;
  font-variant-numeric:tabular-nums;
}
.result-src{
  position:absolute;top:4px;left:4px;
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  padding:2px 6px;border-radius:4px;color:#fff;
}
.result-src.youtube{background:#ff3b3b}
.result-src.spotify{background:#1ed760;color:#08120c}
.result-meta{min-width:0}
.result-title{
  font-weight:600;font-size:14px;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.result-sub{
  font-size:12px;color:var(--muted);margin-top:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.result-actions{display:flex;gap:6px;align-items:center}
.result-actions .btn{padding:8px 12px;font-size:12px}
.result-actions .btn svg{width:14px;height:14px}
.result-open{padding:8px !important}

.result-preview{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.08);color:var(--text);
  border:1px solid var(--line);transition:var(--transition);
  flex-shrink:0;
}
.result-preview:hover{background:rgba(255,255,255,.16);color:var(--accent)}
.result-preview svg{width:14px;height:14px}
.result-preview.playing{background:var(--accent);color:#08120c;border-color:transparent}
.result-preview.loading{opacity:.6;pointer-events:none}
.result-preview.disabled{opacity:.35;pointer-events:none}

/* Inline preview bar that expands under a card while playing */
.preview-bar{
  grid-column:1 / -1;
  display:flex;align-items:center;gap:10px;
  margin-top:8px;padding:8px 10px;
  background:rgba(92,242,138,.06);
  border:1px solid rgba(92,242,138,.25);
  border-radius:10px;
  font-size:12px;color:var(--muted);
}
.preview-bar .pv-time{font-variant-numeric:tabular-nums;min-width:80px;
  display:flex;justify-content:space-between;color:var(--muted)}
.preview-bar .pv-seek{
  flex:1;height:18px;cursor:pointer;display:flex;align-items:center;
}
.preview-bar .pv-track{
  width:100%;height:4px;border-radius:2px;background:var(--panel-2);
  position:relative;overflow:hidden;
}
.preview-bar .pv-fill{
  position:absolute;left:0;top:0;height:100%;width:0;
  background:var(--accent);transition:width .1s linear;
}
.preview-bar .pv-clip{
  font-size:10px;text-transform:uppercase;letter-spacing:.08em;
  background:rgba(30,215,96,.18);color:#1ed760;
  padding:2px 6px;border-radius:4px;font-weight:700;
}

.import-icon.link{background:linear-gradient(135deg,#7d6cff,#3a2bb8);color:#fff}

@media (max-width:700px){
  .result-card{grid-template-columns:72px 1fr;grid-template-rows:auto auto;gap:8px}
  .result-thumb{width:72px;height:56px}
  .result-actions{grid-column:1 / -1;justify-content:flex-end}
  .target-pl{width:100%}
  .target-pl select{flex:1}
}

.import-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));
  gap:24px;margin-bottom:32px;
}
.import-card{
  background:var(--panel);border:1px solid var(--line);
  border-radius:16px;padding:24px;
}
.import-card h2{margin:14px 0 4px;font-size:20px}
.import-card form{display:flex;flex-direction:column;gap:10px;margin-top:14px}
.import-icon{
  width:48px;height:48px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;
}
.import-icon.yt{background:linear-gradient(135deg,#ff3b3b,#a02020)}
.import-icon.up{background:linear-gradient(135deg,#5cf28a,#1ea24f);color:#08120c}
.import-icon svg{width:26px;height:26px}

.file-drop{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  border:2px dashed var(--line);border-radius:12px;
  padding:32px 18px;text-align:center;cursor:pointer;
  transition:var(--transition);color:var(--muted);
}
.file-drop:hover, .file-drop.drag{border-color:var(--accent);color:var(--text);background:var(--panel-2)}
.file-drop small{display:block;margin-top:6px;color:var(--muted-2);font-size:12px}

.import-jobs{display:flex;flex-direction:column;gap:10px}
.job{
  background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px 18px;
  display:flex;align-items:center;gap:14px;
}
.job-info{flex:1;min-width:0}
.job-title{font-size:14px;font-weight:600;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.job-msg{font-size:12px;color:var(--muted);margin-top:2px}
.job-bar{flex:1;height:4px;background:var(--panel-2);border-radius:2px;overflow:hidden;
  max-width:200px}
.job-fill{height:100%;background:var(--accent);transition:width .25s}
.job.done .job-fill{background:var(--accent)}
.job.error .job-fill{background:var(--danger)}
.job.error .job-msg{color:#fca5a5}

/* ----- editor ----- */
.editor-wrap{display:flex;flex-direction:column;gap:18px}
.editor-canvas{
  background:var(--panel);border:1px solid var(--line);
  border-radius:14px;padding:16px;
}
#waveform{height:140px}
.wave-time{display:flex;justify-content:space-between;color:var(--muted);
  font-size:12px;font-variant-numeric:tabular-nums;margin-top:8px}

.editor-controls{
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:center;
  background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px;
}
.ctrl-group{display:flex;gap:6px;align-items:center}
.ctrl-group .lbl{color:var(--muted);font-size:12px;margin-right:4px}
.ctrl-group select{width:auto;padding:6px 10px}

.editor-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;
}
.card-block{
  background:var(--panel);border:1px solid var(--line);
  border-radius:14px;padding:18px;
}
.card-block h3{margin:0 0 10px;font-size:15px;font-weight:600}
.row{display:flex;gap:12px}
.row > *{flex:1}
.markers{
  background:var(--bg-3);border:1px solid var(--line);
  border-radius:8px;padding:8px;min-height:40px;
  display:flex;flex-wrap:wrap;gap:6px;font-size:12px;
}
.marker{
  background:var(--panel-2);padding:4px 8px;border-radius:6px;
  display:inline-flex;align-items:center;gap:6px;color:var(--muted);
}
.marker button{color:var(--muted-2);font-size:14px;line-height:1}

/* ----- toast ----- */
.toast{
  position:fixed;bottom:108px;left:50%;transform:translate(-50%,30px);
  background:var(--bg-3);border:1px solid var(--line);
  padding:10px 16px;border-radius:10px;font-size:13px;
  opacity:0;pointer-events:none;transition:all .25s;z-index:200;
  box-shadow:var(--shadow);
}
.toast.show{opacity:1;transform:translate(-50%,0)}
.toast.error{border-color:#3a1f23;color:#fca5a5}
.toast.success{border-color:#1e3a2a;color:var(--accent)}

/* ----- scrollbar ----- */
.content::-webkit-scrollbar,
.markers::-webkit-scrollbar,
textarea::-webkit-scrollbar{width:12px;height:12px}
.content::-webkit-scrollbar-track{background:rgba(255,255,255,.02)}
.content::-webkit-scrollbar-thumb{background:#3a3a45;border-radius:6px;border:2px solid var(--bg)}
.content::-webkit-scrollbar-thumb:hover{background:#4a4a55}

/* ----- responsive: tablet (sidebar collapses to icons) ----- */
@media (max-width:1100px) and (min-width:781px){
  .app{grid-template-columns:64px 1fr}
  .sidebar .brand-name, .nav-link span, .logout{display:none}
  .nav-link{justify-content:center;padding:12px}
  .sidebar{padding:18px 8px 12px}
  .content{padding:24px 24px 130px}
  .hero-meta h1{font-size:42px}
  .songs-head, .song{grid-template-columns:40px 1.6fr 1.2fr 80px 90px}
}

/* ----- responsive: phone (drawer + bottom nav) ----- */
@media (max-width:780px){
  html{
    height:auto;
    overflow:visible;
  }
  body{
    height:auto;
    min-height:100vh;
    overflow-x:hidden;
    overflow-y:visible;
    font-size:15px;
    touch-action:pan-y;
  }

  /* the app is no longer a fixed-height grid on mobile; the document scrolls */
  .app{
    display:block;
    grid-template-columns:none;
    height:auto;
    min-height:100vh;
    overflow:visible;
  }
  .content{touch-action:pan-y}
  .songs, .song, .grid, .card, .songs-wrap{touch-action:pan-y}

  .topbar{
    display:flex;align-items:center;gap:12px;
    position:sticky;top:0;z-index:40;
    padding:calc(8px + var(--sat)) 12px 8px;
    background:rgba(10,10,12,.92);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border-bottom:1px solid var(--line);
    height:calc(52px + var(--sat));
  }
  .topbar .brand{padding:0;font-size:17px;flex:1;gap:8px}
  .topbar .brand-dot{width:12px;height:12px}
  .hamburger{
    width:42px;height:42px;border-radius:10px;
    display:flex;align-items:center;justify-content:center;
    color:var(--text);background:transparent;
    transition:var(--transition);
    -webkit-tap-highlight-color:transparent;
  }
  .hamburger:active{background:var(--panel);transform:scale(.96)}
  .hamburger svg{width:22px;height:22px;stroke-linecap:round}
  .topbar-action{
    width:42px;height:42px;border-radius:10px;
    display:flex;align-items:center;justify-content:center;
    background:var(--accent);color:#08120c;
    -webkit-tap-highlight-color:transparent;
    transition:var(--transition);
  }
  .topbar-action.ghost{background:transparent;color:var(--muted);border:1px solid var(--line)}
  .topbar-action:active{transform:scale(.94)}
  .topbar-action svg{width:20px;height:20px;stroke-linecap:round;stroke-linejoin:round}

  .sidebar{
    position:fixed;top:0;left:0;bottom:0;
    width:80%;max-width:320px;
    z-index:80;
    transform:translateX(-105%);
    transition:transform .28s cubic-bezier(.32,.72,.24,1);
    box-shadow:0 0 40px rgba(0,0,0,.6);
    padding-top:calc(22px + var(--sat));
    will-change:transform;
  }
  .sidebar.open{transform:translateX(0)}
  .sidebar-backdrop{
    position:fixed;inset:0;z-index:70;
    background:rgba(0,0,0,.55);
    opacity:0;pointer-events:none;
    transition:opacity .25s;
    display:block;
    backdrop-filter:blur(2px);
  }
  .sidebar-backdrop.show{opacity:1;pointer-events:auto}
  .sidebar .nav-link{padding:14px 12px;font-size:15px;border-radius:12px}
  .sidebar .nav-link svg{width:20px;height:20px}
  .sidebar .nav-link:active{background:var(--panel-2);transform:scale(.98)}

  .bottomnav{
    display:none;
    position:fixed;
    left:0;right:0;
    bottom:0;
    z-index:45;
    padding:6px 6px calc(6px + var(--sab));
    background:rgba(10,10,12,.96);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    border-top:1px solid var(--line);
    justify-content:space-around;
    gap:4px;
    height:calc(60px + var(--sab));
  }
  .bottomnav .nav-link{
    flex:1;flex-direction:column;gap:3px;
    padding:6px 4px;border-radius:10px;
    color:var(--muted-2);font-size:10.5px;font-weight:600;letter-spacing:.01em;
    align-items:center;justify-content:center;
    -webkit-tap-highlight-color:transparent;
    transition:transform .12s ease, color var(--transition);
  }
  .bottomnav .nav-link svg{width:22px;height:22px;stroke-linecap:round;stroke-linejoin:round}
  .bottomnav .nav-link.active{color:var(--accent);background:transparent}
  .bottomnav .nav-link:active{transform:scale(.92)}

  /* main content scrolls with the document; pad enough room for the player */
  .content{
    overflow:visible;
    padding:14px 14px calc(120px + var(--sab));
    background:radial-gradient(800px 400px at 50% -10%,#1a1a22 0%,transparent 60%),var(--bg);
  }

  /* page head stacks */
  .page-head{
    flex-direction:column;align-items:stretch;gap:10px;margin-bottom:18px;
  }
  .page-head h1{font-size:26px}
  .page-head .muted{font-size:13px;margin-top:2px}
  .head-actions{width:100%;gap:8px}
  .head-actions .btn{flex:1;justify-content:center}

  /* library grid: 2 cols on phone */
  .grid{
    grid-template-columns:repeat(2,1fr);
    gap:12px;
  }
  .card{padding:10px;-webkit-tap-highlight-color:transparent}
  .card:active{transform:scale(.98)}
  .card-cover{margin-bottom:8px;border-radius:8px}
  .card-title{font-size:14px}
  .card-sub{font-size:11px}
  .card-menu{opacity:1;top:6px;right:6px;gap:4px}
  .icon-btn{width:32px;height:32px}

  /* playlist hero: full-bleed, stacked */
  .has-bg .content{padding-top:0}
  .playlist-hero{
    margin:0 -14px 0;
    padding:22px 18px 18px;
    min-height:auto;
  }
  .hero-inner{flex-direction:column;align-items:stretch;gap:14px}
  .hero-meta h1{font-size:30px;line-height:1.05;margin:4px 0 8px}
  .eyebrow{font-size:10px}
  .hero-desc{font-size:13px}
  .hero-stats{font-size:12px;margin-top:4px}
  .hero-actions{width:100%;gap:8px;display:grid;grid-template-columns:1fr 1fr;}
  .hero-actions .btn{justify-content:center;padding:11px 10px;font-size:13px;border-radius:10px}
  .hero-actions .btn svg{width:15px;height:15px}
  .hero-actions .btn.big{
    grid-column:1 / -1;padding:14px 22px;font-size:15px;border-radius:999px;
    box-shadow:0 6px 22px var(--accent-glow);
  }

  /* songs list: compact two-line layout */
  .songs-wrap{margin-top:18px}
  .songs-toolbar{flex-direction:column;align-items:stretch;gap:8px;padding:0 0 8px}
  .songs-search{width:100%;padding:10px 12px;border-radius:12px}
  .songs-search input{font-size:15px}
  .songs-head{display:none}
  .songs{margin:0 -6px}
  .song{
    grid-template-columns:32px 1fr auto;
    grid-template-rows:auto auto;
    grid-template-areas:
      "idx title actions"
      "idx desc actions";
    gap:2px 10px;
    padding:10px 8px;
    border-radius:10px;
    -webkit-tap-highlight-color:transparent;
  }
  .song:active{background:var(--panel-2)}
  .col-idx{grid-area:idx;align-self:center}
  .col-idx .idx{font-size:13px}
  .col-title{grid-area:title;min-width:0}
  .col-title .title{max-width:none;font-size:14.5px;font-weight:600}
  .col-title .link{display:none}
  .col-desc{
    grid-area:desc;display:block;
    font-size:11.5px;color:var(--muted-2);
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  }
  .col-size{display:none}
  .col-actions{
    grid-area:actions;opacity:1;
    flex-direction:row;gap:0;align-self:center;
  }
  /* on mobile, hide download + editor by default — overflow menu (•••) opens them */
  .song .col-actions [data-act="dl"],
  .song .col-actions [data-act="editor"]{display:none}
  .song .col-actions .icon-btn{width:34px;height:34px}
  .song:hover .col-idx .idx{display:inline}
  .song:hover .col-idx .play-row{display:none}
  .col-idx .play-row{display:none !important}
  /* tap row to play */
  .song{cursor:pointer}
  .song.playing{background:linear-gradient(90deg,rgba(92,242,138,.10),transparent)}
  .song.playing .col-idx .idx{color:var(--accent)}

  /* import grid stacks */
  .import-grid{grid-template-columns:1fr;gap:14px;margin-bottom:24px}
  .import-card{padding:18px;border-radius:14px}
  .import-card h2{font-size:18px}

  .search-card{padding:14px;border-radius:14px;margin-bottom:16px}
  .link-detect{flex-wrap:wrap;gap:10px;padding:12px}
  .link-detect .ld-text{flex:1 0 60%;min-width:160px}
  .link-detect .btn{flex:1 1 auto;justify-content:center;min-width:140px}
  .search-tabs{justify-content:stretch;flex-wrap:wrap}
  .search-tabs .tab{flex:1;justify-content:center;padding:10px 12px;min-width:0}
  .search-tabs .tab span{font-size:13px}
  .search-tabs .tab-config{flex:0 0 auto;padding:10px}
  .search-bar{flex-wrap:wrap;padding:6px 8px;gap:6px}
  .search-bar input{font-size:16px;flex:1 1 100%;padding:8px 4px}
  .search-bar > .btn{flex:1}

  /* search results full-width with icon-only open */
  .result-card{
    grid-template-columns:80px 1fr;
    grid-template-rows:auto auto;
    gap:8px 12px;
    padding:8px;
  }
  .result-thumb{width:80px;height:60px}
  .result-meta{align-self:center}
  .result-title{font-size:13.5px;white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3}
  .result-actions{
    grid-column:1 / -1;
    justify-content:stretch;
    gap:8px;
  }
  .result-actions .result-import{flex:1;justify-content:center}
  .result-actions .btn{padding:11px 12px;font-size:13px}
  .result-preview{width:38px;height:38px}
  .preview-bar{margin-top:6px;padding:8px}

  /* target playlist row */
  .target-pl{flex-direction:column;align-items:stretch;gap:6px;width:100%}
  .target-pl > span{font-size:11px}
  .target-pl select{width:100%;min-width:0;padding:12px 12px;font-size:15px}

  /* editor */
  .editor-canvas{padding:12px;border-radius:12px}
  .editor-controls{padding:10px;gap:6px;border-radius:12px;justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap}
  .editor-controls::-webkit-scrollbar{display:none}
  .editor-controls .ctrl-group{flex-wrap:nowrap;flex-shrink:0}
  .editor-controls .btn{padding:9px 11px;font-size:12px;flex-shrink:0}
  .editor-controls .ctrl-group select{font-size:13px;padding:8px 10px}
  .editor-grid{grid-template-columns:1fr;gap:14px}
  .card-block{padding:14px;border-radius:12px}
  #waveform{height:120px}

  /* modal */
  .modal-card{width:calc(100vw - 24px);padding:18px;border-radius:16px;max-height:88vh;overflow-y:auto}
  .modal-card h2{font-size:17px}

  /* inputs more touch-friendly */
  input[type="text"],input[type="password"],input[type="url"],input[type="number"],
  select,textarea{padding:12px 14px;font-size:16px}
  textarea{min-height:64px}
  .btn{padding:11px 16px;font-size:14px;-webkit-tap-highlight-color:transparent}
  .btn:active{transform:scale(.97)}
  .btn.big{padding:13px 22px}

  /* player: compact sticky bar above bottomnav with mini progress strip */
  .player{
    position:fixed;
    display:flex;
    align-items:center;
    height:auto;min-height:60px;
    padding:0 6px 0 10px;
    bottom:var(--sab);
    gap:4px;
    border-top:1px solid var(--line);
    background:linear-gradient(180deg,#13131a 0%,#0a0a0d 100%);
    -webkit-tap-highlight-color:transparent;
    transition:transform .35s cubic-bezier(.32,.72,.24,1);
  }
  .player-mobile-progress{
    display:block;height:3px;background:transparent;
    position:absolute;left:0;right:0;top:0;
    pointer-events:none;
  }
  .player-mobile-progress::after{
    content:"";display:block;height:100%;background:var(--accent);
    width:var(--mp,0%);transition:width .15s linear;
    box-shadow:0 0 6px var(--accent-glow);
  }
  .player-info{
    flex:1;min-width:0;gap:10px;padding:6px 0;
    cursor:pointer;
  }
  .player-cover{width:46px;height:46px;border-radius:8px}
  .player-title{font-size:13px;max-width:none;line-height:1.2;font-weight:600}
  .player-sub{font-size:11px;max-width:none;color:var(--muted)}
  .player-center{
    flex:0 0 auto;
    flex-direction:row;
    width:auto;
    gap:0;
  }
  .player-controls{gap:0}
  .player-bar{display:none}
  .player-right{display:none}
  .ctrl{width:42px;height:42px}
  .ctrl-main{width:46px;height:46px;background:transparent;color:var(--text)}
  .ctrl-main:hover{background:transparent;transform:none}
  .ctrl-main:active{transform:scale(.92)}
  .ctrl svg{width:22px;height:22px}
  .ctrl-main svg{width:30px;height:30px}
  #btn-shuffle, #btn-repeat{display:none}

  /* fullscreen now-playing overlay (toggled by .np-open on body, .open on .player) */
  .player.expanded{
    position:fixed;
    inset:0;
    bottom:0;
    height:100vh;height:100dvh;
    width:100vw;
    flex-direction:column;
    align-items:stretch;justify-content:flex-start;
    padding:calc(20px + var(--sat)) 22px calc(28px + var(--sab));
    background:linear-gradient(180deg,#1c1c26 0%,#0a0a0d 70%);
    gap:0;border-top:0;
    z-index:120;
    overflow-y:auto;
  }
  .player.expanded .player-mobile-progress{display:none}
  .player.expanded .player-info{
    flex:0 0 auto;flex-direction:column;align-items:center;gap:24px;
    padding:8px 0 0;
  }
  .player.expanded .player-cover{
    width:min(72vw,360px);height:min(72vw,360px);
    border-radius:18px;
    box-shadow:0 30px 60px rgba(0,0,0,.6);
    margin-top:24px;
  }
  .player.expanded .player-text{text-align:center;max-width:100%;width:100%}
  .player.expanded .player-title{
    font-size:22px;line-height:1.2;font-weight:700;
    white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  }
  .player.expanded .player-sub{font-size:14px;margin-top:6px}
  .player.expanded .player-center{
    flex:1 1 auto;flex-direction:column;width:100%;gap:18px;
    margin-top:24px;justify-content:center;
  }
  .player.expanded .player-controls{
    display:flex;justify-content:center;align-items:center;gap:18px;width:100%;
  }
  .player.expanded #btn-shuffle,
  .player.expanded #btn-repeat{display:flex}
  .player.expanded .ctrl{width:52px;height:52px}
  .player.expanded .ctrl svg{width:24px;height:24px}
  .player.expanded .ctrl-main{
    width:72px;height:72px;
    background:var(--text);color:#000;
  }
  .player.expanded .ctrl-main:active{transform:scale(.94)}
  .player.expanded .ctrl-main svg{width:32px;height:32px}
  .player.expanded .player-bar{
    display:flex;width:100%;max-width:100%;
    margin-top:4px;font-size:12px;gap:12px;
  }
  .player.expanded .seek{padding:14px 0}
  .player.expanded .seek-bg{height:5px}
  .player.expanded .seek-thumb{width:14px;height:14px;opacity:1}
  .player.expanded .player-right{
    display:flex;justify-content:center;width:100%;
    margin-top:18px;
  }
  .player.expanded .vol{width:min(80%,320px)}

  /* close handle on expanded player */
  .player.expanded::before{
    content:"";
    position:absolute;top:8px;left:50%;transform:translateX(-50%);
    width:42px;height:5px;border-radius:3px;
    background:rgba(255,255,255,.18);
  }

  /* drag handle area for the dismiss gesture */
  .player.expanded .np-close{
    display:flex;
    position:absolute;top:calc(16px + var(--sat));right:16px;
    width:38px;height:38px;border-radius:50%;
    align-items:center;justify-content:center;
    background:rgba(255,255,255,.08);color:var(--text);
    z-index:2;
  }
  .np-close{display:none}
  .player .np-close svg{width:20px;height:20px;stroke-linecap:round;stroke-linejoin:round}

  /* toast above the player */
  .toast{bottom:calc(80px + var(--sab))}
}

/* ultra small */
@media (max-width:380px){
  .grid{grid-template-columns:1fr 1fr;gap:10px}
  .hero-meta h1{font-size:28px}
  .page-head h1{font-size:23px}
}
