:root {
  color-scheme: light;
  --bg: #f8fafc;
  --bg-gradient: linear-gradient(135deg, #f0f4ff 0%, #faf5ff 50%, #fdf4ff 100%);
  --card: #ffffff;
  --card-hover: #fefefe;
  --text: #1e293b;
  --text-secondary: #475569;
  --muted: #64748b;
  --accent: #6366f1;
  --accent-hover: #4f46e5;
  --accent-light: #eef2ff;
  --accent-gradient: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);
  --accent-color: #6366f1;
  --primary-color: #6366f1;
  --success: #10b981;
  --success-light: #d1fae5;
  --success-gradient: linear-gradient(135deg, #10b981 0%, #059669 100%);
  --warning: #f59e0b;
  --warning-light: #fef3c7;
  --danger: #ef4444;
  --danger-light: #fee2e2;
  --border: #e2e8f0;
  --border-light: #f1f5f9;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  --radius-sm: 8px;
  --radius: 12px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
  --surface: #ffffff;
  --surface-secondary: #f8fafc;
  --primary: #6366f1;
  --fg: #1e293b;
  --text-primary: #1e293b;
  --bg-primary: #ffffff;
  --bg-surface: #ffffff;
  --bg-hover: #f3f4f6;
  --bg-accent: #eef2ff;
  --bg-tertiary: #f1f5f9;
  --bg-card: #ffffff;
  --card-bg: #ffffff;
  --border-color: #e2e8f0;
}

/* ===== Dark Mode Theme ===== */
html.dark-mode {
  color-scheme: dark;
  --bg: #0f172a;
  --bg-gradient: linear-gradient(135deg, #0f172a 0%, #1a1033 50%, #1a0a2e 100%);
  --card: #1e293b;
  --card-hover: #253449;
  --text: #e2e8f0;
  --text-secondary: #94a3b8;
  --muted: #94a3b8;
  --accent: #818cf8;
  --accent-hover: #6366f1;
  --accent-light: #1e1b4b;
  --accent-gradient: linear-gradient(135deg, #818cf8 0%, #a78bfa 100%);
  --accent-color: #818cf8;
  --primary-color: #818cf8;
  --success: #34d399;
  --success-light: #064e3b;
  --success-gradient: linear-gradient(135deg, #34d399 0%, #10b981 100%);
  --warning: #fbbf24;
  --warning-light: #451a03;
  --danger: #f87171;
  --danger-light: #450a0a;
  --border: #334155;
  --border-light: #1e293b;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
  --shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.4), 0 2px 4px -1px rgba(0, 0, 0, 0.3);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.4), 0 4px 6px -2px rgba(0, 0, 0, 0.3);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.5), 0 10px 10px -5px rgba(0, 0, 0, 0.3);
  --surface: #1e293b;
  --surface-secondary: #0f172a;
  --primary: #818cf8;
  --fg: #e2e8f0;
  --text-primary: #e2e8f0;
  --bg-primary: #0f172a;
  --bg-surface: #1e293b;
  --bg-hover: #334155;
  --bg-accent: #1e1b4b;
  --bg-tertiary: #334155;
  --bg-card: #1e293b;
  --card-bg: #1e293b;
  --border-color: #334155;
}

/* Dark mode overrides for elements that use hardcoded colors */
html.dark-mode .nav-link.active {
  box-shadow: 0 4px 12px rgba(129, 140, 248, 0.4);
}

html.dark-mode .notif-panel-item.unread:hover {
  background: #1e1b4b;
}

html.dark-mode input,
html.dark-mode select,
html.dark-mode textarea {
  background: var(--card);
  color: var(--text);
  border-color: var(--border);
}

html.dark-mode input:focus,
html.dark-mode select:focus,
html.dark-mode textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(129, 140, 248, 0.2);
}

html.dark-mode img {
  opacity: 0.9;
}

/* System preference: auto dark mode when user has theme_preference=system */
@media (prefers-color-scheme: dark) {
  html.system-theme {
    color-scheme: dark;
    --bg: #0f172a;
    --bg-gradient: linear-gradient(135deg, #0f172a 0%, #1a1033 50%, #1a0a2e 100%);
    --card: #1e293b;
    --card-hover: #253449;
    --text: #e2e8f0;
    --text-secondary: #94a3b8;
    --muted: #94a3b8;
    --accent: #818cf8;
    --accent-hover: #6366f1;
    --accent-light: #1e1b4b;
    --accent-gradient: linear-gradient(135deg, #818cf8 0%, #a78bfa 100%);
    --accent-color: #818cf8;
    --primary-color: #818cf8;
    --success: #34d399;
    --success-light: #064e3b;
    --success-gradient: linear-gradient(135deg, #34d399 0%, #10b981 100%);
    --warning: #fbbf24;
    --warning-light: #451a03;
    --danger: #f87171;
    --danger-light: #450a0a;
    --border: #334155;
    --border-light: #1e293b;
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
    --shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.4), 0 2px 4px -1px rgba(0, 0, 0, 0.3);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.4), 0 4px 6px -2px rgba(0, 0, 0, 0.3);
    --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.5), 0 10px 10px -5px rgba(0, 0, 0, 0.3);
    --surface: #1e293b;
    --surface-secondary: #0f172a;
    --primary: #818cf8;
    --fg: #e2e8f0;
    --text-primary: #e2e8f0;
    --bg-primary: #0f172a;
    --bg-surface: #1e293b;
    --bg-hover: #334155;
    --bg-accent: #1e1b4b;
    --bg-tertiary: #334155;
    --bg-card: #1e293b;
    --card-bg: #1e293b;
    --border-color: #334155;
  }

  html.system-theme .nav-link.active {
    box-shadow: 0 4px 12px rgba(129, 140, 248, 0.4);
  }

  html.system-theme .notif-panel-item.unread:hover {
    background: #1e1b4b;
  }

  html.system-theme input,
  html.system-theme select,
  html.system-theme textarea {
    background: var(--card);
    color: var(--text);
    border-color: var(--border);
  }

  html.system-theme input:focus,
  html.system-theme select:focus,
  html.system-theme textarea:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(129, 140, 248, 0.2);
  }

  html.system-theme img {
    opacity: 0.9;
  }
}

* {
  box-sizing: border-box;
  font-family: "Inter", system-ui, -apple-system, sans-serif;
}

body {
  margin: 0;
  background: var(--bg-gradient);
  min-height: 100vh;
  color: var(--text);
  line-height: 1.6;
}

/* ===== Layout ===== */
.page {
  max-width: 1400px;
  margin: 0 auto;
  padding: 24px;
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 32px;
  min-height: 100vh;
  transition: var(--transition);
}

.content {
  min-width: 0;
  padding-bottom: 48px;
  overflow: visible;
}

/* ===== Sidebar ===== */
.sidebar {
  background: var(--card);
  border-radius: var(--radius-xl);
  padding: 20px 16px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
  max-height: calc(100vh - 48px);
  overflow: visible;
  position: sticky;
  top: 24px;
  z-index: 100;
  align-self: start;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: var(--transition);
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}

.sidebar::-webkit-scrollbar {
  width: 4px;
}

.sidebar::-webkit-scrollbar-track {
  background: transparent;
}

.sidebar::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 4px;
}

.sidebar-brand {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border-light);
  flex-shrink: 0;
}

.sidebar-brand-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.sidebar-brand-text {
  text-align: left;
}

.sidebar-toggle {
  border: 1px solid var(--border);
  background: var(--card);
  border-radius: var(--radius);
  padding: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text);
  cursor: pointer;
  transition: var(--transition);
}

.sidebar-toggle:hover {
  background: var(--accent-light);
  color: var(--accent);
  border-color: var(--accent-light);
}

.sidebar-brand .eyebrow {
  margin: 0 0 4px;
  background: var(--accent-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 700;
  letter-spacing: 0.15em;
}

.sidebar-title {
  margin: 0;
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
}

.sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1 1 auto;
  min-height: 0;
  overflow: visible;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}

.sidebar-footer-nav {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid var(--border-light);
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex-shrink: 0;
}

.sidebar-version {
  font-size: 0.65rem;
  color: var(--muted);
  text-align: center;
  padding: 6px 0 2px;
  opacity: 0.6;
  user-select: all;
}

