/* ============================================================
   TikTok Musikmanager — Stylesheet v2
   Aesthetic: Broadcast Control — precise, dark-native, alive
   ============================================================ */

@import url('fonts/fonts.css');

/* ── Design Tokens ─────────────────────────────────────────── */
:root {
  --bg:            #0a0a0d;
  --bg-raised:     #111115;
  --bg-panel:      #16161b;
  --bg-panel-hov:  #1c1c23;
  --bg-input:      #0e0e12;

  --border:        rgba(255,255,255,0.06);
  --border-med:    rgba(255,255,255,0.10);
  --border-strong: rgba(255,255,255,0.18);

  --text:          #eeedf2;
  --text-muted:    #6e6c7e;
  --text-subtle:   #3d3b4a;

  --accent:        #e63946;
  --accent-dim:    rgba(230,57,70,0.12);
  --accent-glow:   rgba(230,57,70,0.4);
  --accent-hover:  #f04550;

  --green:         #2dd4bf;
  --green-dim:     rgba(45,212,191,0.12);
  --amber:         #fb923c;
  --amber-dim:     rgba(251,146,60,0.12);
  --blue:          #60a5fa;
  --blue-dim:      rgba(96,165,250,0.12);

  --skip-glow: 0 0 0 1px var(--accent), 0 0 20px rgba(230,57,70,0.2);

  --radius-xs: 3px;
  --radius-sm: 5px;
  --radius:    9px;
  --radius-lg: 14px;

  --font-display: 'Syne', sans-serif;
  --font-mono:    'DM Mono', monospace;

  --ease:      cubic-bezier(0.4, 0, 0.2, 1);
  --ease-out:  cubic-bezier(0, 0, 0.2, 1);
  --t-fast:    120ms;
  --t:         200ms;
  --t-slow:    350ms;

  --shadow-sm: 0 1px 3px rgba(0,0,0,0.5);
  --shadow:    0 4px 20px rgba(0,0,0,0.6);
  --shadow-lg: 0 16px 48px rgba(0,0,0,0.7);

  /* Neumorphic — dark (inverted): sunken toward black, raised toward dim grey */
  --neu-bg:           #121216;
  --neu-raised:       5px 5px 12px #07070a, -4px -4px 10px #1e1e24;
  --neu-sunken:       inset 3px 3px 8px #07070a, inset -3px -3px 8px #1e1e24;
  --neu-sunken-focus: inset 2px 2px 5px #07070a, inset -2px -2px 5px #1c1c22;
  --neu-btn:          4px 4px 10px #07070a, -3px -3px 8px #1e1e24;
  --neu-btn-active:   inset 2px 2px 6px #07070a, inset -2px -2px 6px #1e1e24;
}

[data-theme="light"] {
  --bg:            #f2f1f5;
  --bg-raised:     #ffffff;
  --bg-panel:      #ffffff;
  --bg-panel-hov:  #f8f7fb;
  --bg-input:      #f5f4f8;

  --border:        rgba(0,0,0,0.07);
  --border-med:    rgba(0,0,0,0.11);
  --border-strong: rgba(0,0,0,0.20);

  --text:          #111016;
  --text-muted:    #65637a;
  --text-subtle:   #b5b3c5;

  --accent:        #d42b38;
  --accent-dim:    rgba(212,43,56,0.09);
  --accent-glow:   rgba(212,43,56,0.25);
  --accent-hover:  #bf2534;

  --green:         #0d9488;
  --green-dim:     rgba(13,148,136,0.10);
  --amber:         #ea6c10;
  --amber-dim:     rgba(234,108,16,0.10);
  --blue:          #2563eb;
  --blue-dim:      rgba(37,99,235,0.09);

  --skip-glow: 0 0 0 1px var(--accent), 0 0 16px rgba(212,43,56,0.15);

  --shadow-sm: 0 1px 3px rgba(0,0,0,0.07);
  --shadow:    0 4px 20px rgba(0,0,0,0.09);
  --shadow-lg: 0 16px 48px rgba(0,0,0,0.13);

  /* Neumorphic — light: raised toward white, sunken toward cool grey */
  --neu-bg:           #e8e8ec;
  --neu-raised:       5px 5px 12px #c8c8cc, -5px -5px 12px #ffffff;
  --neu-sunken:       inset 3px 3px 7px #c0c0c5, inset -3px -3px 7px #ffffff;
  --neu-sunken-focus: inset 2px 2px 4px #c0c0c5, inset -2px -2px 4px #ffffff;
  --neu-btn:          4px 4px 10px #c0c0c5, -4px -4px 10px #ffffff;
  --neu-btn-active:   inset 2px 2px 5px #c0c0c5, inset -2px -2px 5px #ffffff;
}

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

html {
  font-size: 15px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  scroll-behavior: smooth;
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 1rem;
  line-height: 1.65;
  min-height: 100dvh;
  transition: background var(--t-slow) var(--ease), color var(--t-slow) var(--ease);
}

/* Subtle grid texture overlay (dark only) */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.015) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.015) 1px, transparent 1px);
  background-size: 32px 32px;
  pointer-events: none;
  z-index: 0;
  opacity: 1;
  transition: opacity var(--t-slow);
}
[data-theme="light"] body::before { opacity: 0; }

/* ── Typography ─────────────────────────────────────────────── */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 800;
  line-height: 1.12;
  letter-spacing: -0.025em;
  color: var(--text);
}

h1 { font-size: clamp(1.7rem, 4vw, 2.4rem); padding-bottom: 0.08em; }
h2 { font-size: clamp(1.15rem, 2.5vw, 1.5rem); font-weight: 700; }
h3 { font-size: 1rem; font-weight: 600; letter-spacing: -0.01em; }

a { color: var(--accent); text-decoration: none; transition: color var(--t-fast) var(--ease); }
a:hover { color: var(--accent-hover); }

strong { font-weight: 500; }
small  { font-size: 0.8rem; color: var(--text-muted); }
code   { font-family: var(--font-mono); font-size: 0.85em; }

