/* ==========================================================================
   macOS Sequoia Visual Aesthetic Redesign - Complete Class Mappings
   ========================================================================== */

:root {
  /* macOS Sequoia inspired palette */
  --mac-bg: #1c1c1e;
  --mac-surface: rgba(44,44,46,0.65);
  --mac-elevated: rgba(58,58,60,0.75);
  --mac-card: rgba(28,28,30,0.5);
  --mac-separator: rgba(84,84,88,0.35);
  --mac-separator-opaque: rgba(84,84,88,0.25);

  /* Vibrancy layers */
  --vibrancy-ultra-thin: rgba(255,255,255,0.03);
  --vibrancy-thin: rgba(255,255,255,0.06);
  --vibrancy-regular: rgba(255,255,255,0.1);
  --vibrancy-thick: rgba(255,255,255,0.15);

  /* macOS accent blue */
  --accent: #0A84FF;
  --accent-glow: rgba(10,132,255,0.3);
  --accent-fill: rgba(10,132,255,0.15);
  --accent-hover: #409CFF;

  /* Semantic status colors */
  --green:  #30D158;  --green-fill:  rgba(48,209,88,0.15);
  --red:    #FF453A;  --red-fill:    rgba(255,69,58,0.15);
  --orange: #FF9F0A;  --orange-fill: rgba(255,159,10,0.15);
  --purple: #BF5AF2;  --purple-fill: rgba(191,90,242,0.15);
  --yellow: #FFD60A;  --yellow-fill: rgba(255,214,10,0.15);
  --teal:   #5AC8FA;  --teal-fill:   rgba(90,200,250,0.12);

  /* Text — macOS hierarchy */
  --label:          rgba(255,255,255,0.92);
  --secondary-label:rgba(235,235,245,0.65);
  --tertiary-label: rgba(235,235,245,0.35);
  --quaternary-label:rgba(235,235,245,0.18);

  --font: 'Inter', -apple-system, 'SF Pro Text', BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --mono: 'SF Mono', 'JetBrains Mono', ui-monospace, monospace;

  --r3: 3px; --r6: 6px; --r10: 10px; --r14: 14px;
  --r18: 18px; --r22: 22px; --r28: 28px;

  --transition: 0.18s cubic-bezier(0.4,0,0.2,1);
}

/* ── OVERRIDES FOR DARK THEME ── */
body.dark-theme {
  --bg-main: var(--mac-bg);
  --bg-surface: var(--mac-surface);
  --border-color: var(--mac-separator);
  --bg-card: var(--mac-card);
  --bg-input: rgba(118,118,128,0.12);
  --bg-th: rgba(255,255,255,0.02);
  --bg-hover: rgba(255,255,255,0.04);
  --bg-topbar: rgba(24,24,26,0.8);
  --bg-drawer: rgba(44,44,46,0.85);
  
  --text-primary: var(--label);
  --text-secondary: var(--secondary-label);
  --text-muted: var(--tertiary-label);
  --accent-primary: var(--accent);
  --accent-hover: var(--accent-hover);
  --color-success: var(--green);
  --color-warning: var(--orange);
  --color-danger: var(--red);
  --color-info: var(--teal);

  /* Set background directly to prevent solid color block */
  background:
    radial-gradient(ellipse 120% 80% at 10% 5%, rgba(10,132,255,0.08) 0%, transparent 55%),
    radial-gradient(ellipse 80% 60% at 90% 90%, rgba(191,90,242,0.07) 0%, transparent 50%),
    radial-gradient(ellipse 60% 50% at 55% 40%, rgba(48,209,88,0.04) 0%, transparent 45%),
    linear-gradient(160deg, #0d0d0f 0%, #1a1a1e 40%, #141418 100%) !important;
}

body {
  font-family: var(--font) !important;
  font-smoothing: antialiased;
  -webkit-font-smoothing: antialiased;
  color: var(--label);
}

/* Hide standard background-before block to avoid overlap */
body.dark-theme::before {
  display: none !important;
}

/* ── SIDEBAR Redesign ── */
.sidebar {
  position: fixed !important;
  top: 52px !important;
  height: calc(100vh - 52px) !important;
  width: 220px !important;
  background: rgba(28,28,30,0.65) !important;
  backdrop-filter: blur(60px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(60px) saturate(180%) !important;
  border-right: 0.5px solid var(--mac-separator) !important;
  padding: 12px 0 !important;
  box-shadow: none !important;
  z-index: 100 !important;
}

.logo-container {
  height: 52px !important;
  display: flex !important;
  align-items: center !important;
  padding: 0 16px !important;
  border-bottom: 0.5px solid rgba(255,255,255,0.06) !important;
  gap: 10px !important;
  margin-bottom: 8px !important;
  background: none !important;
}

.logo-icon {
  width: 22px !important;
  height: 22px !important;
  border-radius: var(--r6) !important;
  background: linear-gradient(135deg, var(--accent) 0%, var(--purple) 100%) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  color: #fff !important;
  box-shadow: 0 2px 8px rgba(10,132,255,0.3) !important;
}

.logo-container h2 {
  font-size: 13.5px !important;
  font-weight: 600 !important;
  margin: 0 !important;
}

.nav-menu {
  padding: 8px 0 !important;
}

.nav-group {
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--tertiary-label) !important;
  padding: 12px 16px 4px 16px !important;
  letter-spacing: 0.01em !important;
  text-transform: uppercase !important;
}

.nav-item {
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  padding: 6px 10px 6px 16px !important;
  margin: 1px 8px !important;
  border-radius: var(--r6) !important;
  cursor: pointer !important;
  color: var(--secondary-label) !important;
  transition: all 0.13s !important;
  border: 1px solid transparent !important;
  font-size: 13px !important;
  font-weight: 400 !important;
}

.nav-item:hover {
  background: rgba(118,118,128,0.18) !important;
  color: var(--label) !important;
}

.nav-item.active {
  background: var(--accent-fill) !important;
  color: var(--accent-hover) !important;
  border-color: rgba(10,132,255,0.2) !important;
  font-weight: 500 !important;
}

.nav-item i {
  font-size: 14px !important;
  width: 18px !important;
  text-align: center !important;
  flex-shrink: 0 !important;
  color: inherit !important;
}

/* Adjust main content left margin and top offset */
.main-content {
  margin-left: 220px !important;
  padding-top: 52px !important;
  background: transparent !important;
}

/* ── TITLEBAR / TOPBAR ── */
.topbar {
  background: rgba(24,24,26,0.82) !important;
  backdrop-filter: blur(40px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(40px) saturate(180%) !important;
  border-bottom: 0.5px solid rgba(255,255,255,0.12) !important;
  box-shadow: none !important;
  background-image: linear-gradient(180deg, rgba(255,255,255,0.04) 0%, transparent 100%) !important;
  height: 52px !important;
  padding: 0 24px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  z-index: 1000 !important;
}

/* Spotlight-style Search Pill */
.search-container {
  background: rgba(118,118,128,0.24) !important;
  border: 0.5px solid rgba(255,255,255,0.08) !important;
  border-radius: var(--r10) !important;
  padding: 5px 12px !important;
  width: 260px !important;
  transition: all var(--transition) !important;
  gap: 8px !important;
  display: flex !important;
  align-items: center !important;
  box-shadow: none !important;
}

.search-container:focus-within {
  background: rgba(118,118,128,0.32) !important;
  border-color: rgba(10,132,255,0.5) !important;
  box-shadow: 0 0 0 3px rgba(10,132,255,0.15) !important;
}

.search-container i {
  color: var(--tertiary-label) !important;
  font-size: 13px !important;
}

.search-container input {
  background: transparent !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  color: var(--label) !important;
  font-size: 12.5px !important;
}

.search-container input:focus {
  box-shadow: none !important;
  border: none !important;
}

.search-container::after {
  content: '⌘K';
  font-size: 10px;
  font-family: var(--mono);
  color: var(--quaternary-label);
  background: rgba(118,118,128,0.2);
  padding: 1px 4px;
  border-radius: 3px;
  border: 0.5px solid rgba(255,255,255,0.08);
}

.topbar-actions i {
  color: var(--secondary-label) !important;
  font-size: 16px !important;
  cursor: pointer !important;
}
.topbar-actions i:hover {
  color: var(--label) !important;
}

/* Time Indicator */
#tb-clock {
  font-family: var(--mono) !important;
  font-size: 11.5px !important;
  color: var(--secondary-label) !important;
  background: rgba(118,118,128,0.16) !important;
  padding: 3px 8px !important;
  border-radius: 20px !important;
  border: 0.5px solid rgba(255,255,255,0.07) !important;
  margin-right: 8px !important;
}

.user-avatar {
  width: 26px !important;
  height: 26px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, var(--accent) 0%, var(--purple) 100%) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  color: #fff !important;
  border: 1.5px solid rgba(255,255,255,0.15) !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.2) !important;
}