.nav-link {
  text-decoration: none;
  color: var(--text-secondary);
  padding: 10px 14px;
  border-radius: var(--radius);
  font-weight: 500;
  font-size: 14px;
  background: transparent;
  transition: var(--transition);
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

.nav-link svg {
  flex-shrink: 0;
}

.nav-link:hover {
  background: var(--accent-light);
  color: var(--accent);
  transform: translateX(4px);
}

.nav-link.active {
  background: var(--accent-gradient);
  color: #fff;
  box-shadow: 0 4px 12px rgba(99, 102, 241, 0.4);
}

.nav-link.active:hover {
  transform: translateX(0);
}

.nav-link-group {
  position: relative;
}

.nav-link-group .nav-link {
  display: flex;
  align-items: center;
  gap: 10px;
}

.nav-chevron {
  margin-left: auto;
  transition: transform 0.2s ease;
  opacity: 0.5;
  flex-shrink: 0;
}

.nav-link-group.active .nav-chevron,
.nav-link-group.expanded .nav-chevron {
  opacity: 0.8;
}

.nav-link-group.expanded .nav-chevron,
.nav-link-group:hover .nav-chevron,
.nav-link-group:focus-within .nav-chevron {
  transform: rotate(90deg);
}

/* Flyout submenu — pops out to the right of the parent nav item on hover. */
.nav-submenu {
  position: absolute;
  left: 100%;
  top: 0;
  max-height: none;
  overflow: visible;
  padding: 6px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  min-width: 160px;
  z-index: 9999;
  display: none;
}

.nav-link-group:hover > .nav-submenu,
.nav-link-group:focus-within > .nav-submenu,
.nav-link-group.expanded > .nav-submenu {
  display: block;
}

.nav-submenu-link {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 14px;
  color: var(--text-secondary);
  text-decoration: none;
  font-size: 13px;
  border-radius: 6px;
  transition: var(--transition);
  white-space: nowrap;
}

.nav-submenu-link:hover {
  color: var(--text);
  background: var(--accent-light);
}

.nav-submenu-link.active {
  color: var(--accent);
  font-weight: 600;
}

.nav-submenu-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.4;
  flex-shrink: 0;
}

.nav-submenu-link.active .nav-submenu-dot {
  opacity: 1;
}

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

/* Collapsed sidebar: desktop only (side panel shrinks to icon-only) */
@media (min-width: 1025px) {
  body.sidebar-collapsed .page,
  html.sidebar-collapsed .page {
    grid-template-columns: 96px 1fr;
  }

  body.sidebar-collapsed .sidebar,
  html.sidebar-collapsed .sidebar {
    padding: 16px 12px;
    align-items: center;
  }

  body.sidebar-collapsed .sidebar-brand,
  html.sidebar-collapsed .sidebar-brand {
    width: 100%;
    align-items: center;
  }

  body.sidebar-collapsed .sidebar-brand-top,
  html.sidebar-collapsed .sidebar-brand-top {
    width: 100%;
    justify-content: center;
  }

  body.sidebar-collapsed .sidebar-brand-text,
  html.sidebar-collapsed .sidebar-brand-text {
    display: none;
  }

  body.sidebar-collapsed .nav-link,
  html.sidebar-collapsed .nav-link {
    justify-content: center;
    padding: 10px;
  }

  body.sidebar-collapsed .nav-label,
  html.sidebar-collapsed .nav-label {
    display: none;
  }

  body.sidebar-collapsed .nav-chevron,
  html.sidebar-collapsed .nav-chevron {
    display: none;
  }

  body.sidebar-collapsed .nav-link-group .nav-link,
  html.sidebar-collapsed .nav-link-group .nav-link {
    justify-content: center;
    padding: 10px;
  }

  /* Restore submenu label visibility when sidebar is collapsed */
  body.sidebar-collapsed .nav-submenu .nav-label,
  html.sidebar-collapsed .nav-submenu .nav-label {
    display: inline;
  }

}

/* Collapsed sidebar: small screens (horizontal top bar, icon-only) */
@media (max-width: 1024px) {
  body.sidebar-collapsed .sidebar-brand-text,
  html.sidebar-collapsed .sidebar-brand-text {
    display: none;
  }

  body.sidebar-collapsed .nav-label,
  html.sidebar-collapsed .nav-label {
    display: none;
  }

  body.sidebar-collapsed .nav-link,
  html.sidebar-collapsed .nav-link {
    justify-content: center;
    padding: 10px;
  }

  body.sidebar-collapsed .nav-chevron,
  html.sidebar-collapsed .nav-chevron {
    display: none;
  }

  body.sidebar-collapsed .nav-submenu .nav-label,
  html.sidebar-collapsed .nav-submenu .nav-label {
    display: inline;
  }
}

/* Collapsed sidebar: mobile – override column layout to keep horizontal row */
@media (max-width: 768px) {
  body.sidebar-collapsed .sidebar,
  html.sidebar-collapsed .sidebar {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 8px;
  }

  body.sidebar-collapsed .sidebar-nav,
  html.sidebar-collapsed .sidebar-nav {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 4px;
  }

  body.sidebar-collapsed .sidebar-footer-nav,
  html.sidebar-collapsed .sidebar-footer-nav {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 4px;
    margin-top: 0;
    padding-top: 0;
    border-top: none;
  }
}

/* ===== Topbar ===== */
.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 32px;
  gap: 24px;
}

.topbar-info {
  flex: 1;
}

.eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-size: 11px;
  color: var(--accent);
  margin: 0;
  font-weight: 600;
}

.headline {
  margin: 8px 0 0;
  font-size: 28px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.3;
}

.topbar-actions {
  display: flex;
  gap: 12px;
}

/* ===== Pending Tickets Pill ===== */
.pending-tickets-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--danger);
  color: #ffffff;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
  padding: 6px 14px;
  border-radius: 9999px;
  text-decoration: none;
  white-space: nowrap;
  box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.5);
  animation: pending-tickets-pulse 2s ease-in-out infinite;
  transition: background 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
}

.pending-tickets-pill:hover {
  background: #dc2626;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(239, 68, 68, 0.4);
  animation: none;
}

.pending-tickets-pill svg {
  flex-shrink: 0;
}

@keyframes pending-tickets-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.5); }
  50% { box-shadow: 0 0 0 6px rgba(239, 68, 68, 0); }
}

/* ===== Notification Bell ===== */
.notification-bell-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text-secondary);
  cursor: pointer;
  transition: var(--transition);
}

.notification-bell-btn:hover {
  background: var(--accent-light);
  border-color: var(--accent);
  color: var(--accent);
}

.notification-bell-btn:focus {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.notification-bell-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 9px;
  background: var(--danger);
  color: #ffffff;
  font-size: 11px;
  font-weight: 700;
  line-height: 18px;
  text-align: center;
  box-shadow: 0 2px 4px rgba(239, 68, 68, 0.3);
  pointer-events: none;
}

.notification-bell-badge[data-animating] {
  animation: bell-badge-pop 0.3s ease;
}

@keyframes bell-badge-pop {
  0% { transform: scale(0.5); }
  60% { transform: scale(1.2); }
  100% { transform: scale(1); }
}

/* ===== Notification Side Panel ===== */
.notif-panel-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.3);
  z-index: 9998;
  transition: opacity 0.2s ease;
}

.notif-panel-overlay.open {
  display: block;
}

.notif-panel {
  position: fixed;
  top: 0;
  right: 0;
  width: 380px;
  max-width: 100vw;
  height: 100vh;
  background: var(--card);
  border-left: 1px solid var(--border);
  box-shadow: var(--shadow-xl);
  z-index: 9999;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.25s ease;
}

.notif-panel.open {
  transform: translateX(0);
}

.notif-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.notif-panel-title {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 8px;
}

.notif-panel-header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.notif-panel-dismiss-all {
  background: none;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 4px 12px;
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
  cursor: pointer;
  transition: var(--transition);
}

.notif-panel-dismiss-all:hover {
  background: var(--accent-light);
  border-color: var(--accent);
  color: var(--accent);
}

.notif-panel-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: none;
  font-size: 18px;
  color: var(--muted);
  cursor: pointer;
  transition: var(--transition);
  line-height: 1;
}

.notif-panel-close:hover {
  background: var(--danger-light);
  border-color: var(--danger);
  color: var(--danger);
}

.notif-panel-body {
  flex: 1;
  overflow-y: auto;
  padding: 0;
}