/* ── Layout Shell ───────────────────────────────────────────── */
.shell {
  position: relative;
  z-index: 1;
  max-width: 860px;
  margin: 0 auto;
  padding: 1.75rem 1.25rem 6rem;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.shell--wide { max-width: 1060px; }

/* ── Top Bar ────────────────────────────────────────────────── */
.topbar {
  position: sticky;
  top: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0 1.25rem;
  height: 52px;
  background: color-mix(in srgb, var(--bg-raised) 90%, transparent);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(16px) saturate(180%);
  -webkit-backdrop-filter: blur(16px) saturate(180%);
  transition: background var(--t-slow) var(--ease);
}

.topbar__brand {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 0.95rem;
  letter-spacing: -0.02em;
  color: var(--text);
  text-decoration: none;
  flex-shrink: 0;
  transition: opacity var(--t-fast);
}
.topbar__brand:hover { opacity: 0.75; color: var(--text); }

.topbar__brand-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 0 var(--accent-glow);
  animation: live-pulse 2.8s ease-in-out infinite;
  flex-shrink: 0;
}

@keyframes live-pulse {
  0%   { box-shadow: 0 0 0 0 var(--accent-glow); }
  50%  { box-shadow: 0 0 0 5px transparent; }
  100% { box-shadow: 0 0 0 0 transparent; }
}

.topbar__nav {
  display: flex;
  align-items: center;
  gap: 2px;
  flex: 1;
}

.topbar__nav-link {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--text-muted);
  padding: 0.3rem 0.7rem;
  border-radius: var(--radius-xs);
  transition: color var(--t-fast), background var(--t-fast);
  text-decoration: none;
  white-space: nowrap;
}
.topbar__nav-link:hover { color: var(--text); background: var(--border); }
.topbar__nav-link--active {
  color: var(--text);
  background: var(--border-med);
  font-weight: 500;
}

.topbar__actions {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin-left: auto;
  flex-shrink: 0;
}

/* ── Theme Toggle ───────────────────────────────────────────── */
.theme-toggle {
  width: 34px;
  height: 34px;
  border-radius: var(--radius-xs);
  border: 1px solid var(--border-med);
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color var(--t-fast), border-color var(--t-fast), background var(--t-fast);
  flex-shrink: 0;
}
.theme-toggle:hover {
  color: var(--text);
  border-color: var(--border-strong);
  background: var(--bg-panel);
}

/* ── Panel / Card ───────────────────────────────────────────── */
.panel {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.5rem 1.75rem;
  box-shadow: var(--shadow-sm);
  position: relative;
  transition: background var(--t-slow), border-color var(--t-slow);
}

.panel--accent {
  border-color: var(--accent);
  background: linear-gradient(135deg, var(--bg-panel), color-mix(in srgb, var(--accent) 6%, var(--bg-panel)));
}

.panel--closed {
  border-color: color-mix(in srgb, var(--accent) 40%, transparent);
  background: linear-gradient(135deg, var(--bg-panel), color-mix(in srgb, var(--accent) 4%, var(--bg-panel)));
}

/* ── Eyebrow ────────────────────────────────────────────────── */
.eyebrow {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  font-family: var(--font-mono);
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 0.45rem;
}
.eyebrow::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
  opacity: 0.7;
}
.eyebrow--accent { color: var(--accent); }
.eyebrow--accent::before { opacity: 1; box-shadow: 0 0 6px var(--accent-glow); }
.eyebrow--green  { color: var(--green); }
.eyebrow--amber  { color: var(--amber); }

/* ── Buttons ────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4em;
  padding: 0.5rem 1rem;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
  line-height: 1;
  letter-spacing: 0.01em;
  text-decoration: none;
  transition: background var(--t-fast) var(--ease),
              border-color var(--t-fast) var(--ease),
              color var(--t-fast) var(--ease),
              box-shadow var(--t-fast) var(--ease),
              opacity var(--t-fast);
  -webkit-user-select: none;
  user-select: none;
}
.btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.btn:disabled { opacity: 0.35; cursor: not-allowed; pointer-events: none; }

.btn--primary {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
  font-weight: 600;
}
.btn--primary:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
  box-shadow: 0 0 0 3px var(--accent-dim), 0 2px 8px rgba(230,57,70,0.3);
  color: #fff;
}

.btn--secondary {
  background: var(--bg-panel-hov);
  color: var(--text);
  border-color: var(--border-med);
}
.btn--secondary:hover {
  background: var(--border-med);
  border-color: var(--border-strong);
  color: var(--text);
}

.btn--ghost {
  background: transparent;
  color: var(--text-muted);
  border-color: transparent;
}
.btn--ghost:hover {
  color: var(--text);
  background: var(--border);
}

.btn--danger {
  background: transparent;
  color: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 35%, transparent);
}
.btn--danger:hover {
  background: var(--accent-dim);
  border-color: var(--accent);
  color: var(--accent);
}

.btn--sm { padding: 0.32rem 0.65rem; font-size: 0.74rem; }
.btn--lg { padding: 0.7rem 1.4rem;  font-size: 0.88rem; }
.btn--full { width: 100%; }
.btn--icon { width: 30px; height: 30px; padding: 0; }
.btn--copied { color: var(--green) !important; border-color: var(--green) !important; }

/* ── Forms ──────────────────────────────────────────────────── */
.form-group { display: flex; flex-direction: column; gap: 0.35rem; }
.form-group + .form-group { margin-top: 0.9rem; }

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  align-items: start; /* Fix: columns stay top-aligned, don't stretch to each other's height */
}
/* Reset sibling margin-top inside a row — columns sit side-by-side, not stacked */
.form-row > .form-group + .form-group { margin-top: 0; }
@media (max-width: 520px) {
  .form-row { grid-template-columns: 1fr; }
  .form-row > .form-group + .form-group { margin-top: 0.9rem; }
}