/* ── CARDS (macOS Card Specular Highlight) ── */
.card, .summary-card, .chart-card, .data-card, .table-card, .dashboard-card {
  background: rgba(255,255,255,0.05) !important;
  backdrop-filter: blur(30px) saturate(150%) !important;
  -webkit-backdrop-filter: blur(30px) saturate(150%) !important;
  border-radius: var(--r14) !important;
  border: 0.5px solid rgba(255,255,255,0.1) !important;
  box-shadow:
    0 0 0 0.5px rgba(255,255,255,0.07) inset,
    0 1px 0 rgba(255,255,255,0.06) inset,
    0 8px 32px rgba(0,0,0,0.3) !important;
  overflow: hidden !important;
  margin-bottom: 16px;
}

.card-header, .card-hd {
  padding: 13px 16px !important;
  border-bottom: 0.5px solid rgba(255,255,255,0.07) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  background: none !important;
}

.card-header h2, .card-title {
  font-size: 13.5px !important;
  font-weight: 600 !important;
  color: var(--label) !important;
}

.card-body, .card-content {
  padding: 16px !important;
  background: none !important;
}

/* ── METRICS GRID Redesign ── */
.metrics-grid, .summary-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 12px !important;
  margin-bottom: 16px !important;
}

.metric-card, .metric-box {
  background: rgba(255,255,255,0.05) !important;
  backdrop-filter: blur(30px) !important;
  -webkit-backdrop-filter: blur(30px) !important;
  border-radius: var(--r14) !important;
  border: 0.5px solid rgba(255,255,255,0.09) !important;
  padding: 16px !important;
  position: relative !important;
  overflow: hidden !important;
  transition: all 0.2s !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  box-shadow: 0 0 0 0.5px rgba(255,255,255,0.05) inset, 0 6px 24px rgba(0,0,0,0.25) !important;
}
.metric-card:hover, .metric-box:hover {
  border-color: rgba(255,255,255,0.18) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 10px 30px rgba(0,0,0,0.4) !important;
}

.metric-info h3 {
  font-size: 11px !important;
  color: var(--tertiary-label) !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  margin-bottom: 6px !important;
}

.metric-info h2 {
  font-size: 28px !important;
  font-weight: 700 !important;
  font-family: var(--mono) !important;
  color: var(--label) !important;
  margin: 0 !important;
}