.notif-panel-loading,
.notif-panel-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 24px;
  color: var(--muted);
  font-size: 14px;
}

.notif-panel-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.notif-panel-item {
  display: flex;
  gap: 12px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border-light);
  transition: background 0.15s ease;
  position: relative;
}

.notif-panel-item:hover {
  background: var(--bg);
}

.notif-panel-item.unread {
  background: var(--accent-light);
}

.notif-panel-item.unread:hover {
  background: #e0e7ff;
}

.notif-item-icon {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--accent-light);
  color: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
}

.notif-item-content {
  flex: 1;
  min-width: 0;
}

.notif-item-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  margin: 0 0 2px;
  line-height: 1.4;
}

.notif-item-title a {
  color: inherit;
  text-decoration: none;
}

.notif-item-title a:hover {
  color: var(--accent);
}

.notif-item-message {
  font-size: 12px;
  color: var(--text-secondary);
  margin: 0 0 4px;
  line-height: 1.4;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.notif-item-meta {
  display: flex;
  align-items: center;
  gap: 8px;
}

.notif-item-time {
  font-size: 11px;
  color: var(--muted);
}

.notif-item-type {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 1px 6px;
  border-radius: 4px;
  background: var(--bg);
  color: var(--muted);
  border: 1px solid var(--border-light);
}

.notif-item-source {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 1px 8px;
  border-radius: 4px;
  border: none;
}

.notif-item-source--voice {
  background: linear-gradient(135deg, #7c3aed 0%, #6d28d9 100%);
  color: #ffffff;
}

.notif-item-dismiss {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: none;
  background: none;
  color: var(--muted);
  font-size: 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition);
  align-self: flex-start;
  margin-top: 2px;
}

.notif-item-dismiss:hover {
  background: var(--danger-light);
  color: var(--danger);
}

@media (max-width: 480px) {
  .notif-panel {
    width: 100vw;
  }
}

/* ===== Voice Record Button ===== */
.voice-record-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text-secondary);
  cursor: pointer;
  transition: var(--transition);
}

.voice-record-btn:hover {
  background: var(--accent-light);
  border-color: var(--accent);
  color: var(--accent);
}

.voice-record-btn:focus {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.voice-record-btn.recording {
  background: var(--danger);
  border-color: var(--danger);
  color: #ffffff;
  animation: voice-pulse 1.5s ease-in-out infinite;
}

@keyframes voice-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.4); }
  50% { box-shadow: 0 0 0 8px rgba(239, 68, 68, 0); }
}

/* ===== Voice Recording Indicator ===== */
.voice-recording-indicator {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 20px;
  background: var(--card);
  border: 1px solid var(--danger);
  border-radius: 999px;
  box-shadow: var(--shadow-lg);
  z-index: 10000;
}

.voice-recording-pulse {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--danger);
  animation: voice-pulse-dot 1s ease-in-out infinite;
}

@keyframes voice-pulse-dot {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}

.voice-recording-text {
  font-size: 13px;
  font-weight: 600;
  color: var(--danger);
}

.voice-recording-timer {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
}

.voice-recording-stop {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  border-radius: 50%;
  background: var(--danger);
  color: #ffffff;
  cursor: pointer;
  transition: var(--transition);
}

.voice-recording-stop:hover {
  background: #dc2626;
}

/* ===== Voice Draft Modal ===== */
.voice-draft-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  z-index: 10000;
}

.voice-draft-overlay.open {
  display: block;
}

.voice-draft-modal {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 540px;
  max-width: calc(100vw - 32px);
  max-height: calc(100vh - 48px);
  background: var(--card);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  z-index: 10001;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.voice-draft-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
}

.voice-draft-modal-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 16px;
  font-weight: 700;
  margin: 0;
  color: var(--text);
}

.voice-draft-modal-close {
  background: none;
  border: none;
  font-size: 22px;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 4px 8px;
  border-radius: var(--radius);
}

.voice-draft-modal-close:hover {
  background: var(--bg);
  color: var(--text);
}

.voice-draft-modal-body {
  padding: 20px;
  overflow-y: auto;
  flex: 1;
}

.voice-draft-field {
  margin-bottom: 16px;
}

.voice-draft-field--half {
  flex: 1;
}

.voice-draft-row {
  display: flex;
  gap: 16px;
}

.voice-draft-label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-secondary);
  margin-bottom: 6px;
}

.voice-draft-transcript {
  margin: 0;
  padding: 12px;
  background: var(--bg);
  border-radius: var(--radius);
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-secondary);
  border: 1px solid var(--border);
  max-height: 120px;
  overflow-y: auto;
}

.voice-draft-input,
.voice-draft-select {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--card);
  color: var(--text);
  font-size: 14px;
  font-family: inherit;
  transition: var(--transition);
  box-sizing: border-box;
}

.voice-draft-input:focus,
.voice-draft-select:focus {
  border-color: var(--accent);
  outline: none;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
}

.voice-draft-textarea {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--card);
  color: var(--text);
  font-size: 14px;
  font-family: inherit;
  resize: vertical;
  min-height: 80px;
  transition: var(--transition);
  box-sizing: border-box;
}

.voice-draft-textarea:focus {
  border-color: var(--accent);
  outline: none;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
}

.voice-draft-tags {
  margin: 0;
  font-size: 13px;
  color: var(--accent);
}

.voice-draft-list-checkboxes,
.voice-draft-custom-list-checkboxes {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding: 10px 12px;
  background: var(--bg);
  border-radius: var(--radius);
  border: 1px solid var(--border);
}

.voice-draft-custom-list-checkboxes:empty {
  display: none;
}

.voice-draft-custom-list-checkboxes {
  margin-top: 8px;
}

.voice-draft-list-checkboxes label,
.voice-draft-custom-list-checkboxes label {
  display: flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 400;
  color: var(--text);
}

.voice-draft-list-checkboxes input[type="checkbox"],
.voice-draft-custom-list-checkboxes input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--accent);
  cursor: pointer;
}

.voice-draft-modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 16px 20px;
  border-top: 1px solid var(--border);
}

.voice-draft-btn {
  padding: 8px 20px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition);
}

.voice-draft-btn--discard {
  background: var(--card);
  color: var(--text-secondary);
}

.voice-draft-btn--discard:hover {
  background: var(--bg);
  border-color: var(--danger);
  color: var(--danger);
}

.voice-draft-btn--save {
  background: var(--accent);
  color: #ffffff;
  border-color: var(--accent);
}

.voice-draft-btn--save:hover {
  background: var(--accent-hover);
}

@media (max-width: 600px) {
  .voice-draft-modal {
    width: calc(100vw - 16px);
  }
  .voice-draft-row {
    flex-direction: column;
    gap: 0;
  }
}

/* =====================================================================
   COMPREHENSIVE DARK MODE OVERRIDES
   Fixes hardcoded light-mode colors across all component CSS files.
   ===================================================================== */

/* --- Helper: dark mode mixin applied to both html.dark-mode and
       @media (prefers-color-scheme: dark) html.system-theme --- */

/* ── Priority Pills (components.css) ─────────────────────────────────── */
html.dark-mode .pill.priority-high,
html.dark-mode .pill[class*="high"] {
  background: rgba(239, 68, 68, 0.15);
  color: #fca5a5;
  border-color: rgba(239, 68, 68, 0.3);
}

html.dark-mode .pill.priority-medium,
html.dark-mode .pill[class*="medium"] {
  background: rgba(245, 158, 11, 0.15);
  color: #fcd34d;
  border-color: rgba(245, 158, 11, 0.3);
}

html.dark-mode .pill.priority-low,
html.dark-mode .pill[class*="low"] {
  background: rgba(16, 185, 129, 0.15);
  color: #6ee7b7;
  border-color: rgba(16, 185, 129, 0.3);
}

/* ── Todo Completed & Archived States (todo.css) ─────────────────────── */
html.dark-mode .list li.completed,
html.dark-mode .list li.past-due.completed {
  background: rgba(16, 185, 129, 0.08);
  border-color: rgba(16, 185, 129, 0.2);
}

html.dark-mode .list li.archived {
  background: rgba(100, 116, 139, 0.1);
  border-color: rgba(100, 116, 139, 0.2);
}

html.dark-mode .pill.status-archived {
  background: rgba(100, 116, 139, 0.15);
  color: #94a3b8;
  border-color: rgba(100, 116, 139, 0.3);
}