label {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="url"],
input[type="number"],
select,
textarea {
  width: 100%;
  padding: 0.6rem 0.85rem;
  background: var(--bg-input);
  border: 1px solid var(--border-med);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 0.85rem;
  line-height: 1.5;
  transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
  -webkit-appearance: none;
  appearance: none;
}
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-dim);
}
input::placeholder, textarea::placeholder { color: var(--text-subtle); }

select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236e6c7e' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  padding-right: 2rem;
  cursor: pointer;
}
select option { background: var(--bg-panel); color: var(--text); }

textarea { resize: vertical; min-height: 90px; }

.form-hint {
  font-size: 0.72rem;
  color: var(--text-muted);
  margin-top: 0.2rem;
  line-height: 1.4;
}

.duration-picker {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}
.duration-picker select { flex: 1; }
.duration-picker__sep {
  color: var(--text-subtle);
  font-size: 1rem;
  font-weight: 500;
  line-height: 1;
  flex-shrink: 0;
}

/* ── Flash / Alerts ─────────────────────────────────────────── */
.flash {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  padding: 0.7rem 1rem;
  border-radius: var(--radius-sm);
  border: 1px solid;
  font-size: 0.83rem;
  line-height: 1.5;
}
.flash::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 0.42rem;
  background: currentColor;
}
.flash-success { background: var(--green-dim); border-color: color-mix(in srgb, var(--green) 40%, transparent); color: var(--green); }
.flash-error   { background: var(--accent-dim); border-color: color-mix(in srgb, var(--accent) 40%, transparent); color: var(--accent); }
.flash-info    { background: var(--blue-dim); border-color: color-mix(in srgb, var(--blue) 40%, transparent); color: var(--blue); }
.flash--hidden { display: none; }

/* ── Badges ─────────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25em;
  padding: 0.18em 0.5em;
  border-radius: var(--radius-xs);
  font-family: var(--font-mono);
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  border: 1px solid;
  line-height: 1.5;
}
.badge--green  { color: var(--green);  background: var(--green-dim);  border-color: color-mix(in srgb, var(--green) 30%, transparent); }
.badge--red    { color: var(--accent); background: var(--accent-dim); border-color: color-mix(in srgb, var(--accent) 30%, transparent); }
.badge--amber  { color: var(--amber);  background: var(--amber-dim);  border-color: color-mix(in srgb, var(--amber) 30%, transparent); }
.badge--blue   { color: var(--blue);   background: var(--blue-dim);   border-color: color-mix(in srgb, var(--blue) 30%, transparent); }
.badge--muted  { color: var(--text-muted); background: var(--border); border-color: transparent; }

/* ── Queue Counter Strip ────────────────────────────────────── */
.queue-counter {
  display: flex;
  align-items: center;
  gap: 0;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.queue-counter__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.1rem;
  padding: 1rem 1.5rem;
  flex-shrink: 0;
  position: relative;
}
.queue-counter__item + .queue-counter__item::before {
  content: '';
  position: absolute;
  left: 0;
  top: 20%;
  bottom: 20%;
  width: 1px;
  background: var(--border);
}

.queue-counter__value {
  font-family: var(--font-display);
  font-size: 1.9rem;
  font-weight: 800;
  line-height: 1;
  color: var(--text);
  letter-spacing: -0.04em;
  font-variant-numeric: tabular-nums;
}
.queue-counter__value--accent { color: var(--accent); }

.queue-counter__label {
  font-family: var(--font-mono);
  font-size: 0.64rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  white-space: nowrap;
}

.queue-counter__spacer { flex: 1; }

.queue-counter__action {
  padding: 0 1.25rem;
  flex-shrink: 0;
}

/* ── Song Cards ─────────────────────────────────────────────── */
.queue-list {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.song-card {
  display: grid;
  grid-template-columns: 20px 1fr auto;
  align-items: center;
  gap: 0.75rem 0.85rem;
  padding: 0.85rem 1rem;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition:
    border-color var(--t-fast) var(--ease),
    background var(--t-fast) var(--ease),
    box-shadow var(--t-fast) var(--ease);
  position: relative;
}
.song-card:hover {
  border-color: var(--border-med);
  background: var(--bg-panel-hov);
}

/* Accent left strip on hover */
.song-card::before {
  content: '';
  position: absolute;
  left: 0;
  top: 20%;
  bottom: 20%;
  width: 2px;
  border-radius: 0 2px 2px 0;
  background: var(--accent);
  opacity: 0;
  transition: opacity var(--t-fast);
}
.song-card:hover::before { opacity: 0.4; }

.song-card--skipped {
  border-color: var(--accent) !important;
  box-shadow: var(--skip-glow);
  animation: skip-pulse 2.5s ease-in-out infinite;
}
.song-card--skipped::before { opacity: 1 !important; }

@keyframes skip-pulse {
  0%, 100% { box-shadow: var(--skip-glow); }
  50%       { box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 30%, transparent); }
}

.song-card--played {
  opacity: 0.45;
}
.song-card--played:hover { opacity: 0.7; }

.song-card__drag {
  cursor: grab;
  color: var(--text-subtle);
  display: flex;
  align-items: center;
  justify-content: center;
  /* Larger hit area — easier to grab */
  padding: 0.5rem 0.3rem;
  margin: -0.5rem -0.3rem;
  touch-action: none;
  flex-shrink: 0;
  transition: color var(--t-fast);
}
.song-card__drag:hover { color: var(--text-muted); }
.song-card__drag:active { cursor: grabbing; }

/* Disable transitions while dragging — prevents jitter */
.song-card.sortable-chosen,
.song-card.sortable-chosen * {
  transition: none !important;
  animation: none !important;
}
.song-card.sortable-ghost {
  opacity: 0.28;
  transition: none !important;
}
.song-card.sortable-chosen {
  opacity: 0.88;
  box-shadow: var(--shadow-lg);
  background: var(--bg-panel-hov);
}

