/* ===================================================
   RADIO COCKPIT — Gedeeld stylesheet (krant.css)
   =================================================== */

* { box-sizing: border-box; }

body {
  min-height: 100vh;
  font-family: 'Segoe UI', system-ui, sans-serif;
  font-size: 14px;
  transition: background 0.3s;
}

[data-bs-theme="dark"] body {
  background: radial-gradient(ellipse at top left, #0f172a 0%, #020617 100%) fixed;
  color: #f1f5f9;
}
[data-bs-theme="light"] body {
  background: radial-gradient(ellipse at top left, #60a5fa 0%, #a5b4fc 100%) fixed;
  color: #0f172a;
}

/* ── Navigatiebalk ── */
.top-nav {
  margin: 10px 16px;
  border-radius: 18px;
  backdrop-filter: blur(15px);
  padding: 8px 18px;
}
[data-bs-theme="dark"] .top-nav {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
}
[data-bs-theme="light"] .top-nav {
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.12);
  box-shadow: 0 2px 14px rgba(0,0,0,0.12);
}

.nav-link {
  font-weight: 500;
  border-radius: 10px;
  padding: 7px 12px !important;
  transition: 0.15s;
  font-size: 0.88rem;
}
[data-bs-theme="dark"] .nav-link          { color: rgba(255,255,255,0.60) !important; }
[data-bs-theme="dark"] .nav-link:hover    { color: #fff !important; background: rgba(255,255,255,0.08); }
[data-bs-theme="dark"] .nav-link.active   { color: #fff !important; background: rgba(255,255,255,0.08); font-weight: 700; }
[data-bs-theme="light"] .nav-link         { color: rgba(0,0,0,0.60) !important; }
[data-bs-theme="light"] .nav-link:hover   { color: #000 !important; background: rgba(0,0,0,0.06); }
[data-bs-theme="light"] .nav-link.active  { color: #000 !important; background: rgba(0,0,0,0.08); font-weight: 700; }

/* ── Kaarten ── */
.glass, .glass-card {
  backdrop-filter: blur(20px);
  border-radius: 22px;
}
[data-bs-theme="dark"] .glass,
[data-bs-theme="dark"] .glass-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}
[data-bs-theme="light"] .glass,
[data-bs-theme="light"] .glass-card {
  background: rgba(255,255,255,0.94);
  border: 1px solid rgba(0,0,0,0.12);
  box-shadow: 0 8px 32px rgba(0,0,0,0.14);
}

.panel {
  border-radius: 20px;
  padding: 24px;
}
[data-bs-theme="dark"] .panel {
  background: #111827;
  border: 1px solid rgba(255,255,255,0.07);
}
[data-bs-theme="light"] .panel {
  background: #ffffff;
  border: 1px solid rgba(0,0,0,0.12);
  box-shadow: 0 4px 20px rgba(0,0,0,0.10);
}

/* ── Knoppen ── */
.ctrl-btn {
  border-radius: 12px !important;
  font-weight: 600;
  font-size: 0.82rem;
  padding: 8px 14px;
  border: none;
  transition: 0.12s;
  white-space: nowrap;
}
.ctrl-btn:active { transform: scale(0.94); }

[data-bs-theme="dark"] .btn-ghost {
  background: rgba(255,255,255,0.07);
  color: rgba(255,255,255,0.8);
  border: 1px solid rgba(255,255,255,0.12) !important;
}
[data-bs-theme="dark"] .btn-ghost:hover { background: rgba(255,255,255,0.13); color: #fff; }
[data-bs-theme="light"] .btn-ghost {
  background: rgba(0,0,0,0.05);
  color: rgba(0,0,0,0.70);
  border: 1px solid rgba(0,0,0,0.12) !important;
}
[data-bs-theme="light"] .btn-ghost:hover { background: rgba(0,0,0,0.10); color: #000; }

[data-bs-theme="dark"] .btn-danger-soft {
  background: rgba(239,68,68,0.10); color: #fca5a5;
  border: 1px solid rgba(239,68,68,0.20) !important;
}
[data-bs-theme="dark"] .btn-danger-soft:hover { background: rgba(239,68,68,0.20); }
[data-bs-theme="light"] .btn-danger-soft {
  background: rgba(239,68,68,0.08); color: #dc2626;
  border: 1px solid rgba(239,68,68,0.28) !important;
}
[data-bs-theme="light"] .btn-danger-soft:hover { background: rgba(239,68,68,0.15); }

.btn-theme {
  border-radius: 12px !important;
  font-size: 0.88rem;
  padding: 7px 12px;
  transition: 0.12s;
  border: 1px solid rgba(99,102,241,0.30) !important;
}
[data-bs-theme="dark"] .btn-theme { background: rgba(99,102,241,0.12); color: #a5b4fc; }
[data-bs-theme="light"] .btn-theme { background: rgba(99,102,241,0.10); color: #4f46e5; }
.btn-theme:hover { opacity: 0.80; }

/* ── Formulieren ── */
[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] .form-select {
  background: #1e293b !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  color: #f1f5f9 !important;
  border-radius: 10px !important;
}
[data-bs-theme="dark"] .form-control::placeholder { color: rgba(255,255,255,0.25) !important; }
[data-bs-theme="dark"] .form-control:focus,
[data-bs-theme="dark"] .form-select:focus {
  box-shadow: 0 0 0 2px rgba(59,130,246,0.35) !important;
  border-color: rgba(59,130,246,0.5) !important;
}
[data-bs-theme="light"] .form-control,
[data-bs-theme="light"] .form-select {
  background: #ffffff !important;
  border: 1px solid rgba(0,0,0,0.15) !important;
  color: #0f172a !important;
  border-radius: 10px !important;
}
[data-bs-theme="light"] .form-control::placeholder { color: rgba(0,0,0,0.35) !important; }
[data-bs-theme="light"] .form-control:focus,
[data-bs-theme="light"] .form-select:focus {
  box-shadow: 0 0 0 2px rgba(59,130,246,0.25) !important;
  border-color: rgba(59,130,246,0.5) !important;
}
.search-input { border-radius: 50px !important; padding: 0.7rem 1.5rem !important; }

[data-bs-theme="dark"] .form-check-input { background-color: #1e293b; border-color: rgba(255,255,255,0.20); }
[data-bs-theme="light"] .form-check-input { background-color: #f8fafc; border-color: rgba(0,0,0,0.25); }
.form-check-input:checked { background-color: #3b82f6 !important; border-color: #3b82f6 !important; }

/* ── Tabellen ── */
[data-bs-theme="dark"] .table { --bs-table-bg: transparent; color: #e2e8f0; }
[data-bs-theme="dark"] .table thead th {
  color: rgba(255,255,255,0.40); font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase;
  border-bottom: 1px solid rgba(255,255,255,0.08); padding: 10px 12px;
}
[data-bs-theme="dark"] .table tbody td { border-bottom: 1px solid rgba(255,255,255,0.04); padding: 12px; vertical-align: middle; }
[data-bs-theme="dark"] .table tbody tr:hover td { background: rgba(255,255,255,0.02); }

[data-bs-theme="light"] .table { --bs-table-bg: transparent; color: #0f172a; }
[data-bs-theme="light"] .table thead th {
  color: rgba(0,0,0,0.50); font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase;
  border-bottom: 1px solid rgba(0,0,0,0.08); padding: 10px 12px;
}
[data-bs-theme="light"] .table tbody td { border-bottom: 1px solid rgba(0,0,0,0.04); padding: 12px; vertical-align: middle; }
[data-bs-theme="light"] .table tbody tr:hover td { background: rgba(0,0,0,0.02); }

/* ── Badges ── */
.badge-actief {
  background: rgba(34,197,94,0.15); border: 1px solid rgba(34,197,94,0.30);
  border-radius: 20px; padding: 3px 12px; font-size: 0.78rem; font-weight: 600;
}
.badge-uit, .badge-inactief {
  background: rgba(239,68,68,0.10); border: 1px solid rgba(239,68,68,0.25);
  border-radius: 20px; padding: 3px 12px; font-size: 0.78rem; font-weight: 600;
}
[data-bs-theme="dark"] .badge-actief { color: #4ade80; }
[data-bs-theme="dark"] .badge-uit,
[data-bs-theme="dark"] .badge-inactief { color: #f87171; }
[data-bs-theme="light"] .badge-actief { color: #16a34a; }
[data-bs-theme="light"] .badge-uit,
[data-bs-theme="light"] .badge-inactief { color: #dc2626; }

/* ── Status badges ── */
.status-badge { border-radius: 20px; padding: 4px 12px; font-size: 0.75rem; font-weight: 700; border: 1px solid; transition: 0.3s; white-space: nowrap; }
.s-on  { background: rgba(34,197,94,0.15); border-color: rgba(34,197,94,0.35); color: #4ade80; }
.s-off { background: rgba(239,68,68,0.10); border-color: rgba(239,68,68,0.25); color: #f87171; }
.s-unk { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.12); color: rgba(255,255,255,0.4); }
[data-bs-theme="light"] .s-on  { color: #16a34a; }
[data-bs-theme="light"] .s-off { color: #dc2626; }
[data-bs-theme="light"] .s-unk { background: rgba(0,0,0,0.05); border-color: rgba(0,0,0,0.10); color: rgba(0,0,0,0.45); }

/* ── Modals ── */
[data-bs-theme="dark"] .modal-content { background: #1e293b; border: 1px solid rgba(255,255,255,0.10); border-radius: 20px; }
[data-bs-theme="light"] .modal-content { background: #ffffff; border: 1px solid rgba(0,0,0,0.10); border-radius: 20px; }

/* ── Paginering ── */
[data-bs-theme="dark"] .page-link { background: rgba(255,255,255,0.05); border-color: rgba(255,255,255,0.10); color: #e2e8f0; }
[data-bs-theme="dark"] .page-link:hover { background: rgba(255,255,255,0.10); color: #fff; }
[data-bs-theme="dark"] .page-item.active .page-link { background: #3b82f6; border-color: #3b82f6; }
[data-bs-theme="dark"] .page-item.disabled .page-link { background: rgba(255,255,255,0.02); color: rgba(255,255,255,0.30); }
[data-bs-theme="light"] .page-link { background: #fff; border-color: rgba(0,0,0,0.12); color: #0f172a; }
[data-bs-theme="light"] .page-link:hover { background: #f1f5f9; color: #000; }
[data-bs-theme="light"] .page-item.active .page-link { background: #3b82f6; border-color: #3b82f6; color: #fff; }
[data-bs-theme="light"] .page-item.disabled .page-link { background: #f8fafc; color: rgba(0,0,0,0.30); }

/* ── Nieuws textarea ── */
.news-editor { min-height: 380px; resize: vertical; font-family: inherit; line-height: 1.7; font-size: 0.92rem; }

/* ── Rich text editor ── */
.rte-toolbar { border-radius: 10px 10px 0 0; padding: 6px 10px; display: flex; gap: 4px; }
[data-bs-theme="dark"] .rte-toolbar { background: #1e293b; border: 1px solid rgba(255,255,255,0.08); border-bottom: none; }
[data-bs-theme="light"] .rte-toolbar { background: #f8fafc; border: 1px solid rgba(0,0,0,0.12); border-bottom: none; }
.rte-btn { background: none; border: none; font-weight: 800; font-size: 0.9rem; padding: 3px 9px; border-radius: 6px; cursor: pointer; transition: 0.15s; }
[data-bs-theme="dark"] .rte-btn { color: rgba(255,255,255,0.50); }
[data-bs-theme="dark"] .rte-btn:hover { background: rgba(255,255,255,0.10); color: #fff; }
[data-bs-theme="light"] .rte-btn { color: rgba(0,0,0,0.60); }
[data-bs-theme="light"] .rte-btn:hover { background: rgba(0,0,0,0.08); color: #000; }
.rte-content { border-radius: 0 0 10px 10px !important; min-height: 140px; padding: 12px; font-size: 0.92rem; outline: none; line-height: 1.6; }
[data-bs-theme="dark"] .rte-content { background: #1e293b !important; border: 1px solid rgba(255,255,255,0.08) !important; color: #f1f5f9; }
[data-bs-theme="dark"] .rte-content:empty:before { content: attr(data-placeholder); color: rgba(255,255,255,0.25); pointer-events: none; }
[data-bs-theme="dark"] .rte-content:focus { box-shadow: 0 0 0 2px rgba(59,130,246,0.35); border-color: rgba(59,130,246,0.5) !important; }
[data-bs-theme="light"] .rte-content { background: #fff !important; border: 1px solid rgba(0,0,0,0.12) !important; color: #0f172a; }
[data-bs-theme="light"] .rte-content:empty:before { content: attr(data-placeholder); color: rgba(0,0,0,0.30); pointer-events: none; }
[data-bs-theme="light"] .rte-content:focus { box-shadow: 0 0 0 2px rgba(59,130,246,0.25); border-color: rgba(59,130,246,0.5) !important; }

/* ── Overige ── */
.section-label { font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 6px; }
[data-bs-theme="dark"] .section-label { color: rgba(255,255,255,0.35); }
[data-bs-theme="light"] .section-label { color: rgba(0,0,0,0.45); }

hr { margin: 12px 0; }
[data-bs-theme="dark"] hr { border-color: rgba(255,255,255,0.07); }
[data-bs-theme="light"] hr { border-color: rgba(0,0,0,0.08); }

::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: transparent; }
[data-bs-theme="dark"] ::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.10); border-radius: 4px; }
[data-bs-theme="light"] ::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.15); border-radius: 4px; }

/* ── Login pagina ── */
.login-card {
  backdrop-filter: blur(25px);
  border-radius: 35px;
  max-width: 450px; width: 100%;
  padding: 3rem;
}
[data-bs-theme="dark"] .login-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow: 0 15px 35px rgba(0,0,0,0.5);
}
[data-bs-theme="light"] .login-card {
  background: rgba(255,255,255,0.90);
  border: 1px solid rgba(0,0,0,0.09);
  box-shadow: 0 15px 35px rgba(0,0,0,0.10);
}

/* ============================================================
   QUEUE.HTML — Specifieke stijlen
   ============================================================ */

/* Now Playing art */
.now-art {
  width: 72px; height: 72px;
  object-fit: cover; border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.10);
  flex-shrink: 0;
}
[data-bs-theme="light"] .now-art { border-color: rgba(0,0,0,0.10); }

/* Pulse dot (live indicator) */
.pulse-dot {
  width: 8px; height: 8px; background: #ef4444;
  border-radius: 50%; display: inline-block;
  animation: ck-pulse 1.5s infinite;
}
@keyframes ck-pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.4;transform:scale(0.75)} }

/* Track info */
.track-artist { font-size: 1rem; font-weight: 700; line-height: 1.2; }
.track-title  { font-size: 0.85rem; margin-top: 2px; }
.track-album  { font-size: 0.73rem; margin-top: 1px; }
[data-bs-theme="dark"]  .track-title  { color: rgba(255,255,255,0.55); }
[data-bs-theme="dark"]  .track-album  { color: rgba(255,255,255,0.30); }
[data-bs-theme="light"] .track-title  { color: rgba(0,0,0,0.55); }
[data-bs-theme="light"] .track-album  { color: rgba(0,0,0,0.35); }

/* Progress bar */
.prog-bar { height: 4px; border-radius: 4px; overflow: hidden; margin: 10px 0 4px; cursor: pointer; }
[data-bs-theme="dark"]  .prog-bar { background: rgba(255,255,255,0.10); }
[data-bs-theme="light"] .prog-bar { background: rgba(0,0,0,0.10); }
.prog-fill { height: 100%; border-radius: 4px; background: linear-gradient(90deg, #6366f1, #a855f7); transition: width 0.5s linear; }
.prog-times { display: flex; justify-content: space-between; font-size: 0.72rem; }
[data-bs-theme="dark"]  .prog-times { color: rgba(255,255,255,0.35); }
[data-bs-theme="light"] .prog-times { color: rgba(0,0,0,0.40); }

/* Player control buttons */
.btn-play  { background: #16a34a !important; color: #fff !important; }
.btn-play:hover  { background: #15803d !important; }
.btn-stop  { background: #dc2626 !important; color: #fff !important; }
.btn-stop:hover  { background: #b91c1c !important; }
.btn-pause { background: #d97706 !important; color: #fff !important; }
.btn-pause:hover { background: #b45309 !important; }
.btn-mode  { background: rgba(99,102,241,0.12) !important; color: #a5b4fc !important; border: 1px solid rgba(99,102,241,0.25) !important; }
.btn-mode:hover { background: rgba(99,102,241,0.22) !important; color: #c7d2fe !important; }
[data-bs-theme="light"] .btn-mode { color: #4f46e5 !important; }

/* Divider */
.divider-v { width: 1px; background: rgba(255,255,255,0.08); align-self: stretch; margin: 0 4px; }
[data-bs-theme="light"] .divider-v { background: rgba(0,0,0,0.08); }

/* Queue list */
.queue-card { padding: 18px 20px; display: flex; flex-direction: column; height: 100%; }
.queue-scroll { overflow-y: auto; flex: 1; padding-right: 4px; }
.q-item { display: flex; align-items: center; gap: 10px; padding: 8px 10px; border-radius: 12px; transition: 0.15s; }
[data-bs-theme="dark"]  .q-item:hover { background: rgba(255,255,255,0.05); }
[data-bs-theme="light"] .q-item:hover { background: rgba(0,0,0,0.04); }
.q-num { min-width: 20px; text-align: right; font-size: 0.75rem; font-weight: 600; }
[data-bs-theme="dark"]  .q-num { color: rgba(255,255,255,0.30); }
[data-bs-theme="light"] .q-num { color: rgba(0,0,0,0.35); }
.q-art { width: 36px; height: 36px; object-fit: cover; border-radius: 7px; flex-shrink: 0; }
[data-bs-theme="dark"]  .q-art { border: 1px solid rgba(255,255,255,0.08); }
[data-bs-theme="light"] .q-art { border: 1px solid rgba(0,0,0,0.08); }
.q-artist { font-size: 0.83rem; font-weight: 600; line-height: 1.2; }
.q-title  { font-size: 0.75rem; }
[data-bs-theme="dark"]  .q-title { color: rgba(255,255,255,0.45); }
[data-bs-theme="light"] .q-title { color: rgba(0,0,0,0.50); }
.q-dur { font-size: 0.72rem; white-space: nowrap; margin-left: auto; }
[data-bs-theme="dark"]  .q-dur { color: rgba(255,255,255,0.30); }
[data-bs-theme="light"] .q-dur { color: rgba(0,0,0,0.40); }
.q-actions { display: flex; gap: 4px; flex-shrink: 0; }
.q-act-btn { border-radius: 7px; padding: 4px 8px; font-size: 0.78rem; transition: 0.12s; cursor: pointer; }
[data-bs-theme="dark"]  .q-act-btn { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.10); color: rgba(255,255,255,0.50); }
[data-bs-theme="dark"]  .q-act-btn:hover { background: rgba(255,255,255,0.15); color: #fff; border-color: rgba(255,255,255,0.25); }
[data-bs-theme="light"] .q-act-btn { background: rgba(0,0,0,0.04); border: 1px solid rgba(0,0,0,0.12); color: rgba(0,0,0,0.55); }
[data-bs-theme="light"] .q-act-btn:hover { background: rgba(0,0,0,0.10); color: #000; }
.q-act-del { background: rgba(239,68,68,0.08) !important; border-color: rgba(239,68,68,0.18) !important; color: rgba(248,113,113,0.7) !important; }
.q-act-del:hover { background: rgba(239,68,68,0.20) !important; color: #f87171 !important; }
.q-new { opacity: 0; transform: translateY(-4px); transition: opacity 0.3s ease, transform 0.3s ease; }
.q-new.q-visible { opacity: 1; transform: translateY(0); }

/* Carts */
.carts-card { padding: 18px 16px; }
.cart-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 7px; }
.cart-btn { border-radius: 11px; font-weight: 700; font-size: 0.95rem; padding: 10px 0; text-align: center; cursor: pointer; transition: 0.12s; }
[data-bs-theme="dark"]  .cart-btn { background: rgba(245,158,11,0.08); border: 1px solid rgba(245,158,11,0.20); color: #fbbf24; }
[data-bs-theme="dark"]  .cart-btn:hover { background: rgba(245,158,11,0.18); border-color: rgba(245,158,11,0.40); }
[data-bs-theme="light"] .cart-btn { background: rgba(245,158,11,0.10); border: 1px solid rgba(245,158,11,0.30); color: #b45309; }
[data-bs-theme="light"] .cart-btn:hover { background: rgba(245,158,11,0.20); }
.cart-btn:active { transform: scale(0.91); }

/* DJ Feedback */
#djFeedback { font-size: 0.82rem; min-height: 1.4em; }

/* ============================================================
   SONGS.HTML — Specifieke stijlen
   ============================================================ */

.album-art {
  width: 44px; height: 44px;
  object-fit: cover; border-radius: 8px;
}
[data-bs-theme="dark"]  .album-art { border: 1px solid rgba(255,255,255,0.08); }
[data-bs-theme="light"] .album-art { border: 1px solid rgba(0,0,0,0.08); }

.bulk-bar { border-radius: 16px; padding: 12px 20px; }
[data-bs-theme="dark"]  .bulk-bar { background: rgba(59,130,246,0.10); border: 1px solid rgba(59,130,246,0.30); }
[data-bs-theme="light"] .bulk-bar { background: rgba(59,130,246,0.06); border: 1px solid rgba(59,130,246,0.25); }

.btn-action { border-radius: 12px; padding: 5px 12px; font-size: 0.8rem; }

/* ── Login: wachtwoord toggle ── */
.password-wrapper {
  position: relative;
}
.password-wrapper .form-control {
  padding-right: 44px !important;
}
.password-toggle {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  line-height: 1;
  border-radius: 6px;
  transition: 0.15s;
}
[data-bs-theme="dark"]  .password-toggle { color: rgba(255,255,255,0.40); }
[data-bs-theme="dark"]  .password-toggle:hover { color: rgba(255,255,255,0.80); }
[data-bs-theme="light"] .password-toggle { color: rgba(0,0,0,0.40); }
[data-bs-theme="light"] .password-toggle:hover { color: rgba(0,0,0,0.80); }

/* ── Login: inlogknop ── */
.btn-login {
  background: linear-gradient(135deg, #6366f1, #a855f7);
  border: none;
  border-radius: 14px !important;
  padding: 12px;
  font-weight: 700;
  font-size: 0.95rem;
  transition: 0.2s;
}
.btn-login:hover { opacity: 0.88; transform: translateY(-1px); }
.btn-login:active { transform: scale(0.97); }

/* ── Stap badges (nieuws.html) ── */
.step-badge {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%;
  font-weight: 700; font-size: 0.8rem; transition: 0.3s;
}
[data-bs-theme="dark"] .step-badge.idle    { background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.40); border: 1px solid rgba(255,255,255,0.14); }
[data-bs-theme="dark"] .step-badge.loading { background: rgba(59,130,246,0.20); color: #60a5fa; border: 1px solid rgba(59,130,246,0.40); }
[data-bs-theme="dark"] .step-badge.ok      { background: rgba(34,197,94,0.15); color: #4ade80; border: 1px solid rgba(34,197,94,0.35); }
[data-bs-theme="dark"] .step-badge.error   { background: rgba(239,68,68,0.15); color: #f87171; border: 1px solid rgba(239,68,68,0.30); }
[data-bs-theme="light"] .step-badge.idle    { background: rgba(0,0,0,0.07); color: rgba(0,0,0,0.60); border: 1px solid rgba(0,0,0,0.18); }
[data-bs-theme="light"] .step-badge.loading { background: rgba(59,130,246,0.15); color: #2563eb; border: 1px solid rgba(59,130,246,0.40); }
[data-bs-theme="light"] .step-badge.ok      { background: rgba(34,197,94,0.15); color: #16a34a; border: 1px solid rgba(34,197,94,0.35); }
[data-bs-theme="light"] .step-badge.error   { background: rgba(239,68,68,0.12); color: #dc2626; border: 1px solid rgba(239,68,68,0.30); }

/* ── Light mode tekst fixes (nieuws.html) ── */
[data-bs-theme=light] .glass-card .text-white { color: #0f172a !important; }
[data-bs-theme=light] .glass-card .opacity-25 { opacity: 1 !important; color: rgba(0,0,0,0.40) !important; }
[data-bs-theme=light] .glass-card .opacity-50 { opacity: 1 !important; color: rgba(0,0,0,0.55) !important; }
[data-bs-theme=light] .glass-card h2 { color: #0f172a !important; }
[data-bs-theme=light] .glass-card small { color: rgba(0,0,0,0.60) !important; }
[data-bs-theme=light] .model-selector { color: #0f172a !important; }
[data-bs-theme=light] .model-selector label { color: #0f172a !important; }
[data-bs-theme=light] .model-selector .opacity-50 { color: rgba(0,0,0,0.60) !important; }
[data-bs-theme=light] .alert.text-white { color: #fff !important; }
[data-bs-theme=light] .btn-info.text-white { color: #fff !important; }
[data-bs-theme=light] .error-detail { color: #b91c1c !important; }

/* ── Tekstselectie lichtmodus ── */
[data-bs-theme="light"] ::selection { background: #1e3a8a; color: #fff; }
[data-bs-theme="dark"]  ::selection { background: rgba(99,102,241,0.5); color: #fff; }