html.dark-mode .list li.starred:not(.past-due) {
  background: rgba(250, 204, 21, 0.1);
}

/* ── Settings Rule Badges (pages.css) ────────────────────────────────── */
html.dark-mode .settings-rule-badge--add {
  background: rgba(16, 185, 129, 0.15);
  color: #6ee7b7;
}

html.dark-mode .settings-rule-badge--remove {
  background: rgba(239, 68, 68, 0.15);
  color: #fca5a5;
}

html.dark-mode .settings-rule-badge--complete {
  background: rgba(59, 130, 246, 0.15);
  color: #93c5fd;
}

/* ── Ticket Status Badges & Pills (tickets.css) ──────────────────────── */
html.dark-mode .tickets-badge-pending.active {
  background: rgba(99, 102, 241, 0.15);
}

html.dark-mode .tickets-badge-sent-to-kim.active {
  background: rgba(245, 158, 11, 0.15);
}

html.dark-mode .tickets-badge-approved.active {
  background: rgba(16, 185, 129, 0.15);
}

html.dark-mode .tickets-badge-denied.active {
  background: rgba(239, 68, 68, 0.15);
}

html.dark-mode .tickets-badge-closed.active {
  background: rgba(100, 116, 139, 0.15);
  border-color: #64748b;
}

html.dark-mode .tickets-badge-roc-ticket-submitted.active {
  background: rgba(234, 88, 12, 0.15);
  border-color: #ea580c;
}

html.dark-mode .tickets-badge-cancelled.active {
  background: rgba(139, 92, 246, 0.15);
  border-color: #7c3aed;
}

html.dark-mode .ticket-status-pending {
  background: rgba(99, 102, 241, 0.15);
  color: #a5b4fc;
  border-color: rgba(99, 102, 241, 0.3);
}

html.dark-mode .ticket-status-sent_to_kim {
  background: rgba(245, 158, 11, 0.15);
  color: #fcd34d;
  border-color: rgba(245, 158, 11, 0.3);
}

html.dark-mode .ticket-status-approved {
  background: rgba(16, 185, 129, 0.15);
  color: #6ee7b7;
  border-color: rgba(16, 185, 129, 0.3);
}

html.dark-mode .ticket-status-denied {
  background: rgba(239, 68, 68, 0.15);
  color: #fca5a5;
  border-color: rgba(239, 68, 68, 0.3);
}

html.dark-mode .ticket-status-closed {
  background: rgba(100, 116, 139, 0.15);
  color: #94a3b8;
  border-color: rgba(100, 116, 139, 0.3);
}

html.dark-mode .ticket-status-roc_ticket_submitted {
  background: rgba(234, 88, 12, 0.15);
  color: #fdba74;
  border-color: rgba(234, 88, 12, 0.3);
}

html.dark-mode .ticket-status-cancelled {
  background: rgba(139, 92, 246, 0.15);
  color: #c4b5fd;
  border-color: rgba(139, 92, 246, 0.3);
}

html.dark-mode .ticket-status-pill.ticket-status-pending {
  background: rgba(99, 102, 241, 0.15);
  color: #a5b4fc;
}

html.dark-mode .ticket-status-pill.ticket-status-sent_to_kim {
  background: rgba(245, 158, 11, 0.15);
  color: #fcd34d;
}

html.dark-mode .ticket-status-pill.ticket-status-approved {
  background: rgba(16, 185, 129, 0.15);
  color: #6ee7b7;
}

html.dark-mode .ticket-status-pill.ticket-status-denied {
  background: rgba(239, 68, 68, 0.15);
  color: #fca5a5;
}

html.dark-mode .ticket-status-pill.ticket-status-closed {
  background: rgba(100, 116, 139, 0.15);
  color: #94a3b8;
}

html.dark-mode .ticket-status-pill.ticket-status-roc_ticket_submitted {
  background: rgba(234, 88, 12, 0.15);
  color: #fdba74;
}

html.dark-mode .ticket-status-pill.ticket-status-cancelled {
  background: rgba(139, 92, 246, 0.15);
  color: #c4b5fd;
}

/* Ticket priority pills */
html.dark-mode .ticket-priority-low {
  background: rgba(16, 185, 129, 0.15);
  color: #6ee7b7;
}

html.dark-mode .ticket-priority-medium {
  background: rgba(245, 158, 11, 0.15);
  color: #fcd34d;
}

html.dark-mode .ticket-priority-high {
  background: rgba(234, 88, 12, 0.15);
  color: #fdba74;
}

html.dark-mode .ticket-priority-urgent {
  background: rgba(239, 68, 68, 0.15);
  color: #fca5a5;
}

html.dark-mode .ticket-active-badge.active {
  background: rgba(16, 185, 129, 0.15);
  color: #6ee7b7;
}

html.dark-mode .ticket-active-badge.inactive {
  background: rgba(100, 116, 139, 0.15);
  color: #94a3b8;
}

/* Ticket detail sections with hardcoded backgrounds */
html.dark-mode .ticket-detail-section {
  background: var(--card);
}

html.dark-mode .ticket-detail-meta-value {
  color: var(--text);
}

/* Ticket reason badges */
html.dark-mode .ticket-reason-downtime {
  background: rgba(239, 68, 68, 0.12);
  color: #fca5a5;
  border-color: rgba(239, 68, 68, 0.3);
}

html.dark-mode .ticket-reason-sys_fixagt {
  background: rgba(234, 88, 12, 0.12);
  color: #fdba74;
  border-color: rgba(234, 88, 12, 0.3);
}

html.dark-mode .ticket-reason-system {
  background: rgba(99, 102, 241, 0.12);
  color: #a5b4fc;
  border-color: rgba(99, 102, 241, 0.3);
}

html.dark-mode .ticket-reason-emergency {
  background: rgba(220, 38, 38, 0.15);
  color: #fca5a5;
  border-color: rgba(220, 38, 38, 0.3);
}

html.dark-mode .ticket-reason-upopa {
  background: rgba(139, 92, 246, 0.12);
  color: #c4b5fd;
  border-color: rgba(139, 92, 246, 0.3);
}

html.dark-mode .ticket-reason-erg_event {
  background: rgba(16, 185, 129, 0.12);
  color: #6ee7b7;
  border-color: rgba(16, 185, 129, 0.3);
}

html.dark-mode .ticket-reason-move_coaching {
  background: rgba(14, 165, 233, 0.12);
  color: #7dd3fc;
  border-color: rgba(14, 165, 233, 0.3);
}

html.dark-mode .ticket-reason-other {
  background: rgba(20, 184, 166, 0.12);
  color: #5eead4;
  border-color: rgba(20, 184, 166, 0.3);
}

/* ── Ticket Reason Radio Chips (checked states in create/edit modal) ── */
html.dark-mode .ticket-radio-label input[type="radio"]:checked + .ticket-reason-downtime {
  border-color: #f87171;
  background: rgba(239, 68, 68, 0.15);
  color: #fca5a5;
}

html.dark-mode .ticket-radio-label input[type="radio"]:checked + .ticket-reason-sys_fixagt {
  border-color: #fb923c;
  background: rgba(234, 88, 12, 0.15);
  color: #fdba74;
}

html.dark-mode .ticket-radio-label input[type="radio"]:checked + .ticket-reason-system {
  border-color: #818cf8;
  background: rgba(99, 102, 241, 0.15);
  color: #a5b4fc;
}

html.dark-mode .ticket-radio-label input[type="radio"]:checked + .ticket-reason-emergency {
  border-color: #f87171;
  background: rgba(220, 38, 38, 0.18);
  color: #fca5a5;
}

html.dark-mode .ticket-radio-label input[type="radio"]:checked + .ticket-reason-upopa {
  border-color: #a78bfa;
  background: rgba(139, 92, 246, 0.15);
  color: #c4b5fd;
}

html.dark-mode .ticket-radio-label input[type="radio"]:checked + .ticket-reason-erg_event {
  border-color: #34d399;
  background: rgba(16, 185, 129, 0.15);
  color: #6ee7b7;
}

html.dark-mode .ticket-radio-label input[type="radio"]:checked + .ticket-reason-move_coaching {
  border-color: #38bdf8;
  background: rgba(14, 165, 233, 0.15);
  color: #7dd3fc;
}