.metric-icon {
  width: 38px !important;
  height: 38px !important;
  border-radius: 8px !important;
  font-size: 16px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.bg-blue { background: rgba(10, 132, 255, 0.18) !important; color: #0A84FF !important; }
.bg-green { background: rgba(48, 209, 88, 0.15) !important; color: #30D158 !important; }
.bg-orange { background: rgba(255, 159, 10, 0.15) !important; color: #FF9F0A !important; }
.bg-red { background: rgba(255, 69, 58, 0.14) !important; color: #FF453A !important; }

/* ── TABLES Adaptations ── */
.tbl-wrap, .table-container {
  overflow-x: auto !important;
  background: none !important;
}

table, .compact-table, .client-table, .installment-table, .reports-table {
  width: 100% !important;
  border-collapse: collapse !important;
  font-size: 12.5px !important;
}

table thead th, th {
  text-align: left !important;
  padding: 8px 14px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--tertiary-label) !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  border-bottom: 0.5px solid rgba(255,255,255,0.08) !important;
  background: rgba(255,255,255,0.02) !important;
}

table tbody tr td, td {
  padding: 10px 14px !important;
  color: var(--secondary-label) !important;
  border-bottom: 0.5px solid rgba(255,255,255,0.05) !important;
  background: none !important;
  vertical-align: middle !important;
}

table tbody tr:hover td {
  background: rgba(255,255,255,0.04) !important;
}

/* ── macOS BUTTONS ── */
.primary-btn, .btn-primary {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 6px 14px !important;
  border-radius: var(--r6) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  font-family: var(--font) !important;
  cursor: pointer !important;
  border: none !important;
  background: var(--accent) !important;
  color: #fff !important;
  transition: all var(--transition) !important;
  box-shadow: 0 2px 10px var(--accent-glow) !important;
}
.primary-btn:hover, .btn-primary:hover {
  background: var(--accent-hover) !important;
  box-shadow: 0 4px 16px var(--accent-glow) !important;
  transform: translateY(-1px) !important;
}

.secondary-btn, .btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 6px 14px !important;
  border-radius: var(--r6) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  font-family: var(--font) !important;
  cursor: pointer !important;
  border: 0.5px solid rgba(255,255,255,0.14) !important;
  background: var(--vibrancy-thin) !important;
  color: var(--label) !important;
  transition: all var(--transition) !important;
  backdrop-filter: blur(10px) !important;
}
.secondary-btn:hover, .btn:hover {
  background: var(--vibrancy-regular) !important;
  border-color: rgba(255,255,255,0.2) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 16px rgba(0,0,0,0.3) !important;
}

/* ── PROGRESS BAR ── */
.progress-bar-bg {
  height: 5px !important;
  background: rgba(118,118,128,0.2) !important;
  border-radius: 99px !important;
  overflow: hidden !important;
}
.progress-bar-fill {
  height: 100% !important;
  border-radius: 99px !important;
  background: linear-gradient(90deg, var(--accent), var(--teal)) !important;
  box-shadow: 0 0 8px rgba(10,132,255,0.4) !important;
  transition: width 1.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
}
.progress-label {
  font-family: var(--mono) !important;
  font-size: 11px !important;
  color: var(--green) !important;
  font-weight: 700 !important;
}

/* ── COMPLIANCE STATS ── */
.compliance-summary-grid {
  display: flex !important;
  gap: 12px !important;
}
.compliance-stat {
  flex: 1 !important;
  background: rgba(255, 255, 255, 0.03) !important;
  border: 0.5px solid rgba(255, 255, 255, 0.07) !important;
  border-radius: var(--r10) !important;
  padding: 12px !important;
  text-align: center !important;
}
.stat-number {
  font-size: 24px !important;
  font-weight: 800 !important;
  font-family: var(--mono) !important;
  display: block !important;
  margin-bottom: 4px !important;
}
.stat-number.text-green { color: var(--green) !important; }
.stat-number.text-orange { color: var(--orange) !important; }
.stat-label {
  font-size: 11px !important;
  color: var(--tertiary-label) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
}

/* ── PAGE HEADERS ── */
.page-header,
.page-hd {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  margin-bottom: 20px !important;
  padding-bottom: 8px !important;
}
.page-header h1,
.page-title {
  font-size: 22px !important;
  font-weight: 700 !important;
  letter-spacing: -0.03em !important;
  color: var(--label) !important;
  margin: 0 !important;
}
.page-sub {
  font-size: 12px !important;
  color: var(--tertiary-label) !important;
  margin-top: 3px !important;
}

/* ── SCROLLBARS ── */
::-webkit-scrollbar {
  width: 5px !important;
  height: 5px !important;
}
::-webkit-scrollbar-track {
  background: transparent !important;
}
::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.12) !important;
  border-radius: 99px !important;
}
::-webkit-scrollbar-thumb:hover {
  background: rgba(255,255,255,0.2) !important;
}

/* ── METRICS GRID macOS Sequoia styles ── */
.metrics {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 12px !important;
  margin-bottom: 16px !important;
}

.metric {
  background: rgba(255,255,255,0.05) !important;
  backdrop-filter: blur(30px) !important;
  -webkit-backdrop-filter: blur(30px) !important;
  border-radius: var(--r14) !important;
  border: 0.5px solid rgba(255,255,255,0.09) !important;
  padding: 16px !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
  position: relative !important;
  overflow: hidden !important;
  box-shadow: 0 0 0 0.5px rgba(255,255,255,0.05) inset, 0 6px 24px rgba(0,0,0,0.25) !important;
  display: block !important;
}

.metric:hover {
  border-color: rgba(255,255,255,0.18) !important;
  transform: translateY(-3px) !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.45) !important;
}

.metric:hover .metric-glow {
  opacity: 1 !important;
}

.metric-glow {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 60px !important;
  opacity: 0;
  transition: opacity 0.2s !important;
  pointer-events: none !important;
}

.metric.blue .metric-glow { background: radial-gradient(ellipse at 50% 0%, rgba(10,132,255,0.18) 0%, transparent 70%) !important; }
.metric.green .metric-glow { background: radial-gradient(ellipse at 50% 0%, rgba(48,209,88,0.16) 0%, transparent 70%) !important; }
.metric.orange .metric-glow { background: radial-gradient(ellipse at 50% 0%, rgba(255,159,10,0.16) 0%, transparent 70%) !important; }
.metric.red .metric-glow { background: radial-gradient(ellipse at 50% 0%, rgba(255,69,58,0.15) 0%, transparent 70%) !important; }

.metric-top {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  margin-bottom: 12px !important;
}

.metric-icon {
  width: 34px !important;
  height: 34px !important;
  border-radius: 9px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 15px !important;
  box-shadow: none !important;
}