.song-card__body  { min-width: 0; }

.song-card__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.92rem;
  letter-spacing: -0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.3;
  margin-bottom: 0.25rem;
  color: var(--text);
}
.song-card__artist {
  font-weight: 400;
  color: var(--text-muted);
  font-family: var(--font-mono);
}

.song-card__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  font-size: 0.72rem;
  color: var(--text-muted);
  line-height: 1;
}

.song-card__tiktok  { color: var(--text-muted); }

.song-card__platform {
  font-size: 0.63rem;
  padding: 0.15em 0.45em;
  border-radius: var(--radius-xs);
  background: var(--border);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border: 1px solid var(--border-med);
}

.song-card__eta     { color: var(--text-subtle); }
.song-card__dur     { color: var(--text-subtle); }
.song-card__played-at { color: var(--text-subtle); font-style: italic; }

.song-card__actions {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  flex-shrink: 0;
}

/* ── Public Queue Preview ───────────────────────────────────── */
/* ── Public Queue ────────────────────────────────────────────── */
.public-queue {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

/* Compact single-row design: #  title · artist  [platform]  ETA */
.pq-item {
  display: grid;
  grid-template-columns: 2rem 1fr auto;
  align-items: center;
  gap: 0 0.6rem;
  padding: 0.48rem 0.75rem;
  border-radius: var(--radius-sm);
  background: transparent;
  border: 1px solid transparent;
  transition: background var(--t-fast), border-color var(--t-fast);
}
.pq-item:hover {
  background: var(--bg-raised);
  border-color: var(--border);
}

.pq-item__pos {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 0.72rem;
  color: var(--text-subtle);
  text-align: right;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

/* Single line: "Song Title · Artist" */
.pq-item__line {
  min-width: 0;
  display: flex;
  align-items: baseline;
  gap: 0;
  white-space: nowrap;
  overflow: hidden;
}
.pq-item__title {
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex-shrink: 1;
  min-width: 3rem;
}
.pq-item__sep {
  color: var(--text-subtle);
  margin: 0 0.35em;
  flex-shrink: 0;
  font-size: 0.75rem;
}
.pq-item__artist {
  font-size: 0.75rem;
  color: var(--text-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex-shrink: 2;
  min-width: 2rem;
}

/* Right side: platform badge + ETA */
.pq-item__right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}
.pq-item__platform {
  font-size: 0.6rem;
  padding: 0.1em 0.4em;
  border-radius: 2px;
  background: var(--border);
  color: var(--text-subtle);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  border: 1px solid var(--border-med);
  line-height: 1.6;
}
.pq-item__eta {
  font-size: 0.7rem;
  color: var(--text-subtle);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  min-width: 2.5rem;
  text-align: right;
}

.pq-item--skipped {
  background: var(--accent-dim);
  border-color: color-mix(in srgb, var(--accent) 30%, transparent) !important;
}
.pq-item--skipped .pq-item__pos  { color: var(--accent); }
.pq-item--skipped .pq-item__title { color: var(--accent); }

/* ── Public Played List ──────────────────────────────────────── */
.played-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.played-item {
  display: grid;
  grid-template-columns: 1.5rem 1fr auto;
  align-items: center;
  gap: 0 0.6rem;
  padding: 0.45rem 0.75rem;
  border-radius: var(--radius-sm);
  background: transparent;
  border: 1px solid transparent;
  transition: background var(--t-fast), border-color var(--t-fast);
  opacity: 0.6;
}
.played-item:hover {
  background: var(--bg-raised);
  border-color: var(--border);
  opacity: 0.9;
}

.played-item__check {
  font-size: 0.65rem;
  color: var(--green);
  text-align: right;
  line-height: 1;
}

.played-item__line {
  min-width: 0;
  display: flex;
  align-items: baseline;
  gap: 0;
  white-space: nowrap;
  overflow: hidden;
}
.played-item__title {
  font-size: 0.8rem;
  font-weight: 400;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex-shrink: 1;
  min-width: 3rem;
  text-decoration: none;
}
.played-item__sep {
  color: var(--text-subtle);
  margin: 0 0.35em;
  flex-shrink: 0;
  font-size: 0.75rem;
}
.played-item__artist {
  font-size: 0.72rem;
  color: var(--text-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex-shrink: 2;
  min-width: 2rem;
}

.played-item__right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}
.played-item__time {
  font-size: 0.66rem;
  color: var(--text-subtle);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.played-item__link {
  display: inline-flex;
  align-items: center;
  color: var(--text-subtle);
  transition: color var(--t-fast);
}
.played-item__link:hover { color: var(--accent); }

/* ── Section Header ─────────────────────────────────────────── */
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 0.6rem;
  padding: 0 0.1rem;
}
.section-header__left   { display: flex; align-items: center; gap: 0.6rem; }
.section-header__actions { display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap; }

.section-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.9rem;
  letter-spacing: -0.01em;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 0.45rem;
}

/* ── Tables ─────────────────────────────────────────────────── */
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

table { width: 100%; border-collapse: collapse; font-size: 0.82rem; }

th {
  text-align: left;
  padding: 0.6rem 1rem;
  font-family: var(--font-mono);
  font-size: 0.66rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  color: var(--text-muted);
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
  background: var(--bg-raised);
}
th:first-child { border-radius: var(--radius-lg) 0 0 0; }
th:last-child  { border-radius: 0 var(--radius-lg) 0 0; }

td {
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  color: var(--text);
}
tr:last-child td { border-bottom: none; }
tr:hover td { background: var(--bg-panel-hov); }

/* ── Login Page ─────────────────────────────────────────────── */
.login-wrap {
  min-height: 100dvh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem 1.25rem;
  position: relative;
}

/* Decorative background gradient for login */
.login-wrap::before {
  content: '';
  position: fixed;
  top: -20%;
  left: 50%;
  transform: translateX(-50%);
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, color-mix(in srgb, var(--accent) 8%, transparent) 0%, transparent 70%);
  pointer-events: none;
}

