/* ─── Reset & tokens ──────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:           #06080f;
  --surface:      #080d1a;
  --card-bg:      rgba(6, 10, 26, 0.90);
  --border:       rgba(37, 99, 235, 0.14);
  --border-hi:    rgba(96, 165, 250, 0.38);
  --blue:         #3b82f6;
  --blue-dim:     #1d4ed8;
  --blue-glow:    rgba(59, 130, 246, 0.22);
  --sky:          #93c5fd;
  --text:         #e8eef8;
  --text-mid:     #9dabc8;
  --text-dim:     #6b7a96;
  --success:      #10b981;
  --success-dim:  rgba(16, 185, 129, 0.15);
  --danger:       #ef4444;
  --danger-dim:   rgba(239, 68, 68, 0.12);
  --radius:       18px;
  --radius-sm:    10px;
  --t:            0.22s cubic-bezier(.4,0,.2,1);
}

html, body {
  min-height: 100vh;
  background: linear-gradient(145deg, #080c18 0%, #0f1028 20%, #151030 40%, #10142a 60%, #0c1824 80%, #0a0e1c 100%);
  color: var(--text);
  font-family: 'Inter', system-ui, sans-serif;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* ─── Atmospheric background ──────────────────────────────────────────────── */
.bg-layer {
  position: fixed; inset: 0; z-index: 0;
  overflow: hidden; pointer-events: none;
}
.orb {
  position: absolute; border-radius: 50%;
  filter: blur(100px);
  animation: drift linear infinite;
  will-change: transform;
}
.orb-1 { width:800px;height:800px;top:-300px;left:-200px;background:radial-gradient(circle,#1a3a6a,transparent 65%);opacity:.40;animation-duration:34s; }
.orb-2 { width:600px;height:600px;bottom:-200px;right:-100px;background:radial-gradient(circle,#3b1f5e,transparent 65%);opacity:.35;animation-duration:28s;animation-delay:-10s; }
.orb-3 { width:400px;height:400px;top:35%;left:60%;background:radial-gradient(circle,#2255aa,transparent 65%);opacity:.20;animation-duration:44s;animation-delay:-20s; }
.orb-4 { width:550px;height:550px;top:65%;left:-5%;background:radial-gradient(circle,#0e5858,transparent 65%);opacity:.28;animation-duration:38s;animation-delay:-5s; }

@keyframes drift {
  0%  { transform:translate(0,0) scale(1); }
  25% { transform:translate(40px,-60px) scale(1.06); }
  50% { transform:translate(-30px,50px) scale(0.94); }
  75% { transform:translate(60px,20px) scale(1.03); }
  100%{ transform:translate(0,0) scale(1); }
}

.grain {
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat:repeat;
}

/* ─── Layout ──────────────────────────────────────────────────────────────── */
.container {
  position:relative;z-index:10;
  max-width:680px;margin:0 auto;
  padding:64px 20px 100px;
}

/* ─── Header ──────────────────────────────────────────────────────────────── */
.site-header { text-align:center;margin-bottom:52px;user-select:none; }

.logo-mark {
  font-size:2rem;color:var(--blue);opacity:.7;
  display:block;margin-bottom:6px;
  filter:drop-shadow(0 0 18px var(--blue));
  animation:pulse-glow 4s ease-in-out infinite;
}
@keyframes pulse-glow {
  0%,100%{ opacity:.6;filter:drop-shadow(0 0 14px var(--blue)); }
  50%    { opacity:.9;filter:drop-shadow(0 0 28px var(--blue)); }
}

.site-title {
  font-family:'Playfair Display',Georgia,serif;
  font-size:clamp(2rem,7vw,3.8rem);font-weight:600;
  letter-spacing:-.02em;line-height:1;
  background:linear-gradient(140deg,#e0f2fe 0%,#93c5fd 40%,#3b82f6 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:10px;
}
.site-tagline {
  font-family:'Playfair Display',Georgia,serif;
  font-style:italic;font-size:1rem;
  color:var(--sky);letter-spacing:.08em;
  text-shadow:0 0 20px rgba(147,197,253,.35), 0 0 40px rgba(59,130,246,.15);
}

/* Platform icons beneath headline */
.header-platforms {
  display:flex;justify-content:center;gap:10px;margin-top:14px;
  opacity:.45;
}
.header-platforms svg { width:18px;height:18px; }

/* ─── Card ────────────────────────────────────────────────────────────────── */
.card {
  background:var(--card-bg);
  border:1px solid var(--border);border-radius:var(--radius);
  padding:32px 30px 28px;
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  box-shadow:0 0 0 1px rgba(255,255,255,.025),0 40px 80px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.04);
}

/* ─── Mode tabs ───────────────────────────────────────────────────────────── */
.mode-tabs {
  display:flex;gap:3px;
  background:rgba(255,255,255,.04);
  border-radius:10px;padding:4px;
  width:fit-content;margin-bottom:28px;
}
.mode-tab {
  padding:8px 18px;border:none;border-radius:7px;
  background:transparent;color:var(--text-dim);
  font-family:'Inter',sans-serif;font-size:.85rem;font-weight:500;
  cursor:pointer;transition:color var(--t),background var(--t),box-shadow var(--t);
  letter-spacing:.03em;
}
.mode-tab.active {
  background:rgba(59,130,246,.18);color:var(--sky);
  box-shadow:0 0 24px rgba(59,130,246,.18);
}
.mode-tab:not(.active):hover { color:var(--text-mid);background:rgba(255,255,255,.04); }

/* ─── Panels ──────────────────────────────────────────────────────────────── */
.mode-panel.hidden { display:none; }

/* ─── Inputs ──────────────────────────────────────────────────────────────── */
.input-wrap { position:relative; }
.input-icon {
  position:absolute;left:14px;top:50%;transform:translateY(-50%);
  width:17px;height:17px;color:var(--text-dim);pointer-events:none;
}
.main-input,.search-input {
  width:100%;background:rgba(255,255,255,.04);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text);font-family:'Inter',sans-serif;font-size:.9rem;
  padding:13px 16px;outline:none;
  transition:border-color var(--t),box-shadow var(--t),background var(--t);
}
.main-input { padding-left:44px; }
.main-input::placeholder,.search-input::placeholder { color:var(--text-dim); }
.main-input:focus,.search-input:focus {
  border-color:var(--border-hi);background:rgba(255,255,255,.06);
  box-shadow:0 0 0 3px rgba(59,130,246,.12);
}

/* Platform chips */
.platform-chips { display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;margin-bottom:28px; }
.chip {
  display:inline-flex;align-items:center;gap:5px;
  font-size:.72rem;font-weight:500;letter-spacing:.04em;padding:4px 11px;border-radius:20px;
}
.chip svg { width:14px;height:14px;flex-shrink:0; }
.chip-spotify { background:rgba(29,185,84,.1);color:#1DB954;border:1px solid rgba(29,185,84,.2); }
.chip-apple   { background:rgba(252,60,68,.1);color:#fc6369;border:1px solid rgba(252,60,68,.2); }
.chip-youtube { background:rgba(255,50,50,.1);color:#ff5555;border:1px solid rgba(255,50,50,.15); }

/* ─── Search panel ────────────────────────────────────────────────────────── */
.field-wrap { display:flex;flex-direction:column;gap:5px; }
.field-label  { font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#b4c4de; }
.optional     { font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-mid); }
.search-note  { margin-top:12px;font-size:.78rem;color:var(--text-mid); }

/* Song autocomplete wrapper */
.song-input-wrap { position:relative; }

.song-results {
  position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:200;
  background:#0e1628;
  border:1px solid var(--border-hi);
  border-radius:var(--radius-sm);
  box-shadow:0 16px 48px rgba(0,0,0,.7),0 0 0 1px rgba(59,130,246,.08);
  overflow:hidden;
  animation:qi-enter .18s cubic-bezier(.4,0,.2,1);
}

.sr-item {
  display:flex;align-items:center;gap:10px;
  padding:9px 14px;cursor:pointer;
  border-bottom:1px solid rgba(255,255,255,.04);
  transition:background var(--t);
}
.sr-item:last-child { border-bottom:none; }
.sr-item:hover,.sr-item.focused { background:rgba(59,130,246,.1); }

.sr-thumb {
  width:36px;height:36px;border-radius:4px;object-fit:cover;flex-shrink:0;
  background:rgba(255,255,255,.06);
}
.sr-thumb-placeholder {
  width:36px;height:36px;border-radius:4px;flex-shrink:0;
  background:rgba(59,130,246,.1);display:flex;align-items:center;justify-content:center;
  color:var(--blue);font-size:.8rem;
}

.sr-info { flex:1;min-width:0; }
.sr-title {
  font-size:.83rem;color:var(--text);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.sr-channel {
  font-size:.72rem;color:var(--text-dim);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

.sr-duration {
  font-size:.7rem;color:var(--text-dim);flex-shrink:0;
  font-variant-numeric:tabular-nums;
}

.sr-footer {
  padding:8px 14px;
  background:rgba(0,0,0,.25);
  border-top:1px solid rgba(255,255,255,.05);
}
.sr-show-more {
  background:transparent;border:none;color:var(--sky);
  font-family:'Inter',sans-serif;font-size:.78rem;font-weight:500;
  cursor:pointer;padding:0;
  transition:color var(--t);
}
.sr-show-more:hover { color:#fff; }

.sr-loading,.sr-empty {
  padding:14px;text-align:center;
  font-size:.8rem;color:var(--text-dim);
}

/* ─── Format / quality row ────────────────────────────────────────────────── */
.fq-row {
  display:flex;flex-wrap:wrap;gap:14px;
  margin-top:22px;padding-top:22px;
  border-top:1px solid var(--border);
  align-items:flex-end;
}
.select-group { display:flex;flex-direction:column;gap:5px;min-width:140px; }

.select-wrap { position:relative; }
.styled-select {
  appearance:none;-webkit-appearance:none;
  width:100%;background:rgba(255,255,255,.04);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text);font-family:'Inter',sans-serif;font-size:.875rem;
  padding:10px 36px 10px 13px;cursor:pointer;outline:none;
  transition:border-color var(--t),box-shadow var(--t),background var(--t);
}
.styled-select:focus {
  border-color:var(--border-hi);background:rgba(255,255,255,.06);
  box-shadow:0 0 0 3px rgba(59,130,246,.12);
}
.styled-select option { background:#0e1628;color:var(--text); }

.select-chevron {
  position:absolute;right:11px;top:50%;transform:translateY(-50%);
  width:14px;height:14px;color:var(--text-dim);pointer-events:none;
}

.lossless-badge {
  display:inline-block;padding:10px 14px;
  background:rgba(16,185,129,.08);
  border:1px solid rgba(16,185,129,.2);
  border-radius:var(--radius-sm);
  color:var(--success);font-size:.8rem;font-weight:500;
  white-space:nowrap;
}

/* ─── Convert button ──────────────────────────────────────────────────────── */
.convert-btn {
  display:flex;align-items:center;justify-content:center;gap:10px;
  width:100%;margin-top:20px;padding:15px 20px;
  background:linear-gradient(135deg,#1d4ed8 0%,#0369a1 100%);
  border:none;border-radius:var(--radius-sm);
  color:#fff;font-family:'Inter',sans-serif;
  font-size:.92rem;font-weight:600;letter-spacing:.03em;
  cursor:pointer;
  transition:transform var(--t),box-shadow var(--t),opacity var(--t);
  box-shadow:0 0 32px rgba(29,78,216,.35),0 4px 16px rgba(0,0,0,.4);
  position:relative;overflow:hidden;
}
.convert-btn::after {
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.08),transparent);
  pointer-events:none;
}
.convert-btn:hover:not(:disabled) { transform:translateY(-2px);box-shadow:0 0 48px rgba(29,78,216,.55),0 8px 24px rgba(0,0,0,.45); }
.convert-btn:active:not(:disabled) { transform:translateY(0); }
.convert-btn:disabled { opacity:.45;cursor:not-allowed; }
.convert-icon { width:18px;height:18px;flex-shrink:0;opacity:.85; }

/* ─── Queue section ───────────────────────────────────────────────────────── */
.queue-section { margin-top:36px; }

.queue-header {
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:16px;
}

.queue-heading {
  display:flex;align-items:center;gap:8px;
  font-size:.72rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);
}
.queue-heading svg { width:14px;height:14px; }

.queue-actions { display:flex;align-items:center;gap:8px; }

.save-all-btn {
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(59,130,246,.14);
  border:1px solid rgba(59,130,246,.3);
  border-radius:6px;color:var(--sky);
  font-family:'Inter',sans-serif;font-size:.72rem;font-weight:600;
  padding:5px 12px;cursor:pointer;
  transition:background var(--t),box-shadow var(--t),border-color var(--t);
  white-space:nowrap;
}
.save-all-btn svg { width:11px;height:11px;flex-shrink:0; }
.save-all-btn:hover:not(:disabled) {
  background:rgba(59,130,246,.24);
  box-shadow:0 0 14px rgba(59,130,246,.2);
  border-color:rgba(59,130,246,.5);
}
.save-all-btn:disabled { opacity:.45;cursor:not-allowed; }

.clear-done-btn {
  background:transparent;border:1px solid var(--border);
  border-radius:6px;color:var(--text-dim);
  font-family:'Inter',sans-serif;font-size:.72rem;font-weight:500;
  padding:4px 12px;cursor:pointer;
  transition:border-color var(--t),color var(--t);
}
.clear-done-btn:hover { border-color:var(--border-hi);color:var(--text-mid); }

.queue-list {
  list-style:none;display:flex;flex-direction:column;gap:8px;
  max-height:540px;overflow-y:auto;padding-right:4px;
  scrollbar-width:thin;scrollbar-color:rgba(59,130,246,.25) transparent;
}
.queue-list::-webkit-scrollbar { width:5px; }
.queue-list::-webkit-scrollbar-track { background:transparent; }
.queue-list::-webkit-scrollbar-thumb { background:rgba(59,130,246,.25);border-radius:3px; }
.queue-list::-webkit-scrollbar-thumb:hover { background:rgba(59,130,246,.4); }

/* ─── Queue item ──────────────────────────────────────────────────────────── */
.qi {
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.05);
  border-radius:var(--radius-sm);
  padding:14px 16px;
  transition:border-color var(--t),background var(--t);
  animation:qi-enter .28s cubic-bezier(.4,0,.2,1);
}
@keyframes qi-enter {
  from { opacity:0;transform:translateY(8px); }
  to   { opacity:1;transform:translateY(0); }
}

.qi[data-status="downloading"],
.qi[data-status="converting"],
.qi[data-status="finalizing"]  { border-color:var(--border-hi); }

.qi[data-status="complete"]    { border-color:rgba(16,185,129,.22);background:rgba(16,185,129,.04); }
.qi[data-status="error"]       { border-color:rgba(239,68,68,.22);background:rgba(239,68,68,.04); }

/* Top row */
.qi-top {
  display:flex;align-items:center;gap:10px;
  margin-bottom:10px;
}

.qi-status-dot {
  width:7px;height:7px;border-radius:50%;flex-shrink:0;
  background:var(--text-dim);transition:background var(--t);
}
.qi[data-status="queued"]       .qi-status-dot { background:var(--text-dim);opacity:.5;animation:none; }
.qi[data-status="queued"]       .qi-label      { opacity:.6; }

.qi[data-status="searching"] .qi-status-dot,
.qi[data-status="starting"]  .qi-status-dot {
  background:var(--sky);opacity:.6;
  animation:blink 2s ease-in-out infinite;
}

.qi[data-status="downloading"] .qi-status-dot,
.qi[data-status="converting"]  .qi-status-dot,
.qi[data-status="finalizing"]  .qi-status-dot {
  background:var(--blue);
  box-shadow:0 0 6px var(--blue);
  animation:blink 1.5s ease-in-out infinite;
}
.qi[data-status="complete"] .qi-status-dot { background:var(--success);box-shadow:0 0 6px var(--success);animation:none; }
.qi[data-status="error"]    .qi-status-dot { background:var(--danger);box-shadow:none;animation:none; }

@keyframes blink { 0%,100%{opacity:1;}50%{opacity:.4;} }

.qi-label {
  font-size:.9rem;color:var(--text-mid);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;
}
.qi[data-status="complete"] .qi-label { color:var(--text); }

.qi-badges { display:flex;gap:6px;flex-shrink:0;align-items:center; }

.qi-badge {
  font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  padding:2px 7px;border-radius:4px;
  background:rgba(59,130,246,.12);
  color:var(--sky);
  border:1px solid rgba(59,130,246,.18);
}
.qi-badge.lossless {
  background:rgba(16,185,129,.1);color:var(--success);
  border-color:rgba(16,185,129,.2);
}
.qi-badge-large {
  background:rgba(234,179,8,.1);color:#facc15;
  border-color:rgba(234,179,8,.2);opacity:.7;
}

.qi-dismiss {
  background:transparent;border:none;color:var(--text-dim);
  font-size:1rem;line-height:1;cursor:pointer;padding:2px 4px;
  flex-shrink:0;opacity:.6;transition:opacity var(--t),color var(--t);
}
.qi-dismiss:hover { opacity:1;color:var(--danger); }

/* Progress track — hidden, using stage labels instead */
.qi-track { display:none; }

/* Bottom row */
.qi-bottom {
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;
}
.qi-status-text {
  font-size:.8rem;color:var(--text-dim);
  font-variant-numeric:tabular-nums;
}
.qi[data-status="complete"] .qi-status-text { color:var(--success); }
.qi[data-status="error"]    .qi-status-text { color:var(--danger); }

/* qi-meta — small artist/album/date line */
.qi-meta {
  font-size:.78rem;color:var(--text-dim);
  margin:-4px 0 8px 17px; /* indent to align under label */
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  font-style:italic;letter-spacing:.01em;
}

.qi-dl {
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;
  color:var(--sky);text-decoration:none;
  background:rgba(59,130,246,.1);
  border:1px solid rgba(59,130,246,.25);
  border-radius:6px;flex-shrink:0;
  transition:background var(--t),box-shadow var(--t),border-color var(--t);
}
.qi-dl:hover { background:rgba(59,130,246,.22);box-shadow:0 0 14px rgba(59,130,246,.2);border-color:rgba(59,130,246,.5); }
.qi-dl svg { width:14px;height:14px; }

/* ─── Error shake ─────────────────────────────────────────────────────────── */
@keyframes shake {
  0%,100%{transform:translateX(0);}
  20%{transform:translateX(-6px);}
  40%{transform:translateX(6px);}
  60%{transform:translateX(-4px);}
  80%{transform:translateX(4px);}
}
.shake { animation:shake .35s ease;border-color:var(--danger) !important; }

/* ─── Playlist import section ─────────────────────────────────────────────── */
.import-section { margin-top:16px; }

.import-toggle {
  display:flex;align-items:center;gap:8px;width:100%;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text-mid);font-family:'Inter',sans-serif;
  font-size:.82rem;font-weight:500;letter-spacing:.04em;
  padding:11px 16px;cursor:pointer;
  transition:border-color var(--t),color var(--t),background var(--t);
}
.import-toggle:hover { border-color:var(--border-hi);color:var(--text);background:rgba(255,255,255,.05); }
.import-toggle svg:first-child { width:15px;height:15px;flex-shrink:0; }
.toggle-chevron {
  width:14px;height:14px;margin-left:auto;flex-shrink:0;
  transition:transform var(--t);
}
.import-toggle[aria-expanded="true"] .toggle-chevron { transform:rotate(180deg); }

.import-body {
  background:var(--card-bg);
  border:1px solid var(--border);border-top:none;
  border-radius:0 0 var(--radius-sm) var(--radius-sm);
  padding:20px;
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
}

/* Drop zone */
.drop-zone {
  border:2px dashed rgba(59,130,246,.22);border-radius:var(--radius-sm);
  padding:32px 20px;text-align:center;cursor:pointer;
  transition:border-color var(--t),background var(--t);
  position:relative;
}
.drop-zone:hover,.drop-zone.drag-over {
  border-color:var(--border-hi);background:rgba(59,130,246,.05);
}
.drop-icon { width:36px;height:36px;color:var(--blue);opacity:.6;margin:0 auto 12px; display:block; }
.drop-title { font-size:.9rem;font-weight:500;color:var(--text-mid);margin-bottom:4px; }
.drop-sub   { font-size:.78rem;color:var(--text-dim); }
.drop-browse { color:var(--sky);text-decoration:underline;cursor:pointer; }

.format-tags {
  display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:14px;
}
.fmt-tag {
  font-size:.65rem;font-weight:500;letter-spacing:.04em;padding:3px 8px;
  border-radius:4px;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);color:var(--text-dim);
}

/* Import preview */
.import-preview { }

.preview-info {
  display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap;
}
.preview-format {
  font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--sky);background:rgba(59,130,246,.1);
  border:1px solid rgba(59,130,246,.2);border-radius:4px;padding:2px 8px;
}
.preview-count {
  font-size:.78rem;color:var(--text-mid);
}

.preview-list {
  list-style:none;max-height:180px;overflow-y:auto;
  border:1px solid var(--border);border-radius:var(--radius-sm);
  margin-bottom:16px;
  scrollbar-width:thin;scrollbar-color:rgba(59,130,246,.3) transparent;
}
.preview-list li {
  display:flex;gap:8px;padding:7px 12px;
  border-bottom:1px solid rgba(255,255,255,.04);font-size:.8rem;
}
.preview-list li:last-child { border-bottom:none; }
.preview-track  { color:var(--text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }
.preview-artist { color:var(--text-dim);flex-shrink:0;max-width:40%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }
.preview-yt     { color:var(--text-dim);font-size:.7rem;font-style:italic; }

.preview-actions { }

.reset-import-btn {
  display:block;width:100%;margin-top:8px;padding:8px;
  background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text-dim);font-family:'Inter',sans-serif;font-size:.78rem;cursor:pointer;
  transition:border-color var(--t),color var(--t);
}
.reset-import-btn:hover { border-color:var(--border-hi);color:var(--text-mid); }

/* ─── Playlist panel ──────────────────────────────────────────────────────── */
.pl-url-row { display:flex;gap:8px;align-items:stretch; }

.fetch-btn {
  display:inline-flex;align-items:center;gap:7px;
  padding:13px 16px;
  background:rgba(59,130,246,.1);
  border:1px solid rgba(59,130,246,.22);border-radius:var(--radius-sm);
  color:var(--sky);font-family:'Inter',sans-serif;
  font-size:.875rem;font-weight:500;
  cursor:pointer;white-space:nowrap;flex-shrink:0;
  transition:background var(--t),border-color var(--t),box-shadow var(--t);
}
.fetch-btn svg { width:15px;height:15px;flex-shrink:0; }
.fetch-btn:hover:not(:disabled) { background:rgba(59,130,246,.18);border-color:rgba(59,130,246,.4);box-shadow:0 0 14px rgba(59,130,246,.15); }
.fetch-btn:disabled { opacity:.45;cursor:not-allowed; }

/* Error banner */
.pl-error {
  display:flex;align-items:flex-start;gap:10px;
  margin-top:14px;padding:12px 14px;
  background:rgba(239,68,68,.07);
  border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);
  color:#fca5a5;font-size:.82rem;line-height:1.5;
  animation:qi-enter .2s cubic-bezier(.4,0,.2,1);
}
.pl-error-icon { width:16px;height:16px;flex-shrink:0;margin-top:1px;color:#f87171; }
.pl-error-msg  { flex:1; }
.pl-error-close {
  background:transparent;border:none;color:#fca5a5;
  font-size:1.1rem;line-height:1;cursor:pointer;padding:0;
  flex-shrink:0;opacity:.7;transition:opacity var(--t);
}
.pl-error-close:hover { opacity:1; }

/* Loading */
.pl-loading {
  display:flex;align-items:center;gap:12px;
  margin-top:18px;color:var(--text-dim);font-size:.82rem;
}
.pl-spinner {
  width:18px;height:18px;flex-shrink:0;
  border:2px solid rgba(59,130,246,.15);
  border-top-color:var(--blue);
  border-radius:50%;
  animation:spin .7s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }

/* Results container */
.pl-results { margin-top:14px;animation:qi-enter .24s cubic-bezier(.4,0,.2,1); }

.pl-info-bar {
  display:flex;align-items:center;gap:10px;
  margin-bottom:12px;flex-wrap:wrap;
}
.pl-platform-badge {
  font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:2px 8px;border-radius:4px;
}
.pl-platform-badge[data-platform="YouTube"] {
  background:rgba(255,50,50,.12);color:#ff7070;border:1px solid rgba(255,50,50,.2);
}
.pl-platform-badge[data-platform="Spotify"] {
  background:rgba(29,185,84,.1);color:#1DB954;border:1px solid rgba(29,185,84,.2);
}
.pl-platform-badge[data-platform="Apple Music"] {
  background:rgba(252,60,68,.1);color:#fc6369;border:1px solid rgba(252,60,68,.2);
}
.pl-name {
  font-size:.88rem;font-weight:500;color:var(--text);flex:1;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.pl-reset-btn {
  background:transparent;border:none;color:var(--text-dim);
  font-size:1.1rem;cursor:pointer;padding:2px 4px;line-height:1;
  flex-shrink:0;opacity:.5;transition:opacity var(--t),color var(--t);
}
.pl-reset-btn:hover { opacity:1;color:var(--danger); }

/* Select-all header */
.pl-check-header {
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 12px;
  background:rgba(59,130,246,.05);
  border:1px solid rgba(59,130,246,.1);
  border-radius:var(--radius-sm) var(--radius-sm) 0 0;
}
.pl-check-label {
  display:inline-flex;align-items:center;gap:8px;
  font-size:.78rem;color:var(--text-mid);cursor:pointer;
  user-select:none;
}
.pl-check-label input[type="checkbox"] { display:none; }
.pl-check-box {
  width:15px;height:15px;flex-shrink:0;
  border:1.5px solid rgba(59,130,246,.35);border-radius:3px;
  background:transparent;display:flex;align-items:center;justify-content:center;
  transition:background var(--t),border-color var(--t);
}
.pl-check-label input:checked ~ .pl-check-box {
  background:var(--blue);border-color:var(--blue);
}
.pl-check-label input:checked ~ .pl-check-box::after {
  content:'';width:8px;height:5px;
  border-left:1.5px solid #fff;border-bottom:1.5px solid #fff;
  transform:rotate(-45deg) translateY(-1px);display:block;
}
.pl-sel-count { font-size:.72rem;color:var(--text-dim); }

/* Track list */
.pl-track-list {
  list-style:none;
  max-height:260px;overflow-y:auto;
  border:1px solid rgba(59,130,246,.1);border-top:none;
  border-radius:0 0 var(--radius-sm) var(--radius-sm);
  scrollbar-width:thin;scrollbar-color:rgba(59,130,246,.25) transparent;
}
.pl-track-list::-webkit-scrollbar { width:4px; }
.pl-track-list::-webkit-scrollbar-thumb { background:rgba(59,130,246,.25);border-radius:2px; }

.pl-track-item {
  display:flex;align-items:center;gap:10px;
  padding:7px 12px;
  border-bottom:1px solid rgba(255,255,255,.04);
  cursor:pointer;transition:background var(--t);
}
.pl-track-item:last-child { border-bottom:none; }
.pl-track-item:hover { background:rgba(59,130,246,.06); }
.pl-track-item.pl-deselected { opacity:.4; }

.pl-item-check { display:none; }
.pl-item-box {
  width:14px;height:14px;flex-shrink:0;
  border:1.5px solid rgba(59,130,246,.3);border-radius:3px;
  background:transparent;transition:background var(--t),border-color var(--t);
  display:flex;align-items:center;justify-content:center;
}
.pl-track-item:not(.pl-deselected) .pl-item-box {
  background:var(--blue);border-color:var(--blue);
}
.pl-track-item:not(.pl-deselected) .pl-item-box::after {
  content:'';width:7px;height:4px;
  border-left:1.5px solid #fff;border-bottom:1.5px solid #fff;
  transform:rotate(-45deg) translateY(-1px);display:block;
}

.pl-thumb {
  width:34px;height:34px;border-radius:4px;object-fit:cover;flex-shrink:0;
  background:rgba(255,255,255,.06);
}
.pl-thumb-ph {
  width:34px;height:34px;border-radius:4px;flex-shrink:0;
  background:rgba(59,130,246,.08);
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;color:var(--blue);
}
.pl-track-info { flex:1;min-width:0; }
.pl-track-name {
  font-size:.88rem;color:var(--text);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.pl-track-artist {
  font-size:.78rem;color:var(--text-dim);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.pl-track-size {
  font-size:.72rem;color:var(--text-dim);flex-shrink:0;
  font-variant-numeric:tabular-nums;
  padding:1px 5px;border-radius:3px;
  background:rgba(255,255,255,.04);
}
.pl-size-large {
  color:#facc15;background:rgba(234,179,8,.1);
  border:1px solid rgba(234,179,8,.18);
}
.pl-track-dur {
  font-size:.76rem;color:var(--text-dim);flex-shrink:0;
  font-variant-numeric:tabular-nums;
}

/* playlist format/quality row spacing */
.pl-fq-row { margin-top:14px;padding-top:14px; }

/* ─── Utility ─────────────────────────────────────────────────────────────── */
[hidden],.hidden { display:none !important; }

/* ─── Responsive ──────────────────────────────────────────────────────────── */
@media(max-width:520px){
  .card{padding:24px 18px 20px;}
  .fq-row{gap:10px;}
  .select-group{min-width:0;flex:1;}
  .site-title{font-size:3rem;}
  .container{padding:48px 16px 80px;}
  .qi-badges{display:none;}
}