.metric.blue .metric-icon { background: rgba(10,132,255,0.18) !important; color: var(--accent) !important; }
.metric.green .metric-icon { background: rgba(48,209,88,0.15) !important; color: var(--green) !important; }
.metric.orange .metric-icon { background: rgba(255,159,10,0.15) !important; color: var(--orange) !important; }
.metric.red .metric-icon { background: rgba(255,69,58,0.14) !important; color: var(--red) !important; }

.metric-delta {
  font-size: 11px !important;
  font-weight: 600 !important;
  padding: 2px 7px !important;
  border-radius: 20px !important;
  font-family: var(--mono) !important;
  display: inline-block !important;
}

.metric-delta.up { color: var(--green) !important; background: var(--green-fill) !important; }
.metric-delta.dn { color: var(--red) !important; background: var(--red-fill) !important; }
.metric-delta.nt { color: var(--tertiary-label) !important; background: rgba(118,118,128,0.15) !important; }

.metric-val {
  font-size: 28px !important;
  font-weight: 700 !important;
  letter-spacing: -0.04em !important;
  line-height: 1 !important;
  margin-bottom: 4px !important;
  font-family: var(--mono) !important;
}

.metric.blue .metric-val { color: var(--accent) !important; }
.metric.green .metric-val { color: var(--green) !important; }
.metric.orange .metric-val { color: var(--orange) !important; }
.metric.red .metric-val { color: var(--red) !important; }

.metric-label {
  font-size: 11.5px !important;
  color: var(--tertiary-label) !important;
}

/* ── LAYOUT GRIDS ── */
.g2 { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 12px !important; margin-bottom: 12px !important; }
.g3 { display: grid !important; grid-template-columns: 1fr 1fr 1fr !important; gap: 12px !important; margin-bottom: 12px !important; }
.g7-5 { display: grid !important; grid-template-columns: 7fr 5fr !important; gap: 12px !important; margin-bottom: 12px !important; }
.g5-7 { display: grid !important; grid-template-columns: 5fr 7fr !important; gap: 12px !important; margin-bottom: 12px !important; }
.mb12 { margin-bottom: 12px !important; }