.login-card {
  width: 100%;
  max-width: 360px;
  position: relative;
  z-index: 1;
}

.login-logo {
  text-align: center;
  margin-bottom: 2.25rem;
}

.login-logo__mark {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: var(--accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
  box-shadow: 0 0 0 8px var(--accent-dim), 0 8px 24px rgba(230,57,70,0.3);
  animation: logo-breathe 3s ease-in-out infinite;
}
@keyframes logo-breathe {
  0%, 100% { box-shadow: 0 0 0 8px var(--accent-dim), 0 8px 24px rgba(230,57,70,0.3); }
  50%       { box-shadow: 0 0 0 4px var(--accent-dim), 0 4px 16px rgba(230,57,70,0.2); }
}

.login-logo__title {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--text);
}
.login-logo__sub {
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-top: 0.2rem;
}

/* ── Collapsible ────────────────────────────────────────────── */
.collapsible {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: border-color var(--t-fast);
}
.collapsible:hover { border-color: var(--border-med); }
.collapsible + .collapsible { margin-top: 0.4rem; }

.collapsible__toggle {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.8rem 1rem;
  background: var(--bg-panel);
  border: none;
  color: var(--text);
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: 0.83rem;
  gap: 0.75rem;
  transition: background var(--t-fast);
  text-align: left;
}
.collapsible__toggle:hover { background: var(--bg-panel-hov); }

.collapsible__arrow {
  color: var(--text-muted);
  transition: transform var(--t) var(--ease);
  flex-shrink: 0;
}
.collapsible--open .collapsible__arrow { transform: rotate(180deg); }

.collapsible__body {
  display: none;
  padding: 1rem;
  border-top: 1px solid var(--border);
  background: var(--bg);
}
.collapsible--open .collapsible__body { display: block; }

/* ── Application Cards ───────────────────────────────────────── */

/* Meta row: Kontakt · E-Mail · Website in einer Zeile */
.app-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 1.25rem;
  font-size: 0.8rem;
  color: var(--text);
}
.app-meta__label {
  font-size: 0.68rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--text-muted);
  margin-right: 0.35em;
}
.app-meta__link {
  color: var(--accent);
  word-break: break-all;
}
.app-meta__link:hover { text-decoration: underline; }

/* Message block — preserves line breaks */
.app-message {
  font-size: 0.82rem;
  line-height: 1.7;
  white-space: pre-wrap;       /* keeps \n from textarea */
  word-break: break-word;
  background: var(--bg);
  border: 1px solid var(--border-med);
  border-left: 3px solid var(--border-strong);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  padding: 0.75rem 1rem;
  color: var(--text);
  max-height: 14rem;
  overflow-y: auto;
}

/* Timestamps row */
.app-timestamps {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 1.25rem;
  font-size: 0.72rem;
  color: var(--text-muted);
}
.app-timestamps span {
  display: inline-flex;
  align-items: center;
  gap: 0.3em;
}
.app-timestamps svg { flex-shrink: 0; opacity: 0.6; }

.app-timestamps__decision {
  font-weight: 500;
}
.app-timestamps__decision--accepted { color: var(--green); }
.app-timestamps__decision--accepted svg { opacity: 1; }
.app-timestamps__decision--rejected { color: var(--accent); }
.app-timestamps__decision--rejected svg { opacity: 1; }
.app-timestamps__decision strong { font-weight: 600; }

/* ── Label Apply Link ───────────────────────────────────────── */
.label-apply-link {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--text-muted);
  border: 1px solid var(--border-med);
  border-radius: var(--radius-sm);
  padding: 0.48rem 0.85rem;
  transition: color var(--t-fast), border-color var(--t-fast), background var(--t-fast);
  text-decoration: none;
  white-space: nowrap;
}
.label-apply-link:hover {
  color: var(--text);
  border-color: var(--border-strong);
  background: var(--border);
}
.label-apply-link svg { flex-shrink: 0; opacity: 0.7; }

/* ── Divider ────────────────────────────────────────────────── */
.divider { height: 1px; background: var(--border); border: none; margin: 0.25rem 0; }

/* ── Empty State ────────────────────────────────────────────── */
.empty-state {
  text-align: center;
  padding: 3rem 1.5rem;
  color: var(--text-muted);
  font-size: 0.85rem;
}
.empty-state__icon {
  font-size: 2rem;
  margin-bottom: 0.75rem;
  opacity: 0.4;
}

/* ── Utility ────────────────────────────────────────────────── */
.text-muted   { color: var(--text-muted) !important; }
.text-subtle  { color: var(--text-subtle) !important; }
.text-accent  { color: var(--accent); }
.text-green   { color: var(--green); }
.text-amber   { color: var(--amber); }
.text-sm      { font-size: 0.82rem; }
.text-xs      { font-size: 0.72rem; }
.font-display { font-family: var(--font-display); }