html.dark-mode .ticket-radio-label input[type="radio"]:checked + .ticket-reason-other {
  border-color: #2dd4bf;
  background: rgba(20, 184, 166, 0.15);
  color: #5eead4;
}

/* ── Badge Classes (import history / general badges) ─────────────────── */
html.dark-mode .badge-success {
  background: rgba(34, 197, 94, 0.15);
  color: #4ade80;
  border-color: rgba(34, 197, 94, 0.25);
}

html.dark-mode .badge-info {
  background: rgba(59, 130, 246, 0.15);
  color: #60a5fa;
  border-color: rgba(59, 130, 246, 0.25);
}

html.dark-mode .badge-default {
  background: rgba(156, 163, 175, 0.15);
  color: #9ca3af;
  border-color: rgba(156, 163, 175, 0.25);
}

/* ── Ticket Select Dropdown Option Elements ──────────────────────────── */
/* Native <option> elements inherit the select's light text color but render
   with the browser's default white background → unreadable in dark mode.
   Force a dark background + readable text on every option. */
html.dark-mode .ticket-status-select option,
html.dark-mode .ticket-view-status-select option,
html.dark-mode .ticket-view-reason-select option,
html.dark-mode .tickets-filter-select option,
html.dark-mode .tickets-bulk-status-select option {
  background: #1e293b;
  color: #e2e8f0;
}

/* Per-status option text colors (readable on dark bg) */
html.dark-mode .ticket-status-select option[value="pending"],
html.dark-mode .ticket-view-status-select option[value="pending"] {
  color: #a5b4fc;
}

html.dark-mode .ticket-status-select option[value="sent_to_kim"],
html.dark-mode .ticket-view-status-select option[value="sent_to_kim"] {
  color: #fcd34d;
}

html.dark-mode .ticket-status-select option[value="approved"],
html.dark-mode .ticket-view-status-select option[value="approved"] {
  color: #6ee7b7;
}

html.dark-mode .ticket-status-select option[value="denied"],
html.dark-mode .ticket-view-status-select option[value="denied"] {
  color: #fca5a5;
}

html.dark-mode .ticket-status-select option[value="closed"],
html.dark-mode .ticket-view-status-select option[value="closed"] {
  color: #94a3b8;
}

html.dark-mode .ticket-status-select option[value="roc_ticket_submitted"],
html.dark-mode .ticket-view-status-select option[value="roc_ticket_submitted"] {
  color: #fdba74;
}

html.dark-mode .ticket-status-select option[value="cancelled"],
html.dark-mode .ticket-view-status-select option[value="cancelled"] {
  color: #c4b5fd;
}

/* Per-reason option text colors */
html.dark-mode .ticket-view-reason-select option[value="DOWNTIME"] {
  color: #fca5a5;
}

html.dark-mode .ticket-view-reason-select option[value="SYS_FIXAGT"] {
  color: #fdba74;
}

html.dark-mode .ticket-view-reason-select option[value="SYSTEM"] {
  color: #a5b4fc;
}

html.dark-mode .ticket-view-reason-select option[value="EMERGENCY"] {
  color: #fca5a5;
}

html.dark-mode .ticket-view-reason-select option[value="UPOPA"] {
  color: #c4b5fd;
}

html.dark-mode .ticket-view-reason-select option[value="ERG_EVENT"] {
  color: #6ee7b7;
}

html.dark-mode .ticket-view-reason-select option[value="MOVE_COACHING"] {
  color: #7dd3fc;
}

html.dark-mode .ticket-view-reason-select option[value="OTHER"] {
  color: #5eead4;
}

/* ── Ticket rule delete button hover ─────────────────────────────────── */
html.dark-mode .ticket-rule-delete-btn:hover {
  background: rgba(239, 68, 68, 0.12);
}

/* ── Commission Hardcoded Backgrounds (commission.css) ───────────────── */
html.dark-mode .commission-alert-warning,
html.dark-mode .commission-note-warning {
  background: rgba(245, 158, 11, 0.12);
}

html.dark-mode .commission-alert-error {
  background: rgba(239, 68, 68, 0.12);
}

html.dark-mode .commission-status-info {
  background: rgba(59, 130, 246, 0.12);
}

/* ── Compliance Matrix (compliance.css) ──────────────────────────────── */
html.dark-mode .compliance-matrix tbody tr:hover td {
  background: var(--card-hover);
}

html.dark-mode .compliance-matrix tbody tr:hover .compliance-member-cell {
  background: var(--card-hover);
}

html.dark-mode .compliance-member-cell {
  background: var(--card);
}

html.dark-mode .compliance-check-cell.checked {
  background: rgba(16, 185, 129, 0.12) !important;
}

html.dark-mode .compliance-check-cell.checked-negative {
  background: rgba(239, 68, 68, 0.12) !important;
}

html.dark-mode .compliance-check-cell.checked-informational {
  background: rgba(59, 130, 246, 0.12) !important;
}

html.dark-mode .compliance-check-cell.flagged {
  background: rgba(249, 168, 37, 0.12) !important;
}

html.dark-mode .compliance-check-cell.flagged.checked {
  background: linear-gradient(135deg, rgba(249, 168, 37, 0.12) 40%, rgba(16, 185, 129, 0.12) 100%) !important;
}

html.dark-mode .compliance-check-cell.flagged.checked-negative {
  background: linear-gradient(135deg, rgba(249, 168, 37, 0.12) 40%, rgba(239, 68, 68, 0.12) 100%) !important;
}

html.dark-mode .compliance-check-cell.flagged.checked-informational {
  background: linear-gradient(135deg, rgba(249, 168, 37, 0.12) 40%, rgba(59, 130, 246, 0.12) 100%) !important;
}

html.dark-mode .compliance-check-cell.exempt {
  background: rgba(100, 116, 139, 0.15) !important;
}

html.dark-mode .mc-item-checked-informational {
  background: rgba(59, 130, 246, 0.12);
}

html.dark-mode .mc-item-checked-negative {
  background: rgba(239, 68, 68, 0.12);
}

html.dark-mode .mc-item-flagged {
  background: rgba(249, 168, 37, 0.12) !important;
}

html.dark-mode .mc-item-flagged.mc-item-checked {
  background: linear-gradient(135deg, rgba(249, 168, 37, 0.12) 40%, rgba(16, 185, 129, 0.12) 100%) !important;
}

html.dark-mode .mc-item-flagged.mc-item-checked-negative {
  background: linear-gradient(135deg, rgba(249, 168, 37, 0.12) 40%, rgba(239, 68, 68, 0.12) 100%) !important;
}

html.dark-mode .mc-item-flagged.mc-item-checked-informational {
  background: linear-gradient(135deg, rgba(249, 168, 37, 0.12) 40%, rgba(59, 130, 246, 0.12) 100%) !important;
}

html.dark-mode .mc-item-checked-informational .mc-item-name {
  color: #93c5fd;
}

html.dark-mode .member-compliance-btn.has-flagged {
  color: #f87171;
  background: rgba(239, 68, 68, 0.12);
  border-color: rgba(239, 68, 68, 0.3);
}

html.dark-mode .member-compliance-btn.has-flagged:hover {
  background: rgba(239, 68, 68, 0.18);
  border-color: rgba(239, 68, 68, 0.5);
}

/* ── Sticky Notes Board & Components (sticky-notes.css) ──────────────── */
html.dark-mode .sticky-notes-board {
  background: linear-gradient(
    145deg,
    rgba(30, 41, 59, 0.5) 0%,
    rgba(15, 23, 42, 0.6) 50%,
    rgba(30, 27, 75, 0.4) 100%
  );
}

html.dark-mode .sticky-notes-board::before {
  background-image: radial-gradient(circle, rgba(129, 140, 248, 0.07) 1px, transparent 1px);
}

html.dark-mode .sticky-note {
  border-color: rgba(255, 255, 255, 0.1);
}

html.dark-mode .sticky-note-toolbar {
  color: rgba(226, 232, 240, 0.65);
}

html.dark-mode .sticky-note-toolbar button {
  background: rgba(0, 0, 0, 0.2);
  color: var(--text);
}

html.dark-mode .sticky-note-toolbar button:hover {
  background: rgba(0, 0, 0, 0.35);
}

html.dark-mode .sticky-note-toolbar button[aria-pressed="true"] {
  background: rgba(255, 255, 255, 0.12);
}