/* ── PROGRESS BARS ── */
.bar-row { margin-bottom: 12px !important; }
.bar-meta { display: flex !important; justify-content: space-between !important; font-size: 11.5px !important; margin-bottom: 5px !important; }
.bar-meta .bl { color: var(--secondary-label) !important; }
.bar-meta .br { font-family: var(--mono) !important; font-size: 11px !important; }
.bar-track { height: 5px !important; background: rgba(118,118,128,0.2) !important; border-radius: 99px !important; overflow: hidden !important; }
.bar-fill { height: 100% !important; border-radius: 99px !important; transition: width 1.2s cubic-bezier(0.4,0,0.2,1) !important; }
.bar-fill.blue { background: linear-gradient(90deg, var(--accent), var(--teal)) !important; box-shadow: 0 0 8px rgba(10,132,255,0.4) !important; }
.bar-fill.green { background: linear-gradient(90deg, var(--green), #34C77B) !important; box-shadow: 0 0 8px rgba(48,209,88,0.35) !important; }
.bar-fill.orange { background: linear-gradient(90deg, var(--orange), #FFD60A) !important; }
.bar-fill.red { background: linear-gradient(90deg, var(--red), #FF8080) !important; }

/* ── HORIZONTAL BARS (hbar) ── */
.hbar { display: flex !important; align-items: center !important; gap: 10px !important; padding: 5px 0 !important; font-size: 12px !important; }
.hbar-label { width: 80px !important; color: var(--secondary-label) !important; flex-shrink: 0 !important; }
.hbar-track { flex: 1 !important; height: 4px !important; background: rgba(118,118,128,0.18) !important; border-radius: 99px !important; overflow: hidden !important; }
.hbar-fill { height: 100% !important; border-radius: 99px !important; }
.hbar-val { width: 65px !important; text-align: right !important; font-family: var(--mono) !important; font-size: 11.5px !important; font-weight: 600 !important; flex-shrink: 0 !important; }

/* ── hbar colors matching overdue aging levels ── */
#aging0to30Bar { background: var(--accent) !important; }
#aging31to60Bar { background: var(--orange) !important; }
#aging61PlusBar { background: var(--red) !important; }

/* ── macOS TABLES ── */
table.mac-tbl { width: 100% !important; border-collapse: collapse !important; font-size: 12.5px !important; }
table.mac-tbl thead th {
  text-align: left !important;
  padding: 8px 14px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--tertiary-label) !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  border-bottom: 0.5px solid rgba(255,255,255,0.08) !important;
}
table.mac-tbl tbody tr { transition: background 0.1s !important; }
table.mac-tbl tbody tr:hover td { background: rgba(255,255,255,0.04) !important; }
table.mac-tbl tbody td {
  padding: 10px 14px !important;
  color: var(--secondary-label) !important;
  border-bottom: 0.5px solid rgba(255,255,255,0.05) !important;
  vertical-align: middle !important;
}
table.mac-tbl tbody tr:last-child td { border-bottom: none !important; }
.cell-name { font-weight: 500 !important; color: var(--label) !important; font-size: 13px !important; }
.cell-sub { font-size: 11px !important; color: var(--tertiary-label) !important; margin-top: 1px !important; }
.cell-mono { font-family: var(--mono) !important; font-size: 11.5px !important; }
.cell-money { font-family: var(--mono) !important; font-size: 12.5px !important; font-weight: 600 !important; }

/* ── STATUS BADGES ── */
.badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  padding: 2px 8px !important;
  border-radius: 5px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  white-space: nowrap !important;
  border: 0.5px solid transparent !important;
}
.badge::before { content: '●' !important; font-size: 6px !important; }
.badge.red { background: var(--red-fill) !important; color: var(--red) !important; border-color: rgba(255,69,58,0.2) !important; }
.badge.orange { background: var(--orange-fill) !important; color: var(--orange) !important; border-color: rgba(255,159,10,0.2) !important; }
.badge.green { background: var(--green-fill) !important; color: var(--green) !important; border-color: rgba(48,209,88,0.2) !important; }
.badge.blue { background: var(--accent-fill) !important; color: var(--accent) !important; border-color: rgba(10,132,255,0.2) !important; }
.badge.purple { background: var(--purple-fill) !important; color: var(--purple) !important; border-color: rgba(191,90,242,0.2) !important; }
.badge.gray { background: rgba(118,118,128,0.15) !important; color: var(--secondary-label) !important; border-color: rgba(118,118,128,0.2) !important; }

/* ── BUTTONS ── */
.btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 6px 14px !important;
  border-radius: var(--r6) !important;
  font-size: 12.5px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  font-family: var(--font) !important;
  border: 0.5px solid rgba(255,255,255,0.14) !important;
  background: var(--vibrancy-thin) !important;
  color: var(--label) !important;
  transition: all var(--transition) !important;
  white-space: nowrap !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}
.btn:hover {
  background: var(--vibrancy-regular) !important;
  border-color: rgba(255,255,255,0.2) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 16px rgba(0,0,0,0.35) !important;
}
.btn:active {
  transform: translateY(0) !important;
  box-shadow: none !important;
}
.btn-primary {
  background: var(--accent) !important;
  border-color: transparent !important;
  color: #fff !important;
  font-weight: 600 !important;
  box-shadow: 0 2px 12px var(--accent-glow) !important;
}
.btn-primary:hover {
  background: var(--accent-hover) !important;
  border-color: transparent !important;
  box-shadow: 0 4px 20px var(--accent-glow) !important;
}
.btn-danger {
  background: var(--red-fill) !important;
  border-color: rgba(255,69,58,0.2) !important;
  color: var(--red) !important;
}
.btn-danger:hover {
  background: rgba(255,69,58,0.25) !important;
}
.btn-xs {
  padding: 4px 10px !important;
  font-size: 11.5px !important;
}
.btn-sm {
  padding: 5px 12px !important;
  font-size: 12px !important;
}

/* ── INPUTS ── */
.input {
  width: 100%;
  background: rgba(118,118,128,0.12) !important;
  border: 0.5px solid rgba(255,255,255,0.1) !important;
  border-radius: var(--r6) !important;
  padding: 7px 11px !important;
  font-size: 13px !important;
  color: var(--label) !important;
  outline: none !important;
  font-family: var(--font) !important;
  caret-color: var(--accent) !important;
  transition: border-color 0.15s, box-shadow 0.15s !important;
  box-sizing: border-box !important;
}
.input:focus {
  border-color: rgba(10,132,255,0.5) !important;
  box-shadow: 0 0 0 3px rgba(10,132,255,0.12) !important;
}
.input::placeholder {
  color: var(--quaternary-label) !important;
}

/* ── TOGGLE SWITCH ── */
.toggle {
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
  cursor: pointer !important;
  user-select: none !important;
}
.toggle-track {
  width: 34px !important;
  height: 20px !important;
  border-radius: 10px !important;
  background: rgba(118,118,128,0.28) !important;
  position: relative !important;
  transition: all 0.22s !important;
  flex-shrink: 0 !important;
  border: 0.5px solid rgba(255,255,255,0.1) !important;
}
.toggle-track.on {
  background: var(--green) !important;
  border-color: transparent !important;
  box-shadow: 0 0 8px rgba(48,209,88,0.4) !important;
}
.toggle-track.accent.on {
  background: var(--accent) !important;
  box-shadow: 0 0 8px var(--accent-glow) !important;
}
.toggle-thumb {
  position: absolute !important;
  top: 2px !important;
  left: 2px !important;
  width: 15px !important;
  height: 15px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,0.75) !important;
  transition: transform 0.22s cubic-bezier(0.34,1.56,0.64,1), background 0.22s !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.4) !important;
}
.toggle-track.on .toggle-thumb {
  transform: translateX(14px) !important;
  background: #fff !important;
}
.toggle-lbl {
  font-size: 12.5px !important;
  color: var(--secondary-label) !important;
}

/* ── LIVE CHAT Redesign ── */
.chat-shell {
  display: grid !important;
  grid-template-columns: 256px 1fr 272px !important;
  height: calc(100vh - 52px) !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}
.chat-left {
  border-right: 0.5px solid var(--mac-separator) !important;
  background: rgba(28,28,30,0.65) !important;
  backdrop-filter: blur(40px) !important;
  -webkit-backdrop-filter: blur(40px) !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  height: 100% !important;
}
.chat-search-wrap {
  padding: 10px !important;
  border-bottom: 0.5px solid rgba(255,255,255,0.07) !important;
  box-sizing: border-box !important;
}
.chat-list {
  flex: 1 !important;
  overflow-y: auto !important;
  padding: 4px !important;
}
.chat-list::-webkit-scrollbar {
  display: none !important;
}
.chat-item {
  padding: 10px 10px !important;
  border-radius: var(--r10) !important;
  cursor: pointer !important;
  transition: all 0.13s !important;
  border: 0.5px solid transparent !important;
  margin-bottom: 2px !important;
  display: flex !important;
  gap: 10px !important;
  align-items: flex-start !important;
}
.chat-item:hover {
  background: rgba(118,118,128,0.15) !important;
}
.chat-item.active {
  background: var(--accent-fill) !important;
  border-color: rgba(10,132,255,0.2) !important;
}
.chat-item .chat-avatar {
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  background: var(--accent) !important;
  color: #fff !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  flex-shrink: 0 !important;
}
.chat-item .chat-details {
  flex: 1 !important;
  min-width: 0 !important;
}
.chat-item .chat-details-header {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin-bottom: 2px !important;
}
.chat-item .chat-details-header h4 {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--label) !important;
  margin: 0 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.chat-item .chat-time {
  font-size: 10.5px !important;
  color: var(--quaternary-label) !important;
  font-family: var(--mono) !important;
}
.chat-item .chat-snippet-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 6px !important;
}
.chat-item .chat-snippet {
  font-size: 12px !important;
  color: var(--tertiary-label) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  flex: 1 !important;
}
.ai-badge {
  font-size: 8.5px !important;
  font-weight: 700 !important;
  padding: 1px 5px !important;
  border-radius: 3px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  border: 0.5px solid transparent !important;
  flex-shrink: 0 !important;
}
.ai-badge.active {
  background: var(--accent-fill) !important;
  color: var(--accent) !important;
  border-color: rgba(10,132,255,0.2) !important;
}
.ai-badge.manual {
  background: rgba(118,118,128,0.15) !important;
  color: var(--tertiary-label) !important;
  border-color: rgba(118,118,128,0.2) !important;
}