.flex         { display: flex; }
.flex-center  { display: flex; align-items: center; }
.flex-between { display: flex; align-items: center; justify-content: space-between; }
.flex-col     { flex-direction: column; }
.flex-wrap    { flex-wrap: wrap; }
.flex-1       { flex: 1; min-width: 0; }
.gap-xs { gap: 0.3rem; }
.gap-sm { gap: 0.5rem; }
.gap    { gap: 0.75rem; }
.gap-lg { gap: 1.25rem; }
.mt-xs  { margin-top: 0.35rem; }
.mt-sm  { margin-top: 0.6rem; }
.mt     { margin-top: 1rem; }
.mt-lg  { margin-top: 1.5rem; }
.mb-sm  { margin-bottom: 0.6rem; }
.mb     { margin-bottom: 1rem; }
.truncate { overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.w-full { width: 100%; }

.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ── Footer ─────────────────────────────────────────────────── */
.site-footer {
  position: relative;
  z-index: 1;
  text-align: center;
  font-size: 0.68rem;
  color: var(--text-subtle);
  padding: 2rem 1.25rem 1.5rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 580px) {
  .shell { padding: 1rem 0.9rem 5rem; gap: 1rem; }
  .topbar { padding: 0 0.9rem; }
  .panel { padding: 1.1rem 1rem; }
  h1 { font-size: 1.5rem; }
  .queue-counter__item { padding: 0.75rem 1rem; }
  .queue-counter__value { font-size: 1.5rem; }
  .song-card { grid-template-columns: 18px 1fr; }
  .song-card__actions { grid-column: 2; justify-content: flex-start; padding-top: 0.25rem; }
  .topbar__nav-link { padding: 0.25rem 0.5rem; font-size: 0.72rem; }
}

/* ── Page entrance ───────────────────────────────────────────── */
@keyframes fade-up {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.shell > * {
  animation: fade-up var(--t-slow) var(--ease-out) both;
}
.shell > *:nth-child(1) { animation-delay: 0.03s; }
.shell > *:nth-child(2) { animation-delay: 0.07s; }
.shell > *:nth-child(3) { animation-delay: 0.11s; }
.shell > *:nth-child(4) { animation-delay: 0.15s; }
.shell > *:nth-child(5) { animation-delay: 0.18s; }

/* ============================================================
   NEUMORPHIC OVERRIDES
   Applied to both themes via --neu-* variables.
   Light = classic raised/sunken.
   Dark  = inverted (same geometry, darker shadows).
   ============================================================ */

/* ── Neumorphic Body background ──────────────────────────────── */
[data-theme="light"] body { background: var(--neu-bg); }
[data-theme="dark"]  body { background: var(--neu-bg); }

/* Grid texture off in both when neumorphic */
[data-theme="light"] body::before,
[data-theme="dark"]  body::before { opacity: 0; }

/* ── Neumorphic Panels ───────────────────────────────────────── */
[data-theme="light"] .panel,
[data-theme="dark"]  .panel {
  background: var(--neu-bg);
  border: none;
  box-shadow: var(--neu-raised);
}

[data-theme="light"] .panel--accent,
[data-theme="dark"]  .panel--accent {
  box-shadow: var(--neu-raised), 0 0 0 2px var(--accent);
  background: var(--neu-bg);
}

[data-theme="light"] .panel--closed,
[data-theme="dark"]  .panel--closed {
  box-shadow: var(--neu-raised), 0 0 0 1px color-mix(in srgb, var(--accent) 40%, transparent);
  background: var(--neu-bg);
}

/* ── Neumorphic Topbar ───────────────────────────────────────── */
[data-theme="light"] .topbar,
[data-theme="dark"]  .topbar {
  background: var(--neu-bg);
  border-bottom: none;
  box-shadow: 0 3px 10px rgba(0,0,0,0.12);
}
[data-theme="dark"] .topbar {
  box-shadow: 0 3px 12px rgba(0,0,0,0.5);
}

/* ── Neumorphic Inputs ───────────────────────────────────────── */
[data-theme="light"] input[type="text"],
[data-theme="light"] input[type="email"],
[data-theme="light"] input[type="password"],
[data-theme="light"] input[type="url"],
[data-theme="light"] input[type="number"],
[data-theme="light"] select,
[data-theme="light"] textarea,
[data-theme="dark"]  input[type="text"],
[data-theme="dark"]  input[type="email"],
[data-theme="dark"]  input[type="password"],
[data-theme="dark"]  input[type="url"],
[data-theme="dark"]  input[type="number"],
[data-theme="dark"]  select,
[data-theme="dark"]  textarea {
  background: var(--neu-bg);
  border: none;
  box-shadow: var(--neu-sunken);
  color: var(--text);
  border-radius: 999px; /* pill shape — classic neumorphic */
  padding: 0.65rem 1.1rem;
  transition: box-shadow var(--t) var(--ease), color var(--t-fast);
}

/* Textarea and select keep square-ish radius — pill looks odd there */
[data-theme="light"] textarea,
[data-theme="dark"]  textarea {
  border-radius: var(--radius-lg);
}
[data-theme="light"] select,
[data-theme="dark"]  select {
  border-radius: 999px;
}

[data-theme="light"] input:focus,
[data-theme="light"] select:focus,
[data-theme="light"] textarea:focus,
[data-theme="dark"]  input:focus,
[data-theme="dark"]  select:focus,
[data-theme="dark"]  textarea:focus {
  outline: none;
  box-shadow: var(--neu-sunken-focus), 0 0 0 2px var(--accent);
  border: none;
}

/* Duration picker selects — pill on both */
[data-theme="light"] .duration-picker select,
[data-theme="dark"]  .duration-picker select {
  border-radius: 999px;
}

/* ── Neumorphic Buttons ──────────────────────────────────────── */

/* Primary — accent fill, raised shadow */
[data-theme="light"] .btn--primary,
[data-theme="dark"]  .btn--primary {
  border: none;
  border-radius: 999px;
  box-shadow: var(--neu-btn);
  background: var(--accent);
  color: #fff;
  font-weight: 600;
}
[data-theme="light"] .btn--primary:hover,
[data-theme="dark"]  .btn--primary:hover {
  box-shadow: var(--neu-btn), 0 0 0 3px var(--accent-dim);
  background: var(--accent-hover);
}
[data-theme="light"] .btn--primary:active,
[data-theme="dark"]  .btn--primary:active {
  box-shadow: var(--neu-btn-active);
}

/* Secondary — raised, no fill */
[data-theme="light"] .btn--secondary,
[data-theme="dark"]  .btn--secondary {
  border: none;
  border-radius: 999px;
  background: var(--neu-bg);
  box-shadow: var(--neu-btn);
  color: var(--text);
}
[data-theme="light"] .btn--secondary:hover,
[data-theme="dark"]  .btn--secondary:hover {
  box-shadow: var(--neu-raised);
}
[data-theme="light"] .btn--secondary:active,
[data-theme="dark"]  .btn--secondary:active {
  box-shadow: var(--neu-btn-active);
}

/* Ghost */
[data-theme="light"] .btn--ghost,
[data-theme="dark"]  .btn--ghost {
  border: none;
  border-radius: 999px;
  background: transparent;
  box-shadow: none;
  color: var(--text-muted);
}
[data-theme="light"] .btn--ghost:hover,
[data-theme="dark"]  .btn--ghost:hover {
  box-shadow: var(--neu-raised);
  background: var(--neu-bg);
  color: var(--text);
}

/* Danger */
[data-theme="light"] .btn--danger,
[data-theme="dark"]  .btn--danger {
  border: none;
  border-radius: 999px;
  background: var(--neu-bg);
  box-shadow: var(--neu-btn);
  color: var(--accent);
}
[data-theme="light"] .btn--danger:hover,
[data-theme="dark"]  .btn--danger:hover {
  box-shadow: var(--neu-btn), 0 0 0 2px var(--accent);
}
[data-theme="light"] .btn--danger:active,
[data-theme="dark"]  .btn--danger:active {
  box-shadow: var(--neu-btn-active);
}

/* Icon buttons — keep square-ish */
[data-theme="light"] .btn--icon,
[data-theme="dark"]  .btn--icon {
  border-radius: var(--radius);
}

/* Theme toggle */
[data-theme="light"] .theme-toggle,
[data-theme="dark"]  .theme-toggle {
  border: none;
  border-radius: var(--radius);
  background: var(--neu-bg);
  box-shadow: var(--neu-btn);
}
[data-theme="light"] .theme-toggle:hover,
[data-theme="dark"]  .theme-toggle:hover {
  box-shadow: var(--neu-raised);
}

/* ── Neumorphic Queue/Song Cards ─────────────────────────────── */
[data-theme="light"] .song-card,
[data-theme="dark"]  .song-card {
  border: none;
  background: var(--neu-bg);
  box-shadow: var(--neu-raised);
}
[data-theme="light"] .song-card:hover,
[data-theme="dark"]  .song-card:hover {
  box-shadow: var(--neu-raised), inset 0 0 0 999px rgba(255,255,255,0.02);
}
[data-theme="light"] .song-card--skipped,
[data-theme="dark"]  .song-card--skipped {
  box-shadow: var(--neu-raised), 0 0 0 1px var(--accent) !important;
}
[data-theme="light"] .song-card::before,
[data-theme="dark"]  .song-card::before { display: none; } /* remove accent strip — neu handles it */

/* Public queue items */
[data-theme="light"] .pq-item:hover,
[data-theme="dark"]  .pq-item:hover {
  background: var(--neu-bg);
  border: none;
  box-shadow: var(--neu-raised);
}
[data-theme="light"] .pq-item--skipped,
[data-theme="dark"]  .pq-item--skipped {
  background: var(--neu-bg);
  border: none;
  box-shadow: var(--neu-raised), 0 0 0 1px color-mix(in srgb, var(--accent) 40%, transparent);
}

/* Played items hover */
[data-theme="light"] .played-item:hover,
[data-theme="dark"]  .played-item:hover {
  background: var(--neu-bg);
  border: none;
  box-shadow: var(--neu-raised);
}

/* ── Neumorphic Queue Counter ────────────────────────────────── */
[data-theme="light"] .queue-counter,
[data-theme="dark"]  .queue-counter {
  border: none;
  background: var(--neu-bg);
  box-shadow: var(--neu-raised);
}

/* ── Neumorphic Collapsible ──────────────────────────────────── */
[data-theme="light"] .collapsible,
[data-theme="dark"]  .collapsible {
  border: none;
  box-shadow: var(--neu-raised);
  background: var(--neu-bg);
  border-radius: var(--radius-lg);
}
[data-theme="light"] .collapsible__toggle,
[data-theme="dark"]  .collapsible__toggle {
  background: var(--neu-bg);
}
[data-theme="light"] .collapsible__toggle:hover,
[data-theme="dark"]  .collapsible__toggle:hover {
  background: var(--neu-bg);
  box-shadow: inset 0 0 0 999px rgba(255,255,255,0.03);
}
[data-theme="light"] .collapsible__body,
[data-theme="dark"]  .collapsible__body {
  background: color-mix(in srgb, var(--neu-bg) 95%, transparent);
  border-top: 1px solid var(--border);
}

/* ── Neumorphic Flash messages ───────────────────────────────── */
[data-theme="light"] .flash,
[data-theme="dark"]  .flash {
  border: none;
  box-shadow: var(--neu-raised);
}

/* ── Neumorphic Table ────────────────────────────────────────── */
[data-theme="light"] .panel th,
[data-theme="dark"]  .panel th {
  background: color-mix(in srgb, var(--neu-bg) 95%, black);
}

/* ── Neumorphic Label Apply Link ─────────────────────────────── */
[data-theme="light"] .label-apply-link,
[data-theme="dark"]  .label-apply-link {
  border: none;
  border-radius: 999px;
  background: var(--neu-bg);
  box-shadow: var(--neu-btn);
}
[data-theme="light"] .label-apply-link:hover,
[data-theme="dark"]  .label-apply-link:hover {
  box-shadow: var(--neu-raised);
  color: var(--text);
}

/* ── Login card ──────────────────────────────────────────────── */
[data-theme="light"] .login-logo__mark,
[data-theme="dark"]  .login-logo__mark {
  box-shadow: var(--neu-raised), 0 0 0 6px var(--accent-dim);
  animation: none; /* keep it static in neu mode */
}
[data-theme="light"] .login-wrap::before,
[data-theme="dark"]  .login-wrap::before { display: none; }

/* ── App message block ───────────────────────────────────────── */
[data-theme="light"] .app-message,
[data-theme="dark"]  .app-message {
  border: none;
  border-left: 3px solid var(--border-strong);
  background: color-mix(in srgb, var(--neu-bg) 80%, black);
  box-shadow: var(--neu-sunken);
  border-radius: var(--radius-lg);
}

/* ============================================================
   UTILITY CLASSES — replaces all inline style="" attributes
   to comply with Content-Security-Policy: style-src 'self'
   ============================================================ */

/* Label hint spans (Spotify-Hinweis, "optional", "min. 8 Zeichen") */
.label-hint {
  font-size: 0.65rem;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 400;
}

/* Queue counter ETA value — slightly smaller than number values */
.queue-counter__value--time {
  font-size: 1.2rem;
  letter-spacing: -0.02em;
}

/* Forms inside flex rows that need no extra margin */
.form-inline { margin: 0; display: contents; }
.m-0 { margin: 0; }

/* Played checkmark cell */
.played-check {
  color: var(--green);
  font-size: 0.75rem;
  text-align: center;
  line-height: 1;
}

/* Panel with no padding and clipped overflow (user table) */
.panel--flush {
  padding: 0;
  overflow: hidden;
}

/* Inline role select inside table cell */
.role-select {
  padding: 0.22rem 1.75rem 0.22rem 0.5rem;
  font-size: 0.74rem;
  width: auto;
}

/* Password collapsible dropdown — positioned relative to its trigger */
.pw-collapsible {
  position: relative;
  display: inline-block;
}
.pw-collapsible .collapsible__toggle {
  height: 28px;
  padding: 0 0.6rem;
  font-size: 0.72rem;
}
.pw-collapsible .collapsible__body {
  position: absolute;
  right: 0;
  top: calc(100% + 4px);
  z-index: 20;
  background: var(--bg-panel);
  border: 1px solid var(--border-med);
  border-radius: var(--radius);
  padding: 0.7rem;
  min-width: 240px;
  box-shadow: var(--shadow-lg);
  width: max-content;
}
.pw-input {
  flex: 1;
  font-size: 0.78rem;
}
.btn--table {
  height: 28px;
}

/* Settings page section eyebrow spacing */
.eyebrow--section { margin-top: 1.5rem; }

/* Settings divider spacing */
.divider--section { margin: 1.5rem 0; }

/* Applications badge inline */
.badge--inline {
  font-size: 0.65rem;
  vertical-align: middle;
  margin-left: 0.25rem;
}

/* Application decision action row */
.app-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--border);
  margin-top: 0.25rem;
}