html.dark-mode .sticky-note-title {
  border-bottom-color: rgba(226, 232, 240, 0.15);
}

html.dark-mode .sticky-note-title:focus {
  border-bottom-color: rgba(226, 232, 240, 0.4);
}

html.dark-mode .sticky-note-title::placeholder {
  color: rgba(226, 232, 240, 0.35);
}

html.dark-mode .sticky-note textarea::placeholder {
  color: rgba(226, 232, 240, 0.45);
}

html.dark-mode .sticky-note .sticky-note-meta,
html.dark-mode .sticky-note-meta-row {
  color: rgba(226, 232, 240, 0.5);
}

html.dark-mode .sticky-note-menu-btn {
  color: rgba(226, 232, 240, 0.5);
}

html.dark-mode .sticky-note-menu-btn:hover {
  background: rgba(226, 232, 240, 0.08);
  color: rgba(226, 232, 240, 0.85);
}

html.dark-mode .sticky-note-color.active {
  border-color: rgba(226, 232, 240, 0.5);
}

html.dark-mode .sticky-note-resize-handle::after {
  border-right-color: rgba(226, 232, 240, 0.2);
  border-bottom-color: rgba(226, 232, 240, 0.2);
}

html.dark-mode .sticky-note:hover .sticky-note-resize-handle::after {
  border-color: rgba(226, 232, 240, 0.35);
}