.chat-center {
  display: flex !important;
  flex-direction: column !important;
  background: rgba(22,22,24,0.7) !important;
  overflow: hidden !important;
  height: 100% !important;
}
.chat-topbar {
  padding: 11px 16px !important;
  border-bottom: 0.5px solid rgba(255,255,255,0.07) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  background: rgba(28,28,30,0.6) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  flex-shrink: 0 !important;
  box-sizing: border-box !important;
}
.ctb-name {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--label) !important;
}
.ctb-meta {
  font-size: 11px !important;
  color: var(--tertiary-label) !important;
  margin-top: 1px !important;
  font-family: var(--mono) !important;
}
.human-banner {
  margin: 10px 14px 0 !important;
  padding: 8px 12px !important;
  background: var(--red-fill) !important;
  border: 0.5px solid rgba(255,69,58,0.25) !important;
  border-radius: var(--r10) !important;
  font-size: 12px !important;
  color: var(--red) !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-shrink: 0 !important;
  box-sizing: border-box !important;
}

.msgs-area {
  flex: 1 !important;
  overflow-y: auto !important;
  padding: 16px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}
.msgs-area::-webkit-scrollbar {
  width: 3px !important;
}
.msgs-area::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.1) !important;
  border-radius: 99px !important;
}

.chat-date-header-row {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin: 4px 0 !important;
}
.chat-date-header-row::before, .chat-date-header-row::after {
  content: '' !important;
  flex: 1 !important;
  height: 0.5px !important;
  background: rgba(255,255,255,0.08) !important;
}
.chat-date-header-badge {
  font-size: 11px !important;
  color: var(--quaternary-label) !important;
}

.message-bubble-row {
  display: flex !important;
  flex-direction: column !important;
}
.message-bubble-row.inbound {
  align-items: flex-start !important;
}
.message-bubble-row.outbound,
.message-bubble-row.outbound_manual,
.message-bubble-row.outbound_reminder {
  align-items: flex-end !important;
}

.message-bubble {
  max-width: 72% !important;
  padding: 9px 13px !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
  word-break: break-word !important;
}
.message-bubble-row.inbound .message-bubble {
  background: rgba(118,118,128,0.2) !important;
  border: 0.5px solid rgba(255,255,255,0.08) !important;
  border-radius: 16px 16px 16px 4px !important;
  color: var(--label) !important;
}
.message-bubble-row.outbound .message-bubble,
.message-bubble-row.outbound_manual .message-bubble,
.message-bubble-row.outbound_reminder .message-bubble {
  background: var(--accent) !important;
  border-radius: 16px 16px 4px 16px !important;
  color: #fff !important;
  box-shadow: 0 4px 16px var(--accent-glow) !important;
}
.message-bubble-row.outbound .message-bubble {
  /* Dynamic MIRA styling if preferred, or standard blue */
}
.message-bubble-row.outbound_manual .message-bubble {
  background: rgba(10,132,255,0.85) !important;
}
.message-bubble-row.outbound_reminder .message-bubble {
  background: rgba(191,90,242,0.22) !important;
  border: 0.5px solid rgba(191,90,242,0.3) !important;
  color: var(--label) !important;
  box-shadow: none !important;
}

.message-meta {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 4px !important;
  font-size: 10px !important;
  color: var(--quaternary-label) !important;
  margin-top: 3px !important;
  font-family: var(--mono) !important;
}
.message-bubble-row.inbound .message-meta {
  justify-content: flex-start !important;
}

.bubble-tag {
  font-size: 8.5px !important;
  font-weight: 700 !important;
  padding: 1px 4px !important;
  border-radius: 3px !important;
  text-transform: uppercase !important;
  margin-right: 4px !important;
}
.bubble-tag.mira {
  background: rgba(255,255,255,0.15) !important;
  color: #fff !important;
}
.bubble-tag.agent {
  background: rgba(255,255,255,0.25) !important;
  color: #fff !important;
}
.bubble-tag.reminder {
  background: rgba(191,90,242,0.2) !important;
  color: var(--purple) !important;
}

.message-status-tick {
  display: inline-flex !important;
  align-items: center !important;
}
.message-status-tick.read {
  color: #5AC8FA !important;
}

.chat-input-bar {
  padding: 11px 14px !important;
  border-top: 0.5px solid rgba(255,255,255,0.07) !important;
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  background: rgba(28,28,30,0.5) !important;
  flex-shrink: 0 !important;
  box-sizing: border-box !important;
}
.chat-input-bar input {
  flex: 1 !important;
  background: rgba(118,118,128,0.16) !important;
  border: 0.5px solid rgba(255,255,255,0.1) !important;
  border-radius: 22px !important;
  padding: 8px 15px !important;
  font-size: 13px !important;
  color: var(--label) !important;
  outline: none !important;
  font-family: var(--font) !important;
  caret-color: var(--accent) !important;
  transition: border-color 0.15s !important;
}
.chat-input-bar input:focus {
  border-color: rgba(10,132,255,0.45) !important;
}