/* ── Sync indicator dot ──────────────────────────────────────── */
.sync-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green);
  flex-shrink: 0;
  opacity: 0.45;
  transition: opacity 0.3s, transform 0.3s;
  align-self: center;
}
.sync-dot--pulse {
  opacity: 1;
  transform: scale(1.6);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--green) 25%, transparent);
}

/* pw-collapsible flex-col form ──────────────────────────────── */
.pw-collapsible .flex-col { gap: 0.5rem; }

/* ── Embedded Player Panel ───────────────────────────────────── */
.player-panel {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  min-height: 100px;
  transition: background var(--t-slow), border-color var(--t-slow);
}

.player-panel__inner {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  width: 100%;
}

/* Embedded platform players */
.player-embed-iframe,
.player-spotify-iframe {
  width: 100%;
  height: 152px;  /* Spotify compact player height */
  border: none;
  display: block;
}

.player-embed-iframe--youtube {
  aspect-ratio: 16 / 9;
  height: auto;
  min-height: 220px;
}

.player-embed-iframe--soundcloud {
  height: 166px;
}

.player-embed-iframe--suno {
  height: 240px;
}

.player-embed-iframe--tiktok {
  height: min(70vh, 640px);
  min-height: 420px;
  background: #000;
}

/* Label above iframe */
.player-label {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--text-muted);
  padding: 0.6rem 1rem 0.3rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  letter-spacing: 0.02em;
}
.player-label--muted { opacity: 0.7; }