/* Darken sticky note colors for dark mode */
html.dark-mode .sticky-note.color-sunset {
  background: linear-gradient(135deg, #78350f 0%, #92400e 40%, #a16207 100%);
  border-color: rgba(252, 211, 77, 0.2);
}

html.dark-mode .sticky-note.color-lavender {
  background: linear-gradient(135deg, #3b0764 0%, #4c1d95 40%, #5b21b6 100%);
  border-color: rgba(196, 181, 253, 0.2);
}

html.dark-mode .sticky-note.color-mint {
  background: linear-gradient(135deg, #052e16 0%, #064e3b 40%, #065f46 100%);
  border-color: rgba(134, 239, 172, 0.2);
}

html.dark-mode .sticky-note.color-sky {
  background: linear-gradient(135deg, #0c4a6e 0%, #075985 40%, #0369a1 100%);
  border-color: rgba(125, 211, 252, 0.2);
}

html.dark-mode .sticky-note.color-rose {
  background: linear-gradient(135deg, #4c0519 0%, #881337 40%, #9f1239 100%);
  border-color: rgba(253, 164, 175, 0.2);
}

html.dark-mode .sticky-note.color-peach {
  background: linear-gradient(135deg, #7c2d12 0%, #9a3412 40%, #c2410c 100%);
  border-color: rgba(253, 186, 116, 0.2);
}

html.dark-mode .sticky-note.color-slate {
  background: linear-gradient(135deg, #1e293b 0%, #334155 40%, #475569 100%);
  border-color: rgba(203, 213, 225, 0.2);
}

/* ── Bulk Grid (bulk.css) ────────────────────────────────────────────── */
html.dark-mode .bulk-grid tbody tr.bulk-row-selected {
  background: rgba(99, 102, 241, 0.1);
}

html.dark-mode .bulk-grid td.bulk-selected {
  background: rgba(59, 130, 246, 0.12);
}

html.dark-mode .bulk-fill-handle {
  border-color: var(--card);
}

/* ── Search results (search.css) ──────────────────────────────────────── */
html.dark-mode .search-result-card:hover,
html.dark-mode .search-result:hover {
  background: var(--card-hover);
}

html.dark-mode .search-result-item.completed {
  background: rgba(16, 185, 129, 0.08);
}

html.dark-mode .ms-recognition-tile--gold .ms-recognition-medal {
  background: linear-gradient(145deg, rgba(245, 158, 11, 0.3), rgba(251, 191, 36, 0.2));
}

html.dark-mode .ms-recognition-tile--silver .ms-recognition-medal {
  background: linear-gradient(145deg, rgba(148, 163, 184, 0.3), rgba(203, 213, 225, 0.2));
}

html.dark-mode .ms-recognition-tile--bronze .ms-recognition-medal {
  background: linear-gradient(145deg, rgba(194, 112, 62, 0.3), rgba(212, 149, 106, 0.2));
}

/* ── Notebook Mention Tags (notebooks.css) ───────────────────────────── */
html.dark-mode .nb-mention-tag {
  background: rgba(59, 130, 246, 0.15);
  color: #93c5fd;
}

html.dark-mode .nb-mention-tag:hover {
  background: rgba(59, 130, 246, 0.25);
  color: #bfdbfe;
}

/* ── Responsive form-complete button hover (responsive.css) ──────────── */
html.dark-mode .form-complete-btn:hover {
  color: #fff;
}

/* ── Log status connected (pages.css) ────────────────────────────────── */
html.dark-mode .log-status.connected {
  color: #fff;
}

/* ── Metrics KPI items (metrics.css) ─────────────────────────────────── */
html.dark-mode .mx-kpi-quality-item strong {
  color: #e2e8f0;
}

/* ── Commission table highlights (commission.css) ────────────────────── */
html.dark-mode [class*="commission-row-highlight"],
html.dark-mode .commission-row-warning {
  background: rgba(245, 158, 11, 0.08);
}

/* ── Search page specific overrides (search.css) ─────────────────────── */
html.dark-mode .search-cmd-palette,
html.dark-mode .search-dropdown,
html.dark-mode .search-result-panel {
  background: var(--card);
  border-color: var(--border);
}

/* ── Huddle note specific overrides (huddle.css) ─────────────────────── */
html.dark-mode .huddle-note-card {
  background: var(--card);
}

/* ── Toggle slider (compliance.css) ──────────────────────────────────── */
html.dark-mode .toggle-slider::after {
  background: var(--text);
}

/* =====================================================================
   SYSTEM THEME DARK MODE OVERRIDES (prefers-color-scheme: dark)
   Mirrors all the above overrides for system-theme users.
   ===================================================================== */
@media (prefers-color-scheme: dark) {
  /* ── Priority Pills ── */
  html.system-theme .pill.priority-high,
  html.system-theme .pill[class*="high"] {
    background: rgba(239, 68, 68, 0.15);
    color: #fca5a5;
    border-color: rgba(239, 68, 68, 0.3);
  }

  html.system-theme .pill.priority-medium,
  html.system-theme .pill[class*="medium"] {
    background: rgba(245, 158, 11, 0.15);
    color: #fcd34d;
    border-color: rgba(245, 158, 11, 0.3);
  }

  html.system-theme .pill.priority-low,
  html.system-theme .pill[class*="low"] {
    background: rgba(16, 185, 129, 0.15);
    color: #6ee7b7;
    border-color: rgba(16, 185, 129, 0.3);
  }

  /* ── Todo Completed & Archived ── */
  html.system-theme .list li.completed,
  html.system-theme .list li.past-due.completed {
    background: rgba(16, 185, 129, 0.08);
    border-color: rgba(16, 185, 129, 0.2);
  }

  html.system-theme .list li.archived {
    background: rgba(100, 116, 139, 0.1);
    border-color: rgba(100, 116, 139, 0.2);
  }

  html.system-theme .pill.status-archived {
    background: rgba(100, 116, 139, 0.15);
    color: #94a3b8;
    border-color: rgba(100, 116, 139, 0.3);
  }

  html.system-theme .list li.starred:not(.past-due) {
    background: rgba(250, 204, 21, 0.1);
  }

  /* ── Settings Rule Badges ── */
  html.system-theme .settings-rule-badge--add {
    background: rgba(16, 185, 129, 0.15);
    color: #6ee7b7;
  }

  html.system-theme .settings-rule-badge--remove {
    background: rgba(239, 68, 68, 0.15);
    color: #fca5a5;
  }

  html.system-theme .settings-rule-badge--complete {
    background: rgba(59, 130, 246, 0.15);
    color: #93c5fd;
  }

  /* ── Ticket Statuses ── */
  html.system-theme .tickets-badge-pending.active { background: rgba(99, 102, 241, 0.15); }
  html.system-theme .tickets-badge-sent-to-kim.active { background: rgba(245, 158, 11, 0.15); }
  html.system-theme .tickets-badge-approved.active { background: rgba(16, 185, 129, 0.15); }
  html.system-theme .tickets-badge-denied.active { background: rgba(239, 68, 68, 0.15); }
  html.system-theme .tickets-badge-closed.active { background: rgba(100, 116, 139, 0.15); border-color: #64748b; }
  html.system-theme .tickets-badge-roc-ticket-submitted.active { background: rgba(234, 88, 12, 0.15); border-color: #ea580c; }
  html.system-theme .tickets-badge-cancelled.active { background: rgba(139, 92, 246, 0.15); border-color: #7c3aed; }

  html.system-theme .ticket-status-pending { background: rgba(99, 102, 241, 0.15); color: #a5b4fc; border-color: rgba(99, 102, 241, 0.3); }
  html.system-theme .ticket-status-sent_to_kim { background: rgba(245, 158, 11, 0.15); color: #fcd34d; border-color: rgba(245, 158, 11, 0.3); }
  html.system-theme .ticket-status-approved { background: rgba(16, 185, 129, 0.15); color: #6ee7b7; border-color: rgba(16, 185, 129, 0.3); }
  html.system-theme .ticket-status-denied { background: rgba(239, 68, 68, 0.15); color: #fca5a5; border-color: rgba(239, 68, 68, 0.3); }
  html.system-theme .ticket-status-closed { background: rgba(100, 116, 139, 0.15); color: #94a3b8; border-color: rgba(100, 116, 139, 0.3); }
  html.system-theme .ticket-status-roc_ticket_submitted { background: rgba(234, 88, 12, 0.15); color: #fdba74; border-color: rgba(234, 88, 12, 0.3); }
  html.system-theme .ticket-status-cancelled { background: rgba(139, 92, 246, 0.15); color: #c4b5fd; border-color: rgba(139, 92, 246, 0.3); }

  html.system-theme .ticket-status-pill.ticket-status-pending { background: rgba(99, 102, 241, 0.15); color: #a5b4fc; }
  html.system-theme .ticket-status-pill.ticket-status-sent_to_kim { background: rgba(245, 158, 11, 0.15); color: #fcd34d; }
  html.system-theme .ticket-status-pill.ticket-status-approved { background: rgba(16, 185, 129, 0.15); color: #6ee7b7; }
  html.system-theme .ticket-status-pill.ticket-status-denied { background: rgba(239, 68, 68, 0.15); color: #fca5a5; }
  html.system-theme .ticket-status-pill.ticket-status-closed { background: rgba(100, 116, 139, 0.15); color: #94a3b8; }
  html.system-theme .ticket-status-pill.ticket-status-roc_ticket_submitted { background: rgba(234, 88, 12, 0.15); color: #fdba74; }
  html.system-theme .ticket-status-pill.ticket-status-cancelled { background: rgba(139, 92, 246, 0.15); color: #c4b5fd; }

  html.system-theme .ticket-priority-low { background: rgba(16, 185, 129, 0.15); color: #6ee7b7; }
  html.system-theme .ticket-priority-medium { background: rgba(245, 158, 11, 0.15); color: #fcd34d; }
  html.system-theme .ticket-priority-high { background: rgba(234, 88, 12, 0.15); color: #fdba74; }
  html.system-theme .ticket-priority-urgent { background: rgba(239, 68, 68, 0.15); color: #fca5a5; }

  html.system-theme .ticket-active-badge.active { background: rgba(16, 185, 129, 0.15); color: #6ee7b7; }
  html.system-theme .ticket-active-badge.inactive { background: rgba(100, 116, 139, 0.15); color: #94a3b8; }

  /* Ticket reason badges */
  html.system-theme .ticket-reason-downtime { background: rgba(239, 68, 68, 0.12); color: #fca5a5; border-color: rgba(239, 68, 68, 0.3); }
  html.system-theme .ticket-reason-sys_fixagt { background: rgba(234, 88, 12, 0.12); color: #fdba74; border-color: rgba(234, 88, 12, 0.3); }
  html.system-theme .ticket-reason-system { background: rgba(99, 102, 241, 0.12); color: #a5b4fc; border-color: rgba(99, 102, 241, 0.3); }
  html.system-theme .ticket-reason-emergency { background: rgba(220, 38, 38, 0.15); color: #fca5a5; border-color: rgba(220, 38, 38, 0.3); }
  html.system-theme .ticket-reason-upopa { background: rgba(139, 92, 246, 0.12); color: #c4b5fd; border-color: rgba(139, 92, 246, 0.3); }
  html.system-theme .ticket-reason-erg_event { background: rgba(16, 185, 129, 0.12); color: #6ee7b7; border-color: rgba(16, 185, 129, 0.3); }
  html.system-theme .ticket-reason-move_coaching { background: rgba(14, 165, 233, 0.12); color: #7dd3fc; border-color: rgba(14, 165, 233, 0.3); }
  html.system-theme .ticket-reason-other { background: rgba(20, 184, 166, 0.12); color: #5eead4; border-color: rgba(20, 184, 166, 0.3); }

  /* ── Ticket Reason Radio Chips (checked states) ── */
  html.system-theme .ticket-radio-label input[type="radio"]:checked + .ticket-reason-downtime { border-color: #f87171; background: rgba(239, 68, 68, 0.15); color: #fca5a5; }
  html.system-theme .ticket-radio-label input[type="radio"]:checked + .ticket-reason-sys_fixagt { border-color: #fb923c; background: rgba(234, 88, 12, 0.15); color: #fdba74; }
  html.system-theme .ticket-radio-label input[type="radio"]:checked + .ticket-reason-system { border-color: #818cf8; background: rgba(99, 102, 241, 0.15); color: #a5b4fc; }
  html.system-theme .ticket-radio-label input[type="radio"]:checked + .ticket-reason-emergency { border-color: #f87171; background: rgba(220, 38, 38, 0.18); color: #fca5a5; }
  html.system-theme .ticket-radio-label input[type="radio"]:checked + .ticket-reason-upopa { border-color: #a78bfa; background: rgba(139, 92, 246, 0.15); color: #c4b5fd; }
  html.system-theme .ticket-radio-label input[type="radio"]:checked + .ticket-reason-erg_event { border-color: #34d399; background: rgba(16, 185, 129, 0.15); color: #6ee7b7; }
  html.system-theme .ticket-radio-label input[type="radio"]:checked + .ticket-reason-move_coaching { border-color: #38bdf8; background: rgba(14, 165, 233, 0.15); color: #7dd3fc; }
  html.system-theme .ticket-radio-label input[type="radio"]:checked + .ticket-reason-other { border-color: #2dd4bf; background: rgba(20, 184, 166, 0.15); color: #5eead4; }

  /* ── Badge Classes ── */
  html.system-theme .badge-success { background: rgba(34, 197, 94, 0.15); color: #4ade80; border-color: rgba(34, 197, 94, 0.25); }
  html.system-theme .badge-info { background: rgba(59, 130, 246, 0.15); color: #60a5fa; border-color: rgba(59, 130, 246, 0.25); }
  html.system-theme .badge-default { background: rgba(156, 163, 175, 0.15); color: #9ca3af; border-color: rgba(156, 163, 175, 0.25); }

  /* ── Ticket rule delete button hover ── */
  html.system-theme .ticket-rule-delete-btn:hover { background: rgba(239, 68, 68, 0.12); }

  /* ── Ticket Select Dropdown Option Elements ── */
  html.system-theme .ticket-status-select option,
  html.system-theme .ticket-view-status-select option,
  html.system-theme .ticket-view-reason-select option,
  html.system-theme .tickets-filter-select option,
  html.system-theme .tickets-bulk-status-select option {
    background: #1e293b;
    color: #e2e8f0;
  }

  html.system-theme .ticket-status-select option[value="pending"],
  html.system-theme .ticket-view-status-select option[value="pending"] { color: #a5b4fc; }
  html.system-theme .ticket-status-select option[value="sent_to_kim"],
  html.system-theme .ticket-view-status-select option[value="sent_to_kim"] { color: #fcd34d; }
  html.system-theme .ticket-status-select option[value="approved"],
  html.system-theme .ticket-view-status-select option[value="approved"] { color: #6ee7b7; }
  html.system-theme .ticket-status-select option[value="denied"],
  html.system-theme .ticket-view-status-select option[value="denied"] { color: #fca5a5; }
  html.system-theme .ticket-status-select option[value="closed"],
  html.system-theme .ticket-view-status-select option[value="closed"] { color: #94a3b8; }
  html.system-theme .ticket-status-select option[value="roc_ticket_submitted"],
  html.system-theme .ticket-view-status-select option[value="roc_ticket_submitted"] { color: #fdba74; }
  html.system-theme .ticket-status-select option[value="cancelled"],
  html.system-theme .ticket-view-status-select option[value="cancelled"] { color: #c4b5fd; }

  html.system-theme .ticket-view-reason-select option[value="DOWNTIME"] { color: #fca5a5; }
  html.system-theme .ticket-view-reason-select option[value="SYS_FIXAGT"] { color: #fdba74; }
  html.system-theme .ticket-view-reason-select option[value="SYSTEM"] { color: #a5b4fc; }
  html.system-theme .ticket-view-reason-select option[value="EMERGENCY"] { color: #fca5a5; }
  html.system-theme .ticket-view-reason-select option[value="UPOPA"] { color: #c4b5fd; }
  html.system-theme .ticket-view-reason-select option[value="ERG_EVENT"] { color: #6ee7b7; }
  html.system-theme .ticket-view-reason-select option[value="MOVE_COACHING"] { color: #7dd3fc; }
  html.system-theme .ticket-view-reason-select option[value="OTHER"] { color: #5eead4; }

  /* ── Compliance Matrix ── */
  html.system-theme .compliance-matrix tbody tr:hover td { background: var(--card-hover); }
  html.system-theme .compliance-matrix tbody tr:hover .compliance-member-cell { background: var(--card-hover); }
  html.system-theme .compliance-member-cell { background: var(--card); }
  html.system-theme .compliance-check-cell.checked { background: rgba(16, 185, 129, 0.12) !important; }
  html.system-theme .compliance-check-cell.checked-negative { background: rgba(239, 68, 68, 0.12) !important; }
  html.system-theme .compliance-check-cell.checked-informational { background: rgba(59, 130, 246, 0.12) !important; }
  html.system-theme .compliance-check-cell.flagged { background: rgba(249, 168, 37, 0.12) !important; }
  html.system-theme .compliance-check-cell.flagged.checked { background: linear-gradient(135deg, rgba(249, 168, 37, 0.12) 40%, rgba(16, 185, 129, 0.12) 100%) !important; }
  html.system-theme .compliance-check-cell.flagged.checked-negative { background: linear-gradient(135deg, rgba(249, 168, 37, 0.12) 40%, rgba(239, 68, 68, 0.12) 100%) !important; }
  html.system-theme .compliance-check-cell.flagged.checked-informational { background: linear-gradient(135deg, rgba(249, 168, 37, 0.12) 40%, rgba(59, 130, 246, 0.12) 100%) !important; }
  html.system-theme .compliance-check-cell.exempt { background: rgba(100, 116, 139, 0.15) !important; }
  html.system-theme .mc-item-checked-informational { background: rgba(59, 130, 246, 0.12); }
  html.system-theme .mc-item-checked-negative { background: rgba(239, 68, 68, 0.12); }
  html.system-theme .mc-item-flagged { background: rgba(249, 168, 37, 0.12) !important; }
  html.system-theme .mc-item-flagged.mc-item-checked { background: linear-gradient(135deg, rgba(249, 168, 37, 0.12) 40%, rgba(16, 185, 129, 0.12) 100%) !important; }
  html.system-theme .mc-item-flagged.mc-item-checked-negative { background: linear-gradient(135deg, rgba(249, 168, 37, 0.12) 40%, rgba(239, 68, 68, 0.12) 100%) !important; }
  html.system-theme .mc-item-flagged.mc-item-checked-informational { background: linear-gradient(135deg, rgba(249, 168, 37, 0.12) 40%, rgba(59, 130, 246, 0.12) 100%) !important; }
  html.system-theme .mc-item-checked-informational .mc-item-name { color: #93c5fd; }
  html.system-theme .member-compliance-btn.has-flagged { color: #f87171; background: rgba(239, 68, 68, 0.12); border-color: rgba(239, 68, 68, 0.3); }
  html.system-theme .member-compliance-btn.has-flagged:hover { background: rgba(239, 68, 68, 0.18); border-color: rgba(239, 68, 68, 0.5); }

  /* ── Sticky Notes Board ── */
  html.system-theme .sticky-notes-board {
    background: linear-gradient(145deg, rgba(30, 41, 59, 0.5) 0%, rgba(15, 23, 42, 0.6) 50%, rgba(30, 27, 75, 0.4) 100%);
  }
  html.system-theme .sticky-notes-board::before {
    background-image: radial-gradient(circle, rgba(129, 140, 248, 0.07) 1px, transparent 1px);
  }
  html.system-theme .sticky-note { border-color: rgba(255, 255, 255, 0.1); }
  html.system-theme .sticky-note-toolbar { color: rgba(226, 232, 240, 0.65); }
  html.system-theme .sticky-note-toolbar button { background: rgba(0, 0, 0, 0.2); color: var(--text); }
  html.system-theme .sticky-note-toolbar button:hover { background: rgba(0, 0, 0, 0.35); }
  html.system-theme .sticky-note-title { border-bottom-color: rgba(226, 232, 240, 0.15); }
  html.system-theme .sticky-note .sticky-note-meta,
  html.system-theme .sticky-note-meta-row { color: rgba(226, 232, 240, 0.5); }
  html.system-theme .sticky-note-menu-btn { color: rgba(226, 232, 240, 0.5); }
  html.system-theme .sticky-note-resize-handle::after { border-right-color: rgba(226, 232, 240, 0.2); border-bottom-color: rgba(226, 232, 240, 0.2); }

  /* Darken sticky note colors */
  html.system-theme .sticky-note.color-sunset { background: linear-gradient(135deg, #78350f 0%, #92400e 40%, #a16207 100%); border-color: rgba(252, 211, 77, 0.2); }
  html.system-theme .sticky-note.color-lavender { background: linear-gradient(135deg, #3b0764 0%, #4c1d95 40%, #5b21b6 100%); border-color: rgba(196, 181, 253, 0.2); }
  html.system-theme .sticky-note.color-mint { background: linear-gradient(135deg, #052e16 0%, #064e3b 40%, #065f46 100%); border-color: rgba(134, 239, 172, 0.2); }
  html.system-theme .sticky-note.color-sky { background: linear-gradient(135deg, #0c4a6e 0%, #075985 40%, #0369a1 100%); border-color: rgba(125, 211, 252, 0.2); }
  html.system-theme .sticky-note.color-rose { background: linear-gradient(135deg, #4c0519 0%, #881337 40%, #9f1239 100%); border-color: rgba(253, 164, 175, 0.2); }
  html.system-theme .sticky-note.color-peach { background: linear-gradient(135deg, #7c2d12 0%, #9a3412 40%, #c2410c 100%); border-color: rgba(253, 186, 116, 0.2); }
  html.system-theme .sticky-note.color-slate { background: linear-gradient(135deg, #1e293b 0%, #334155 40%, #475569 100%); border-color: rgba(203, 213, 225, 0.2); }

  /* ── Bulk Grid ── */
  html.system-theme .bulk-grid tbody tr.bulk-row-selected { background: rgba(99, 102, 241, 0.1); }
  html.system-theme .bulk-grid td.bulk-selected { background: rgba(59, 130, 246, 0.12); }

  /* ── Search results ── */
  html.system-theme .search-result-item.completed { background: rgba(16, 185, 129, 0.08); }
  html.system-theme .ms-recognition-tile--gold .ms-recognition-medal { background: linear-gradient(145deg, rgba(245, 158, 11, 0.3), rgba(251, 191, 36, 0.2)); }
  html.system-theme .ms-recognition-tile--silver .ms-recognition-medal { background: linear-gradient(145deg, rgba(148, 163, 184, 0.3), rgba(203, 213, 225, 0.2)); }
  html.system-theme .ms-recognition-tile--bronze .ms-recognition-medal { background: linear-gradient(145deg, rgba(194, 112, 62, 0.3), rgba(212, 149, 106, 0.2)); }

  /* ── Notebook Mention Tags ── */
  html.system-theme .nb-mention-tag { background: rgba(59, 130, 246, 0.15); color: #93c5fd; }
  html.system-theme .nb-mention-tag:hover { background: rgba(59, 130, 246, 0.25); color: #bfdbfe; }

  /* ── Toggle slider ── */
  html.system-theme .toggle-slider::after { background: var(--text); }
}