.chat-right {
  border-left: 0.5px solid var(--mac-separator) !important;
  background: rgba(28,28,30,0.6) !important;
  backdrop-filter: blur(40px) !important;
  -webkit-backdrop-filter: blur(40px) !important;
  overflow-y: auto !important;
  padding: 16px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  height: 100% !important;
  box-sizing: border-box !important;
}
.chat-right::-webkit-scrollbar {
  display: none !important;
}
.cir-title {
  font-size: 10.5px !important;
  font-weight: 700 !important;
  color: var(--tertiary-label) !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
  margin-bottom: 9px !important;
  padding-bottom: 7px !important;
  border-bottom: 0.5px solid rgba(255,255,255,0.07) !important;
}
.stat-pair {
  display: flex !important;
  justify-content: space-between !important;
  font-size: 12.5px !important;
  margin-bottom: 8px !important;
}
.stat-pair .stat-key {
  color: var(--secondary-label) !important;
}
.stat-pair .stat-val {
  font-family: var(--mono) !important;
  font-weight: 500 !important;
  color: var(--label) !important;
}

.fdot {
  width: 18px !important;
  height: 18px !important;
  border-radius: 50% !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 10.5px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
}
.fdot.filed {
  background: var(--green-fill) !important;
  color: var(--green) !important;
}
.fdot.pending {
  background: var(--orange-fill) !important;
  color: var(--orange) !important;
}
.fdot.na {
  background: rgba(118,118,128,0.15) !important;
  color: var(--tertiary-label) !important;
}

/* ── TAB BAR ── */
.tab-bar {
  display: flex !important;
  gap: 2px !important;
  background: rgba(118,118,128,0.14) !important;
  border: 0.5px solid rgba(255,255,255,0.09) !important;
  border-radius: var(--r10) !important;
  padding: 3px !important;
  margin-bottom: 16px !important;
  width: fit-content !important;
  box-sizing: border-box !important;
}
.tab-btn {
  padding: 5px 14px !important;
  border-radius: 7px !important;
  font-size: 12.5px !important;
  cursor: pointer !important;
  border: 0.5px solid transparent !important;
  background: none !important;
  color: var(--secondary-label) !important;
  transition: all 0.13s !important;
  font-family: var(--font) !important;
}
.tab-btn:hover {
  color: var(--label) !important;
  background: rgba(255,255,255,0.03) !important;
}
.tab-btn.active {
  background: rgba(255,255,255,0.1) !important;
  border-color: rgba(255,255,255,0.05) !important;
  color: var(--label) !important;
  font-weight: 500 !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.15) !important;
}

/* Override .chat-wrapper layout grids */
.chat-wrapper {
  display: grid !important;
  grid-template-columns: 256px 1fr 272px !important;
  height: calc(100vh - 52px) !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
}
.chat-sidebar {
  border-right: 0.5px solid var(--mac-separator) !important;
  background: rgba(28,28,30,0.65) !important;
  backdrop-filter: blur(40px) !important;
  -webkit-backdrop-filter: blur(40px) !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  height: 100% !important;
}
.sidebar-search {
  padding: 10px !important;
  border-bottom: 0.5px solid rgba(255,255,255,0.07) !important;
  box-sizing: border-box !important;
}
.sidebar-search input {
  padding: 7px 11px 7px 30px !important;
  border-radius: var(--r6) !important;
  border: 0.5px solid rgba(255,255,255,0.1) !important;
  background: rgba(118,118,128,0.12) !important;
  color: var(--label) !important;
  font-size: 13px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.sidebar-search .search-icon {
  left: 20px !important;
  font-size: 14px !important;
}
.chat-main {
  display: flex !important;
  flex-direction: column !important;
  background: rgba(22,22,24,0.7) !important;
  overflow: hidden !important;
  height: 100% !important;
}
.chat-header {
  padding: 11px 16px !important;
  border-bottom: 0.5px solid rgba(255,255,255,0.07) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  background: rgba(28,28,30,0.6) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  flex-shrink: 0 !important;
  box-sizing: border-box !important;
}
.chat-header h3 {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--label) !important;
  margin: 0 !important;
}
.chat-messages {
  flex: 1 !important;
  overflow-y: auto !important;
  padding: 16px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}
.chat-messages::-webkit-scrollbar {
  width: 3px !important;
}
.chat-messages::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.1) !important;
  border-radius: 99px !important;
}
.chat-footer {
  padding: 11px 14px !important;
  border-top: 0.5px solid rgba(255,255,255,0.07) !important;
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  background: rgba(28,28,30,0.5) !important;
  flex-shrink: 0 !important;
  box-sizing: border-box !important;
}
.chat-footer textarea {
  flex: 1 !important;
  background: rgba(118,118,128,0.16) !important;
  border: 0.5px solid rgba(255,255,255,0.1) !important;
  border-radius: 20px !important;
  padding: 8px 15px !important;
  font-size: 13px !important;
  color: var(--label) !important;
  outline: none !important;
  font-family: var(--font) !important;
  caret-color: var(--accent) !important;
  height: 36px !important;
  min-height: 36px !important;
  max-height: 100px !important;
  resize: none !important;
  box-sizing: border-box !important;
}
.chat-footer textarea:focus {
  border-color: rgba(10,132,255,0.45) !important;
}
.send-message-btn {
  width: 30px !important;
  height: 30px !important;
  border-radius: 50% !important;
  background: var(--accent) !important;
  color: #fff !important;
  border: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  font-size: 14px !important;
  transition: all var(--transition) !important;
  flex-shrink: 0 !important;
}
.send-message-btn:hover {
  background: var(--accent-hover) !important;
}
.chat-info-panel {
  border-left: 0.5px solid var(--mac-separator) !important;
  background: rgba(28,28,30,0.6) !important;
  backdrop-filter: blur(40px) !important;
  -webkit-backdrop-filter: blur(40px) !important;
  overflow-y: auto !important;
  padding: 16px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  height: 100% !important;
  box-sizing: border-box !important;
}
.chat-info-panel::-webkit-scrollbar {
  display: none !important;
}
.chat-info-panel h3 {
  font-size: 10.5px !important;
  font-weight: 700 !important;
  color: var(--tertiary-label) !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
  margin: 0 0 9px 0 !important;
  padding-bottom: 7px !important;
  border-bottom: 0.5px solid rgba(255,255,255,0.07) !important;
}
.info-group {
  display: flex !important;
  justify-content: space-between !important;
  font-size: 12.5px !important;
  margin-bottom: 8px !important;
}
.info-group label {
  color: var(--secondary-label) !important;
}
.info-group span {
  font-family: var(--mono) !important;
  font-weight: 500 !important;
  color: var(--label) !important;
}
.financial-snippet .fin-row {
  display: flex !important;
  justify-content: space-between !important;
  font-size: 12.5px !important;
  margin-bottom: 8px !important;
}
.financial-snippet .fin-row span {
  color: var(--secondary-label) !important;
}
.compliance-snippet .comp-item {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  font-size: 12px !important;
  margin-bottom: 6px !important;
}
.compliance-snippet .comp-item .comp-name {
  color: var(--secondary-label) !important;
}