/* Default image */
.player-default-img {
  width: 100%;
  height: 180px;
  max-height: 180px;
  object-fit: cover;
  object-position: center center;
  display: block;
}

/* Idle state */
.player-idle {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 2rem 1.5rem;
  color: var(--text-subtle);
  font-size: 0.8rem;
  text-align: center;
  min-height: 100px;
}
.player-idle svg { opacity: 0.4; }
.player-idle small { font-size: 0.72rem; }

/* Play button on song cards */
.btn--play {
  color: var(--text-muted);
  transition: color var(--t-fast), background var(--t-fast);
}
.btn--play:hover { color: var(--accent); }
.btn--play-active {
  color: var(--accent) !important;
  background: var(--accent-dim) !important;
}
.btn--play-active svg { animation: play-pulse 1.2s ease-in-out infinite; }
@keyframes play-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.5; }
}

/* Neumorphic overrides for player panel */
[data-theme="light"] .player-panel,
[data-theme="dark"]  .player-panel {
  border: none;
  box-shadow: var(--neu-raised);
  background: var(--neu-bg);
}

/* ── Settings: image upload preview ─────────────────────────── */
.player-image-preview {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 0.75rem;
  margin-bottom: 0.5rem;
}
.player-image-preview img {
  width: 160px;
  height: 90px;
  object-fit: cover;
  border-radius: var(--radius);
  border: 1px solid var(--border-med);
  display: block;
}

/* file input */
input[type="file"] {
  font-family: var(--font-mono);
  font-size: 0.82rem;
  color: var(--text-muted);
  background: transparent;
  border: 1px dashed var(--border-strong);
  border-radius: var(--radius-sm);
  padding: 0.5rem 0.75rem;
  width: 100%;
  cursor: pointer;
  transition: border-color var(--t-fast), color var(--t-fast);
  box-shadow: none;
}
input[type="file"]:hover {
  border-color: var(--accent);
  color: var(--text);
}
[data-theme="light"] input[type="file"],
[data-theme="dark"]  input[type="file"] {
  box-shadow: none;
  border-radius: var(--radius-sm);
  border: 1px dashed var(--border-strong);
  background: transparent;
}