/* ── REMINDER ENGINE ── */
.engine-status {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 13px 16px !important;
  border-radius: var(--r10) !important;
  margin-bottom: 14px !important;
  background: rgba(48,209,88,0.1) !important;
  border: 0.5px solid rgba(48,209,88,0.2) !important;
  box-sizing: border-box !important;
}
.engine-status.off {
  background: rgba(118,118,128,0.1) !important;
  border-color: rgba(118,118,128,0.15) !important;
}
.engine-icon {
  font-size: 22px !important;
}
.engine-name {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--label) !important;
}
.engine-meta {
  font-size: 11px !important;
  color: var(--tertiary-label) !important;
  margin-top: 1px !important;
}

.rule-row {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 10px 13px !important;
  border-radius: var(--r10) !important;
  background: rgba(255,255,255,0.03) !important;
  border: 0.5px solid rgba(255,255,255,0.07) !important;
  transition: border-color 0.12s !important;
  margin-bottom: 6px !important;
  box-sizing: border-box !important;
}
.rule-row:hover {
  border-color: rgba(255,255,255,0.12) !important;
}
.rule-tag {
  font-family: var(--mono) !important;
  font-size: 10.5px !important;
  font-weight: 700 !important;
  padding: 3px 8px !important;
  border-radius: 5px !important;
  width: 58px !important;
  text-align: center !important;
  flex-shrink: 0 !important;
}
.rule-tag.pre {
  background: var(--accent-fill) !important;
  color: var(--accent) !important;
}
.rule-tag.today {
  background: var(--green-fill) !important;
  color: var(--green) !important;
}
.rule-tag.over {
  background: var(--orange-fill) !important;
  color: var(--orange) !important;
}
.rule-tag.crit {
  background: var(--red-fill) !important;
  color: var(--red) !important;
}
.rule-name {
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--label) !important;
}
.rule-desc {
  font-size: 11px !important;
  color: var(--tertiary-label) !important;
  margin-top: 1px !important;
}
.rule-tmpl {
  font-size: 10.5px !important;
  padding: 2px 7px !important;
  border-radius: 5px !important;
  background: var(--purple-fill) !important;
  color: var(--purple) !important;
  border: 0.5px solid rgba(191,90,242,0.2) !important;
  margin-left: auto !important;
  flex-shrink: 0 !important;
  font-weight: 600 !important;
}

.log-stream {
  background: rgba(0,0,0,0.4) !important;
  border: 0.5px solid rgba(255,255,255,0.08) !important;
  border-radius: var(--r10) !important;
  padding: 12px 14px !important;
  font-family: var(--mono) !important;
  font-size: 11.5px !important;
  height: 170px !important;
  overflow-y: auto !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
  box-sizing: border-box !important;
}
.log-stream::-webkit-scrollbar {
  width: 3px !important;
}
.log-stream::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.1) !important;
}
.ll {
  display: flex !important;
  gap: 10px !important;
}
.lt {
  color: var(--quaternary-label) !important;
  flex-shrink: 0 !important;
}
.lm {
  color: var(--secondary-label) !important;
}
.lm.ok { color: var(--green) !important; }
.lm.err { color: var(--red) !important; }
.lm.wrn { color: var(--orange) !important; }
.lm.inf { color: var(--accent) !important; }

/* Native Checkbox Styled as macOS Sequoia Toggle Switch */
input[type="checkbox"].mac-switch {
  appearance: none !important;
  -webkit-appearance: none !important;
  width: 36px !important;
  height: 20px !important;
  background: rgba(120, 120, 128, 0.28) !important;
  border-radius: 10px !important;
  position: relative !important;
  outline: none !important;
  cursor: pointer !important;
  transition: background 0.22s, box-shadow 0.22s !important;
  border: 0.5px solid rgba(255, 255, 255, 0.1) !important;
  flex-shrink: 0 !important;
  box-sizing: border-box !important;
  margin: 0 !important;
}
input[type="checkbox"].mac-switch:checked {
  background: var(--green) !important;
  border-color: transparent !important;
  box-shadow: 0 0 8px rgba(48,209,88,0.4) !important;
}
input[type="checkbox"].mac-switch.accent:checked {
  background: var(--accent) !important;
  box-shadow: 0 0 8px var(--accent-glow) !important;
}
input[type="checkbox"].mac-switch::after {
  content: '' !important;
  position: absolute !important;
  top: 1.5px !important;
  left: 2px !important;
  width: 15px !important;
  height: 15px !important;
  border-radius: 50% !important;
  background: #fff !important;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.4) !important;
  transition: transform 0.22s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}
input[type="checkbox"].mac-switch:checked::after {
  transform: translateX(16px) !important;
}

/* Live Chat Message Delete Button */
.message-bubble {
  position: relative !important;
}
.delete-msg-btn {
  position: absolute !important;
  top: -6px !important;
  right: -6px !important;
  background: var(--red) !important;
  color: #ffffff !important;
  border: 0.5px solid rgba(255,255,255,0.15) !important;
  border-radius: 50% !important;
  width: 18px !important;
  height: 18px !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  font-size: 10px !important;
  box-shadow: 0 2px 6px rgba(0,0,0,0.3) !important;
  z-index: 100 !important;
  transition: transform 0.1s ease !important;
}
.delete-msg-btn:hover {
  transform: scale(1.15) !important;
}
.message-bubble:hover .delete-msg-btn {
  display: flex !important;
}

