/* =================================================================
   Cloudspire Admin — Atmospheric Precision Theme
   Bootstrap 5.3.3 override layer. data-bs-theme="dark|light" switching.
   Brand: purple #7c3aed → blue #2563eb → cyan #06b6d4
   Aesthetic: glassmorphic surfaces, aurora ambient depth, precise motion
   ================================================================= */

/* ── Shared brand tokens ────────────────────────────────────────── */
:root {
  --onc-purple:       #6366f1;
  --onc-purple-hover: #818cf8;
  --onc-blue:         #2563eb;
  --onc-blue-light:   #60a5fa;
  --onc-cyan:         #06b6d4;
  --onc-cyan-light:   #22d3ee;
  --onc-green:        #22c55e;
  --onc-red:          #ef4444;
  --onc-yellow:       #eab308;
  --onc-neon:         #94d60a;
  --onc-gradient:     linear-gradient(135deg, #7c3aed 0%, #2563eb 50%, #06b6d4 100%);
  --onc-gradient-text: linear-gradient(135deg, #a78bfa 0%, #60a5fa 50%, #22d3ee 100%);

  /* Motion — cloudspire.ai signature easing */
  --onc-ease:         cubic-bezier(0.16, 1, 0.3, 1);
  --onc-duration:     0.3s;
  --onc-transition:   0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

/* ── Dark palette ────────────────────────────────────────────────── */
[data-bs-theme="dark"] {
  /* Surface tiers — deep navy, matching cloudspire.ai */
  --onc-bg:        #08081a;
  --onc-surface:   #111128;
  --onc-raised:    #1a1a38;
  --onc-border:    rgba(129, 140, 248,0.20);
  --onc-border-lt: rgba(99, 102, 241, 0.32);

  /* Glass surface — translucent with blur */
  --onc-glass:     rgba(17, 17, 40, 0.70);
  --onc-glass-border: rgba(129, 140, 248,0.14);

  /* Text tiers */
  --onc-text:      #d1d5db;
  --onc-heading:   #f1f3f8;
  --onc-muted:     #7b8a9e;

  /* Links */
  --onc-link-color: #22d3ee;
  --onc-link-hover: #67e8f9;

  /* Semantic text */
  --onc-text-success: #4ade80;
  --onc-text-danger:  #fca5a5;
  --onc-text-warning: #facc15;
  --onc-text-info:    #67e8f9;

  /* Alerts — glass-like with soft backdrop */
  --onc-alert-success-bg:     rgba(34,197,94,.10);
  --onc-alert-success-border: rgba(34,197,94,.25);
  --onc-alert-success-text:   #4ade80;
  --onc-alert-danger-bg:      rgba(239,68,68,.10);
  --onc-alert-danger-border:  rgba(239,68,68,.25);
  --onc-alert-danger-text:    #fca5a5;
  --onc-alert-warning-bg:     rgba(234,179,8,.08);
  --onc-alert-warning-border: rgba(234,179,8,.25);
  --onc-alert-warning-text:   #facc15;
  --onc-alert-avg-bg:         rgba(249,115,22,.10);
  --onc-alert-avg-border:     rgba(249,115,22,.25);
  --onc-alert-avg-text:       #fb923c;
  --onc-alert-info-bg:        rgba(34,211,238,.07);
  --onc-alert-info-border:    rgba(34,211,238,.22);
  --onc-alert-info-text:      #67e8f9;

  /* Buttons */
  --onc-btn-primary-bg:     rgba(37,99,235,.30);
  --onc-btn-primary-hover:  rgba(37,99,235,.50);
  --onc-btn-primary-active: rgba(37,99,235,.65);
  --onc-btn-primary-text:   #fff;
  --onc-btn-danger-bg:      rgba(239,68,68,.25);
  --onc-btn-danger-hover:   rgba(239,68,68,.45);
  --onc-btn-danger-active:  rgba(239,68,68,.60);
  --onc-btn-danger-text:    #fff;
  --onc-btn-secondary-bg:   rgba(37,99,235,.10);
  --onc-btn-secondary-hover:rgba(37,99,235,.22);
  --onc-btn-secondary-text: #c8cdd5;
  --onc-btn-secondary-hover-text: #f1f3f8;

  /* Tables */
  --onc-table-head-bg:     rgba(99,102,241,.14);
  --onc-table-head-border: rgba(99,102,241,.25);
  --onc-table-head-text:   #e2e6ed;
  --onc-table-stripe:      rgba(255,255,255,.05);
  --onc-table-even:        rgba(255,255,255,.04);
  --onc-table-hover:       rgba(99,102,241,.10);

  /* Contextual table rows */
  --onc-table-danger-bg:   rgba(239,68,68,.10);
  --onc-table-danger-text: #fca5a5;
  --onc-table-success-bg:  rgba(34,197,94,.08);
  --onc-table-success-text:#86efac;
  --onc-table-warning-bg:  rgba(234,179,8,.08);
  --onc-table-warning-text:#fde047;
  --onc-table-info-bg:     rgba(34,211,238,.06);
  --onc-table-info-text:   #67e8f9;

  /* Tabs */
  --onc-tab-active-bg: rgba(37,99,235,.35);
  --onc-tab-active-text: #fff;

  /* Misc */
  --onc-dropdown-shadow: 0 8px 32px rgba(0,0,0,.55), 0 0 0 1px rgba(129,140,248,.08);
  --onc-btn-close-filter: invert(1) grayscale(100%) brightness(200%);
  --onc-logo-filter: drop-shadow(0 1px 4px rgba(99,102,241,.20));
  --onc-mark-bg: rgba(234,179,8,0.22);
  --onc-home-hover-bg: rgba(99,102,241,.25);
  --onc-header-text: #e5e7eb;
  --onc-header-muted: #94a3b8;
  --onc-header-border: rgba(255,255,255,.15);

  /* Card elevation */
  --onc-card-shadow: 0 1px 3px rgba(0,0,0,.25), 0 4px 16px rgba(0,0,0,.15);
  --onc-card-hover-shadow: 0 8px 32px rgba(0,0,0,.35), 0 0 48px rgba(99,102,241,.06);

  /* Match indicator (billing DID maint) */
  --onc-match-neutral-bg:  #161630;
  --onc-match-neutral-text:#94a3b8;
  --onc-match-warning-bg:  rgba(234,179,8,.15);
  --onc-match-warning-text:#facc15;
  --onc-match-success-bg:  rgba(34,197,94,.15);
  --onc-match-success-text:#4ade80;
  --onc-match-danger-bg:   rgba(239,68,68,.15);
  --onc-match-danger-text: #fca5a5;

  /* Bootstrap overrides */
  --bs-body-color:      #d1d5db;
  --bs-body-bg:         #08081a;
  --bs-emphasis-color:  #f1f3f8;
  --bs-secondary-color: #7b8a9e;
  --bs-tertiary-color:  #56657a;
  --bs-secondary-bg:    #111128;
  --bs-tertiary-bg:     #1a1a38;
  --bs-heading-color:   #f1f3f8;
  --bs-link-color:      #22d3ee;
  --bs-link-hover-color:#67e8f9;
  --bs-border-color:    rgba(129, 140, 248,0.12);
  --bs-border-color-translucent: rgba(255,255,255,0.04);
  --bs-code-color:      #22d3ee;
}

/* ── Light palette ───────────────────────────────────────────────── */
[data-bs-theme="light"] {
  /* Surface tiers — clean, warm white */
  --onc-bg:        #f4f2f7;
  --onc-surface:   #ffffff;
  --onc-raised:    #eee8f8;
  --onc-border:    rgba(99, 102, 241,0.14);
  --onc-border-lt: rgba(99, 102, 241,0.25);

  /* Glass surface */
  --onc-glass:     rgba(255, 255, 255, 0.72);
  --onc-glass-border: rgba(99, 102, 241,0.10);

  /* Text tiers */
  --onc-text:      #3e4559;
  --onc-heading:   #111827;
  --onc-muted:     #6b7280;

  /* Links — purple on light */
  --onc-link-color: #6366f1;
  --onc-link-hover: #4f46e5;

  /* Semantic text */
  --onc-text-success: #16a34a;
  --onc-text-danger:  #dc2626;
  --onc-text-warning: #ca8a04;
  --onc-text-info:    #0891b2;

  /* Alerts */
  --onc-alert-success-bg:     rgba(34,197,94,.08);
  --onc-alert-success-border: rgba(34,197,94,.22);
  --onc-alert-success-text:   #15803d;
  --onc-alert-danger-bg:      rgba(239,68,68,.06);
  --onc-alert-danger-border:  rgba(239,68,68,.22);
  --onc-alert-danger-text:    #dc2626;
  --onc-alert-warning-bg:     rgba(234,179,8,.08);
  --onc-alert-warning-border: rgba(234,179,8,.22);
  --onc-alert-warning-text:   #a16207;
  --onc-alert-avg-bg:         rgba(249,115,22,.08);
  --onc-alert-avg-border:     rgba(249,115,22,.22);
  --onc-alert-avg-text:       #c2410c;
  --onc-alert-info-bg:        rgba(34,211,238,.06);
  --onc-alert-info-border:    rgba(34,211,238,.18);
  --onc-alert-info-text:      #0e7490;

  /* Buttons */
  --onc-btn-primary-bg:     #2563eb;
  --onc-btn-primary-hover:  #1d4ed8;
  --onc-btn-primary-active: #1e40af;
  --onc-btn-primary-text:   #fff;
  --onc-btn-danger-bg:      #dc2626;
  --onc-btn-danger-hover:   #ef4444;
  --onc-btn-danger-active:  #b91c1c;
  --onc-btn-danger-text:    #fff;
  --onc-btn-secondary-bg:   rgba(37,99,235,.06);
  --onc-btn-secondary-hover:rgba(37,99,235,.12);
  --onc-btn-secondary-text: #3e4559;
  --onc-btn-secondary-hover-text: #111827;

  /* Tables */
  --onc-table-head-bg:     rgba(99,102,241,.06);
  --onc-table-head-border: rgba(99,102,241,.14);
  --onc-table-head-text:   #111827;
  --onc-table-stripe:      rgba(0,0,0,.035);
  --onc-table-even:        rgba(99,102,241,.04);
  --onc-table-hover:       rgba(99,102,241,.07);

  /* Contextual table rows */
  --onc-table-danger-bg:   rgba(239,68,68,.06);
  --onc-table-danger-text: #dc2626;
  --onc-table-success-bg:  rgba(34,197,94,.06);
  --onc-table-success-text:#15803d;
  --onc-table-warning-bg:  rgba(234,179,8,.06);
  --onc-table-warning-text:#a16207;
  --onc-table-info-bg:     rgba(34,211,238,.05);
  --onc-table-info-text:   #0e7490;

  /* Tabs */
  --onc-tab-active-bg: rgba(37,99,235,.18);
  --onc-tab-active-text: #111827;

  /* Misc */
  --onc-dropdown-shadow: 0 8px 32px rgba(0,0,0,.08), 0 0 0 1px rgba(99,102,241,.06);
  --onc-btn-close-filter: none;
  --onc-logo-filter: drop-shadow(0 1px 3px rgba(0,0,0,.10));
  --onc-mark-bg: rgba(234,179,8,0.18);
  --onc-home-hover-bg: rgba(99,102,241,.08);
  --onc-header-text: #fff;
  --onc-header-muted: rgba(255,255,255,.7);
  --onc-header-border: rgba(255,255,255,.25);

  /* Card elevation */
  --onc-card-shadow: 0 1px 3px rgba(0,0,0,.04), 0 4px 16px rgba(99,102,241,.03);
  --onc-card-hover-shadow: 0 8px 32px rgba(99,102,241,.08), 0 2px 8px rgba(0,0,0,.05);

  /* Match indicator (billing DID maint) */
  --onc-match-neutral-bg:  #f1f5f9;
  --onc-match-neutral-text:#64748b;
  --onc-match-warning-bg:  rgba(234,179,8,.10);
  --onc-match-warning-text:#a16207;
  --onc-match-success-bg:  rgba(34,197,94,.10);
  --onc-match-success-text:#15803d;
  --onc-match-danger-bg:   rgba(239,68,68,.08);
  --onc-match-danger-text: #dc2626;

  /* Bootstrap overrides */
  --bs-body-color:      #3e4559;
  --bs-body-bg:         #f4f2f7;
  --bs-emphasis-color:  #111827;
  --bs-secondary-color: #6b7280;
  --bs-tertiary-color:  #9ca3af;
  --bs-secondary-bg:    #ffffff;
  --bs-tertiary-bg:     #eee8f8;
  --bs-heading-color:   #111827;
  --bs-link-color:      #6366f1;
  --bs-link-hover-color:#4f46e5;
  --bs-border-color:    rgba(99, 102, 241,0.12);
  --bs-border-color-translucent: rgba(0,0,0,0.05);
  --bs-code-color:      #6366f1;
}

/* ── Theme transition ───────────────────────────────────────────── */
html[data-bs-theme] body,
html[data-bs-theme] .card,
html[data-bs-theme] .card-header,
html[data-bs-theme] .card-body,
html[data-bs-theme] .table,
html[data-bs-theme] .modal-content,
html[data-bs-theme] .form-control,
html[data-bs-theme] .form-select,
html[data-bs-theme] .nav-tabs .nav-link,
html[data-bs-theme] .alert,
html[data-bs-theme] .dropdown-menu {
  transition: background-color 0.35s ease, color 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

/* ── Base ────────────────────────────────────────────────────────── */
body {
  background: var(--onc-bg);
  color: var(--onc-text);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  min-height: 100vh;
  overflow-x: hidden;
}

/* Ambient aurora — very subtle atmospheric depth (dark only) */
[data-bs-theme="dark"] body::before,
[data-bs-theme="dark"] body::after {
  content: '';
  position: fixed;
  pointer-events: none;
  z-index: 0;
  border-radius: 50%;
  filter: blur(120px);
}
[data-bs-theme="dark"] body::before {
  width: 600px;
  height: 600px;
  top: -8%;
  left: -5%;
  background: radial-gradient(ellipse at center, rgba(99,102,241,.08) 0%, transparent 70%);
}
[data-bs-theme="dark"] body::after {
  width: 500px;
  height: 500px;
  bottom: -5%;
  right: -5%;
  background: radial-gradient(ellipse at center, rgba(6,182,212,.05) 0%, transparent 70%);
}

/* Light mode — soft purple wash in background */
[data-bs-theme="light"] body::before {
  content: '';
  position: fixed;
  pointer-events: none;
  z-index: 0;
  top: -10%;
  right: -10%;
  width: 700px;
  height: 700px;
  border-radius: 50%;
  filter: blur(120px);
  background: radial-gradient(ellipse at center, rgba(99,102,241,.04) 0%, transparent 70%);
}

/* Content above aurora layer */
.onc-header {
  position: relative;
  z-index: 10;
}
.container {
  position: relative;
  z-index: 1;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  color: var(--onc-heading);
  letter-spacing: -0.01em;
}

p, li, label, span, div, td, th, small, em, legend, figcaption, dt, dd {
  color: inherit;
}
strong, b, .fw-semibold, .fw-bold { color: var(--onc-heading); }

a {
  color: var(--onc-link-color);
  transition: color var(--onc-transition);
}
a:hover { color: var(--onc-link-hover); }

pre {
  color: var(--onc-text);
  background: var(--onc-surface);
  border: 1px solid var(--onc-border);
  border-radius: 8px;
  padding: 0.75rem;
}
code  { color: var(--onc-link-color); }
mark  { background: var(--onc-mark-bg); color: var(--onc-heading); }
hr    { border-color: var(--onc-border); opacity: 1; }

::selection {
  background: rgba(99, 102, 241,0.35);
  color: #fff;
}
[data-bs-theme="light"] ::selection {
  background: rgba(99, 102, 241,0.20);
  color: #111827;
}

/* ── Brand Header Bar ────────────────────────────────────────────── */
.onc-header {
  padding: 0.6rem 0;
  background: rgba(5, 5, 16, 0.92);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid rgba(129, 140, 248,0.12);
  box-shadow: 0 1px 0 0 rgba(99,102,241,.08), 0 4px 24px rgba(0,0,0,.25);
}
/* Gradient accent line at the very top of header */
.onc-header::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--onc-gradient);
  z-index: 1;
}
[data-bs-theme="light"] .onc-header {
  background: linear-gradient(135deg, rgba(99,102,241,.92) 0%, rgba(37,99,235,.92) 50%, rgba(6,182,212,.92) 100%);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 4px 24px rgba(99,102,241,.15);
}
[data-bs-theme="light"] .onc-header::before {
  background: rgba(255,255,255,.15);
}
.onc-logo {
  height: 44px;
  filter: var(--onc-logo-filter);
  transition: filter var(--onc-transition);
}
/* Theme-aware logo switching (general pages) */
.onc-logo-dark  { display: inline-block; }
.onc-logo-light { display: none; }
.onc-logo-white { display: none; }
[data-bs-theme="light"] .onc-logo-dark  { display: none; }
[data-bs-theme="light"] .onc-logo-light { display: inline-block; }
/* Header: dark theme = gradient logo on black, light theme = white logo on gradient bg */
.onc-header .onc-logo-light { display: none !important; }
.onc-header .onc-logo-white { display: none !important; }
.onc-header .onc-logo-dark  { display: inline-block !important; }
[data-bs-theme="light"] .onc-header .onc-logo-dark  { display: none !important; }
[data-bs-theme="light"] .onc-header .onc-logo-white { display: inline-block !important; }

.onc-divider {
  width: 1px;
  height: 28px;
  background: var(--onc-header-border);
}
.onc-title {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--onc-header-text);
  letter-spacing: .08em;
  text-transform: uppercase;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Contextual help button (next to page title) ─────────────────── */
.onc-help-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  color: var(--onc-header-text);
  text-decoration: none;
  font-family: inherit;
  font-size: .65rem;
  font-weight: 500;
  letter-spacing: .04em;
  text-transform: uppercase;
  opacity: .55;
  padding: 3px 8px;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 10px;
  background: none;
  cursor: pointer;
  transition: all var(--onc-transition);
  flex-shrink: 0;
  white-space: nowrap;
}
.onc-help-link:hover {
  opacity: 1;
  color: #fff;
  border-color: rgba(255,255,255,.4);
  background: rgba(255,255,255,.1);
  transform: translateY(-1px);
}
.onc-help-link svg {
  width: 13px;
  height: 13px;
}

.onc-tagline {
  font-size: .68rem;
  font-weight: 400;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--onc-header-muted);
}
.onc-home-link {
  font-size: .72rem;
  color: var(--onc-header-text);
  text-decoration: none;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: .3rem .75rem;
  border: 1px solid var(--onc-header-border);
  border-radius: 6px;
  transition: all var(--onc-transition);
  font-weight: 500;
}
.onc-home-link:hover {
  color: #fff;
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.4);
  transform: translateY(-1px);
}

/* ── Header Meta (site badge left, version/user stacked right) ─── */
.onc-header-meta { align-items: center; gap: .5rem; }
.onc-header-meta-stack { display: flex; flex-direction: column; align-items: center; line-height: 1.3; }
.onc-header-meta-user { font-size: .55rem; color: var(--onc-header-text); opacity: .45; white-space: nowrap; }

/* ── Site Badge (header) ────────────────────────────────────────── */
.onc-site-badge { font-size: .6rem; background: transparent; }

/* ── Version Badge ──────────────────────────────────────────────── */
.onc-version-badge {
  font-size: .65rem;
  color: var(--onc-header-text);
  text-decoration: none;
  letter-spacing: .04em;
  opacity: .6;
  padding: 2px 6px;
  border: 1px solid transparent;
  border-radius: 10px;
  transition: var(--onc-transition);
  white-space: nowrap;
}
.onc-version-badge:hover {
  opacity: 1;
  color: #fff;
  border-color: rgba(255,255,255,.3);
  background: rgba(255,255,255,.08);
}

/* ── Theme Toggle Button ────────────────────────────────────────── */
.onc-theme-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  font-size: 1.1rem;
  line-height: 1;
  background: transparent;
  border: 1px solid var(--onc-border);
  border-radius: 8px;
  color: var(--onc-text);
  cursor: pointer;
  transition: all var(--onc-transition);
  padding: 0;
}
.onc-theme-btn:hover {
  color: var(--onc-heading);
  background: var(--onc-raised);
  border-color: var(--onc-border-lt);
  transform: rotate(30deg);
}
/* Override when inside the header bar */
.onc-header .onc-theme-btn {
  border-color: var(--onc-header-border);
  color: var(--onc-header-text);
}
.onc-header .onc-theme-btn:hover {
  color: #fff;
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.4);
  transform: rotate(30deg);
}

/* ── Mobile header ─────────────────────────────────────────────── */
/* ── Mobile tab select (replaces nav-tabs on small screens) ──────── */
.onc-mobile-tab-select {
  font-weight: 500;
  border-color: var(--onc-border-lt);
  background-color: var(--onc-surface);
  color: var(--onc-text);
}
.onc-mobile-tab-select:focus {
  border-color: var(--onc-purple);
  box-shadow: 0 0 0 2px rgba(99,102,241,.25);
}

/* ── Mobile menu button + offcanvas nav ───────────────────────────── */
.onc-mobile-menu-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  font-size: 1.2rem;
  background: transparent;
  border: 1px solid var(--onc-header-border);
  border-radius: 8px;
  color: var(--onc-header-text);
  cursor: pointer;
  transition: var(--onc-transition);
  padding: 0;
  line-height: 1;
}
.onc-mobile-menu-btn:hover {
  color: #fff;
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.4);
}
.onc-mobile-nav {
  --bs-offcanvas-width: 260px;
}
.onc-mobile-nav .offcanvas-header {
  border-bottom: 1px solid var(--onc-border);
}
.onc-mobile-link {
  color: var(--onc-text);
  font-size: .95rem;
  padding: .5rem .75rem;
  border-radius: 6px;
  transition: var(--onc-transition);
}
.onc-mobile-link:hover {
  color: var(--onc-heading);
  background: var(--onc-raised);
}
.onc-mobile-link.active {
  color: var(--onc-purple);
  font-weight: 600;
  background: rgba(99,102,241,.08);
}

@media (max-width: 767.98px) {
  .onc-header .container-fluid {
    padding-left: .75rem;
    padding-right: .75rem;
  }
  .onc-header .container-fluid > div:first-child {
    min-width: 0;
    flex: 1 1 0;
    overflow: hidden;
    gap: .5rem !important;
  }
  .onc-header .container-fluid > div:last-child {
    flex-shrink: 0;
    gap: .4rem !important;
  }
  .onc-logo { height: 28px; }
  .onc-divider { height: 20px; }
  .onc-title { display: none; }
  .onc-help-link { display: none; }
  .onc-header .container-fluid > div:first-child > .onc-divider { display: none; }
  .onc-home-link { display: none; }
  .onc-theme-btn { width: 28px; height: 28px; font-size: .95rem; }
  .onc-header-tenant-select { max-width: 140px; font-size: .78rem; }

  /* ── Sticky Actions column on mobile ──────────────────────────── */
  .table-responsive th:last-child,
  .table-responsive td:last-child {
    position: sticky;
    right: 0;
    z-index: 2;
    background: var(--onc-surface) !important;
    box-shadow: -3px 0 6px rgba(0,0,0,.1);
  }
  .table-responsive thead th:last-child {
    background: var(--onc-raised) !important;
    z-index: 3;
  }
  .table-responsive .table-striped > tbody > tr:nth-of-type(odd) > td:last-child {
    background: var(--onc-raised) !important;
  }
}

/* ── Content area — fluid on mobile, capped on large desktops ────── */
.onc-content {
  max-width: 1600px;
  margin-left: auto;
  margin-right: auto;
}

/* ── Cards — glassmorphic surfaces ───────────────────────────────── */
.card {
  background: var(--onc-glass);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--onc-glass-border);
  border-radius: 12px;
  color: var(--onc-text);
  box-shadow: var(--onc-card-shadow);
  transition: transform var(--onc-transition), box-shadow var(--onc-transition), border-color var(--onc-transition);
  overflow: hidden;
  position: relative;
}
/* Gradient border shimmer overlay */
.card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(99,102,241,.12) 0%, transparent 40%, transparent 60%, rgba(6,182,212,.10) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--onc-transition);
}
.card:hover::before {
  opacity: 1;
}
[data-bs-theme="light"] .card {
  background: var(--onc-glass);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
[data-bs-theme="light"] .card::before {
  background: linear-gradient(135deg, rgba(99,102,241,.06) 0%, transparent 40%, transparent 60%, rgba(6,182,212,.05) 100%);
}
.card-body {
  background: transparent;
  color: var(--onc-text);
}
.card-header {
  background: rgba(99, 102, 241,0.14);
  border-bottom: 1px solid rgba(99, 102, 241,0.22);
  color: var(--onc-heading);
  font-weight: 600;
  font-size: 0.9rem;
  letter-spacing: 0.02em;
}
[data-bs-theme="light"] .card-header {
  background: rgba(99, 102, 241,0.12);
  border-bottom: 1px solid rgba(99, 102, 241,0.20);
  box-shadow: 0 1px 0 rgba(99, 102, 241,0.06);
}
.card-header-accent {
  background: rgba(99, 102, 241,0.22);
  border-bottom: 1px solid rgba(99, 102, 241,0.30);
}
[data-bs-theme="light"] .card-header-accent {
  background: rgba(99, 102, 241,0.16);
  border-bottom: 1px solid rgba(99, 102, 241,0.24);
}

/* ── Tables ───────────────────────────────────────────────────────── */
.table {
  --bs-table-bg:            transparent;
  --bs-table-color:         var(--onc-text);
  --bs-table-border-color:  var(--onc-border);
  --bs-table-striped-bg:    var(--onc-table-stripe);
  --bs-table-striped-color: var(--onc-text);
  --bs-table-hover-bg:      var(--onc-table-hover);
  --bs-table-hover-color:   var(--onc-heading);
  color: var(--onc-text);
}
.table > thead > tr > th {
  background: var(--onc-table-head-bg) !important;
  color: var(--onc-table-head-text) !important;
  border-color: var(--onc-table-head-border) !important;
  border-width: 1px !important;
  font-weight: 600;
  font-size: .78rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding-top: 0.65rem;
  padding-bottom: 0.65rem;
}
.table > tbody > tr > td {
  border-color: var(--onc-border) !important;
  border-width: 1px !important;
  color: var(--onc-text);
  vertical-align: middle;
  transition: background-color 0.15s ease, color 0.15s ease;
}
.table > tbody > tr:nth-child(even) > td {
  background: var(--onc-table-even);
}
.table > tbody > tr:hover > td {
  background: var(--onc-table-hover);
  color: var(--onc-heading);
}
.table-bordered, .table-bordered th, .table-bordered td {
  border-color: var(--onc-border) !important;
}
/* contextual rows */
.table-danger  { --bs-table-bg: var(--onc-table-danger-bg);  --bs-table-color: var(--onc-table-danger-text);  --bs-table-border-color: var(--onc-border); }
.table-success { --bs-table-bg: var(--onc-table-success-bg);  --bs-table-color: var(--onc-table-success-text); --bs-table-border-color: var(--onc-border); }
.table-warning { --bs-table-bg: var(--onc-table-warning-bg);  --bs-table-color: var(--onc-table-warning-text); --bs-table-border-color: var(--onc-border); }
.table-info    { --bs-table-bg: var(--onc-table-info-bg);     --bs-table-color: var(--onc-table-info-text);    --bs-table-border-color: var(--onc-border); }

/* ── Forms ────────────────────────────────────────────────────────── */
.form-control, .form-select {
  background-color: var(--onc-surface);
  border: 1px solid var(--onc-border);
  border-radius: 8px;
  color: var(--onc-heading);
  transition: border-color var(--onc-transition), box-shadow var(--onc-transition), background-color var(--onc-transition);
}
.form-select {
  border-color: var(--onc-border-lt);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%236366f1' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
}
.form-control:focus, .form-select:focus {
  background-color: var(--onc-surface);
  border-color: var(--onc-purple);
  color: var(--onc-heading);
  box-shadow: 0 0 0 3px rgba(99,102,241,.20), 0 0 16px rgba(99,102,241,.08);
}
.form-control:disabled, .form-select:disabled,
.form-control[readonly] {
  background-color: var(--onc-raised);
  color: var(--onc-muted);
  opacity: .65;
}
.form-control::placeholder { color: var(--onc-muted); }
.form-label      { color: var(--onc-text); font-weight: 500; font-size: 0.875rem; }
.form-check-label { color: var(--onc-text); }
.form-check-input {
  background-color: var(--onc-surface);
  border: 1.5px solid var(--onc-border-lt);
  border-radius: 4px;
  transition: all var(--onc-transition);
}
.form-check-input:checked {
  background-color: var(--onc-purple);
  border-color: var(--onc-purple);
  box-shadow: 0 0 8px rgba(99,102,241,.25);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e");
}
.form-check-input:focus {
  box-shadow: 0 0 0 3px rgba(99,102,241,.20);
}
.form-check-input:disabled {
  background-color: var(--onc-raised);
  border-color: var(--onc-border);
  opacity: .5;
}
.form-check-input:disabled:checked {
  background-color: var(--onc-border-lt);
  border-color: var(--onc-border-lt);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e");
  opacity: .5;
}
.form-text { color: var(--onc-muted); }

/* ── Range sliders — visible track + themed thumb ────────────────── */
.form-range::-webkit-slider-runnable-track {
  background: rgba(99,102,241,.30);
  border-radius: 4px;
}
.form-range::-moz-range-track {
  background: rgba(99,102,241,.30);
  border-radius: 4px;
}
.form-range::-webkit-slider-thumb {
  background: var(--onc-purple);
  box-shadow: 0 0 6px rgba(99,102,241,.30);
}
.form-range::-moz-range-thumb {
  background: var(--onc-purple);
  box-shadow: 0 0 6px rgba(99,102,241,.30);
}
.form-range:focus::-webkit-slider-thumb {
  box-shadow: 0 0 0 3px rgba(99,102,241,.25);
}
.form-range:focus::-moz-range-thumb {
  box-shadow: 0 0 0 3px rgba(99,102,241,.25);
}
[data-bs-theme="light"] .form-range::-webkit-slider-runnable-track {
  background: rgba(99,102,241,.18);
}
[data-bs-theme="light"] .form-range::-moz-range-track {
  background: rgba(99,102,241,.18);
}
.input-group-text {
  background: var(--onc-raised);
  border-color: var(--onc-border);
  color: var(--onc-muted);
  border-radius: 8px;
}
select option {
  background: var(--onc-surface);
  color: var(--onc-text);
}

/* ── Buttons — glass fill with depth ─────────────────────────────── */
.btn {
  border-radius: 8px;
  font-weight: 500;
  transition: all var(--onc-transition);
  position: relative;
}

.btn-primary,
.btn-success,
.btn-outline-primary {
  background: var(--onc-btn-primary-bg);
  border: 1px solid rgba(37,99,235,.45);
  color: var(--onc-btn-primary-text);
  box-shadow: 0 1px 3px rgba(37,99,235,.15);
}
.btn-primary:hover, .btn-primary:focus,
.btn-success:hover, .btn-success:focus,
.btn-outline-primary:hover, .btn-outline-primary:focus {
  background: var(--onc-btn-primary-hover);
  border-color: var(--onc-blue-light);
  color: var(--onc-btn-primary-text);
  box-shadow: 0 4px 16px rgba(37,99,235,.25);
  transform: translateY(-1px);
}
.btn-primary:active, .btn-success:active, .btn-outline-primary:active {
  background: var(--onc-btn-primary-active);
  border-color: var(--onc-blue);
  color: var(--onc-btn-primary-text);
  transform: translateY(0);
  box-shadow: 0 1px 2px rgba(37,99,235,.20);
}

/* Light mode: solid buttons with gradient sheen */
[data-bs-theme="light"] .btn-primary,
[data-bs-theme="light"] .btn-success,
[data-bs-theme="light"] .btn-outline-primary {
  background: linear-gradient(135deg, #2563eb 0%, #3b82f6 100%);
  border-color: transparent;
  box-shadow: 0 2px 8px rgba(37,99,235,.20);
}
[data-bs-theme="light"] .btn-primary:hover,
[data-bs-theme="light"] .btn-success:hover,
[data-bs-theme="light"] .btn-outline-primary:hover {
  background: linear-gradient(135deg, #1d4ed8 0%, #2563eb 100%);
  box-shadow: 0 4px 20px rgba(37,99,235,.30);
}

/* Radio/checkbox button groups */
.btn-check + .btn-outline-primary {
  background: rgba(99,102,241,.08);
  color: var(--onc-blue-light);
}
.btn-check:checked + .btn-outline-primary {
  background: var(--onc-btn-primary-bg);
  border-color: var(--onc-blue);
  color: var(--onc-btn-primary-text);
}

.btn-danger,
.btn-outline-danger {
  background: var(--onc-btn-danger-bg);
  border: 1px solid rgba(239,68,68,.40);
  color: var(--onc-btn-danger-text);
  box-shadow: 0 1px 3px rgba(239,68,68,.12);
}
.btn-danger:hover, .btn-danger:focus,
.btn-outline-danger:hover, .btn-outline-danger:focus {
  background: var(--onc-btn-danger-hover);
  border-color: rgba(239,68,68,.60);
  color: var(--onc-btn-danger-text);
  box-shadow: 0 4px 16px rgba(239,68,68,.20);
  transform: translateY(-1px);
}
.btn-danger:active, .btn-outline-danger:active {
  background: var(--onc-btn-danger-active);
  border-color: var(--onc-red);
  color: var(--onc-btn-danger-text);
  transform: translateY(0);
}

[data-bs-theme="light"] .btn-danger,
[data-bs-theme="light"] .btn-outline-danger {
  background: linear-gradient(135deg, #dc2626 0%, #ef4444 100%);
  border-color: transparent;
  box-shadow: 0 2px 8px rgba(239,68,68,.18);
}

.btn-secondary,
.btn-outline-secondary {
  background: var(--onc-btn-secondary-bg);
  border: 1px solid var(--onc-border-lt);
  color: var(--onc-btn-secondary-text);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.btn-secondary:hover, .btn-outline-secondary:hover {
  background: var(--onc-btn-secondary-hover);
  border-color: var(--onc-blue-light);
  color: var(--onc-btn-secondary-hover-text);
  transform: translateY(-1px);
}

/* Warning & Info outline buttons (used by agent state toggle) */
.btn-outline-warning {
  background: rgba(234,179,8,.10);
  border: 1px solid rgba(234,179,8,.35);
  color: var(--onc-text-warning);
  transition: all var(--onc-transition);
}
.btn-outline-warning:hover {
  background: rgba(234,179,8,.20);
  border-color: rgba(234,179,8,.50);
  color: var(--onc-text-warning);
  transform: translateY(-1px);
}
.btn-outline-info {
  background: rgba(34,211,238,.08);
  border: 1px solid rgba(34,211,238,.30);
  color: var(--onc-text-info);
  transition: all var(--onc-transition);
}
.btn-outline-info:hover {
  background: rgba(34,211,238,.16);
  border-color: rgba(34,211,238,.45);
  color: var(--onc-text-info);
  transform: translateY(-1px);
}
.btn-outline-success {
  background: rgba(34,197,94,.08);
  border: 1px solid rgba(34,197,94,.30);
  color: var(--onc-text-success);
  transition: all var(--onc-transition);
}
.btn-outline-success:hover {
  background: rgba(34,197,94,.16);
  border-color: rgba(34,197,94,.45);
  color: var(--onc-text-success);
  transform: translateY(-1px);
}

/* ── Nav Tabs ────────────────────────────────────────────────────── */
.nav-tabs {
  border-bottom: 1px solid var(--onc-border);
  gap: 3px;
}
.nav-tabs .nav-link {
  color: var(--onc-text);
  background: rgba(99,102,241,.06);
  border: 1px solid rgba(99,102,241,.10);
  border-bottom: none;
  border-radius: 8px 8px 0 0;
  padding: .5rem 1.2rem;
  font-weight: 500;
  font-size: 0.88rem;
  transition: all var(--onc-transition);
  position: relative;
}
.nav-tabs .nav-link:hover {
  color: var(--onc-heading);
  background: rgba(99,102,241,.12);
  border-color: rgba(99,102,241,.20);
}
.nav-tabs .nav-link.active {
  background: var(--onc-tab-active-bg);
  color: var(--onc-tab-active-text);
  border-color: var(--onc-border-lt);
  font-weight: 600;
}
/* Gradient underline accent on active tab — uses ::before because
   Bootstrap's dropdown-toggle uses ::after for the caret arrow */
.nav-tabs .nav-link.active::before {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--onc-gradient);
  border-radius: 1px;
  z-index: 1;
}
.nav-tabs .nav-link.tab-maint {
  opacity: 0.65;
  font-size: 0.84rem;
}
.nav-tabs .nav-link.tab-maint:hover,
.nav-tabs .nav-link.tab-maint.active {
  opacity: 1;
}

/* ── Tab dropdown menus ────────────────────────────────────────── */
.nav-tabs .dropdown-menu {
  background: var(--onc-glass);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--onc-border);
  border-radius: 10px;
  padding: 0.35rem 0;
  min-width: 10rem;
  box-shadow: var(--onc-dropdown-shadow);
}
.nav-tabs .dropdown-item {
  color: var(--onc-text);
  font-size: 0.88rem;
  padding: 0.45rem 1rem;
  border-radius: 4px;
  margin: 0 0.25rem;
  transition: all 0.15s ease;
}
.nav-tabs .dropdown-item:hover,
.nav-tabs .dropdown-item:focus {
  background: rgba(99,102,241,.10);
  color: var(--onc-heading);
}
.nav-tabs .dropdown-item.active {
  background: rgba(99,102,241,.18);
  color: var(--onc-heading);
  font-weight: 600;
  position: relative;
  padding-left: calc(1rem + 4px);
}
.nav-tabs .dropdown-item.active::before {
  content: '';
  position: absolute;
  left: 0;
  top: 4px;
  bottom: 4px;
  width: 2px;
  background: var(--onc-gradient);
  border-radius: 1px;
}
.nav-tabs .nav-link.dropdown-toggle.active {
  border-bottom-color: transparent;
}

/* ── Generate icon button ──────────────────────────────────────── */
.btn-icon-gen {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.375rem 0.5rem;
}

/* ── Action icon buttons (Lucide stroke style) ─────────────────── */
.btn-action-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  padding: 0;
  border: 1px solid rgba(99,102,241,.08);
  border-radius: 8px;
  background: rgba(99,102,241,.03);
  color: var(--onc-muted);
  cursor: pointer;
  transition: all 0.15s ease;
}
.btn-action-icon:hover {
  background: rgba(99,102,241,.10);
  border-color: var(--onc-purple);
  color: var(--onc-purple);
  box-shadow: 0 1px 3px rgba(99,102,241,.10);
}
.btn-action-icon.btn-action-danger {
  border-color: rgba(239,68,68,.08);
  background: rgba(239,68,68,.02);
}
.btn-action-icon.btn-action-danger:hover {
  background: rgba(239,68,68,.06);
  border-color: rgba(239,68,68,.35);
  color: var(--onc-red, #ef4444);
  box-shadow: 0 1px 3px rgba(239,68,68,.10);
}

/* ── Header tenant selector ─────────────────────────────────────── */
.onc-header-tenant-select {
  appearance: auto;
  background: rgba(255,255,255,.08);
  border: 1px solid var(--onc-header-border);
  border-radius: 6px;
  color: var(--onc-header-text);
  font-size: 0.85rem;
  padding: 0.2rem 0.5rem;
  max-width: 250px;
  cursor: pointer;
  transition: all var(--onc-transition);
}
.onc-header-tenant-select:focus {
  outline: none;
  border-color: #6366f1;
  box-shadow: 0 0 0 2px rgba(99,102,241,.3);
}
.onc-header-tenant-select option {
  background: #111128;
  color: #e5e7eb;
}
[data-bs-theme="light"] .onc-header-tenant-select {
  background: rgba(255,255,255,.20);
  border-color: rgba(255,255,255,.35);
  color: #fff;
}
[data-bs-theme="light"] .onc-header-tenant-select option {
  background: #fff;
  color: #1e293b;
}

/* ── Small action buttons ─────────────────────────────────────────── */
.btn-xs {
  font-size: 0.72rem;
  padding: 0.2rem 0.45rem;
  line-height: 1.3;
  border-radius: 6px;
}

/* ── Codec format badges ─────────────────────────────────────────── */
.badge-codec { font-size: 0.65rem; }

/* ── Alerts — glass-panel style ───────────────────────────────────── */
.alert {
  border-radius: 10px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.alert-success {
  background: var(--onc-alert-success-bg);
  border: 1px solid var(--onc-alert-success-border);
  color: var(--onc-alert-success-text);
}
.alert-danger {
  background: var(--onc-alert-danger-bg);
  border: 1px solid var(--onc-alert-danger-border);
  color: var(--onc-alert-danger-text);
}
.alert-warning {
  background: var(--onc-alert-warning-bg);
  border: 1px solid var(--onc-alert-warning-border);
  color: var(--onc-alert-warning-text);
}
.alert-info {
  background: var(--onc-alert-info-bg);
  border: 1px solid var(--onc-alert-info-border);
  color: var(--onc-alert-info-text);
}

/* ── Pagination ───────────────────────────────────────────────────── */
.page-link {
  background: var(--onc-surface);
  border-color: var(--onc-border);
  color: var(--onc-text);
  border-radius: 6px;
  transition: all var(--onc-transition);
}
.page-link:hover {
  background: var(--onc-raised);
  border-color: var(--onc-border-lt);
  color: var(--onc-heading);
  transform: translateY(-1px);
}
.page-item.active .page-link {
  background: linear-gradient(135deg, var(--onc-purple) 0%, var(--onc-blue) 100%);
  border-color: transparent;
  color: #fff;
  box-shadow: 0 2px 8px rgba(99,102,241,.25);
}
.page-item.disabled .page-link {
  background: var(--onc-bg);
  border-color: var(--onc-border);
  color: var(--onc-muted);
}

/* ── Badges — refined glass pills ─────────────────────────────────── */
.badge {
  font-weight: 600;
  letter-spacing: 0.02em;
  border-radius: 6px;
  text-transform: uppercase;
}
/* Center-align table cells whose only element children are badges or a lone placeholder */
.table td:has(> .badge:only-child),
.table td:has(> .badge):not(:has(> :not(.badge))),
.table td:not(.text-start):has(> .text-muted:only-child),
.table td:has(> .text-success:only-child) {
  text-align: center;
}
/* Center-align action button columns (last-child cells containing .btn) */
.table td:last-child:has(.btn) {
  text-align: center;
}
.table td:last-child.d-flex:has(.btn) {
  justify-content: center;
}
.badge.bg-success {
  background: rgba(34,197,94,.18) !important;
  color: var(--onc-text-success) !important;
  border: 1px solid rgba(34,197,94,.25);
}
.badge.bg-danger {
  background: rgba(239,68,68,.18) !important;
  color: var(--onc-text-danger) !important;
  border: 1px solid rgba(239,68,68,.25);
}
.badge.bg-secondary {
  background: var(--onc-raised) !important;
  color: var(--onc-muted) !important;
  border: 1px solid var(--onc-border);
}
.badge.bg-warning {
  background: rgba(234,179,8,.15) !important;
  color: var(--onc-text-warning) !important;
  border: 1px solid rgba(234,179,8,.25);
}
.badge.bg-info {
  background: rgba(34,211,238,.12) !important;
  color: var(--onc-text-info) !important;
  border: 1px solid rgba(34,211,238,.22);
}
.badge.bg-primary {
  background: rgba(99,102,241,.18) !important;
  color: var(--onc-purple-hover) !important;
  border: 1px solid rgba(99,102,241,.25);
}
/* Light mode badge overrides for readability */
[data-bs-theme="light"] .badge.bg-success {
  background: rgba(34,197,94,.10) !important;
  color: #15803d !important;
}
[data-bs-theme="light"] .badge.bg-danger {
  background: rgba(239,68,68,.10) !important;
  color: #dc2626 !important;
}
[data-bs-theme="light"] .badge.bg-warning {
  background: rgba(234,179,8,.10) !important;
  color: #a16207 !important;
}
[data-bs-theme="light"] .badge.bg-info {
  background: rgba(34,211,238,.08) !important;
  color: #0e7490 !important;
}
[data-bs-theme="light"] .badge.bg-primary {
  background: rgba(99,102,241,.10) !important;
  color: #6366f1 !important;
}

/* ── Modals — glassmorphic dialog ─────────────────────────────────── */
.modal-backdrop {
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.modal-content {
  background: var(--onc-glass);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid var(--onc-border);
  border-radius: 14px;
  color: var(--onc-text);
  box-shadow: 0 16px 64px rgba(0,0,0,.35), 0 0 0 1px rgba(129,140,248,.08);
  overflow: hidden;
}
[data-bs-theme="light"] .modal-content {
  background: var(--onc-glass);
  box-shadow: 0 16px 64px rgba(0,0,0,.10), 0 0 0 1px rgba(99,102,241,.06);
}
.modal-header {
  border-bottom: 1px solid var(--onc-border);
  color: var(--onc-heading);
  padding: 1rem 1.25rem;
}
.modal-footer {
  border-top: 1px solid var(--onc-border);
  padding: 0.85rem 1.25rem;
}
.modal-title  { color: var(--onc-heading); font-weight: 600; }
.btn-close    { filter: var(--onc-btn-close-filter); }

/* ── Bootstrap text utilities ────────────────────────────────────── */
.text-muted    { color: var(--onc-muted) !important; }
.text-body     { color: var(--onc-text) !important; }
.text-success  { color: var(--onc-text-success) !important; }
.text-danger   { color: var(--onc-text-danger) !important; }
.text-warning  { color: var(--onc-text-warning) !important; }
.text-info     { color: var(--onc-text-info) !important; }
.text-primary  { color: var(--onc-link-color) !important; }
.text-dark     { color: var(--onc-text) !important; }
.text-light    { color: var(--onc-heading) !important; }
.text-white    { color: #fff !important; }
.text-center   { color: inherit !important; }

/* ── Bootstrap background utilities ──────────────────────────────── */
.bg-light  { background: var(--onc-surface) !important; color: var(--onc-text) !important; }
.bg-white  { background: var(--onc-surface) !important; color: var(--onc-text) !important; }
.bg-body   { background: var(--onc-bg) !important; }
.bg-dark   { background: var(--onc-bg) !important; }

/* ── Misc ─────────────────────────────────────────────────────────── */
.border        { border-color: var(--onc-border) !important; }
.border-bottom { border-bottom-color: var(--onc-border) !important; }
.border-top    { border-top-color: var(--onc-border) !important; }

.list-group-item {
  background: var(--onc-surface);
  border-color: var(--onc-border);
  color: var(--onc-text);
  transition: background-color 0.15s ease;
}
.list-group-item:hover {
  background: var(--onc-raised);
}

.dropdown-menu {
  background: var(--onc-glass);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--onc-border);
  border-radius: 10px;
  box-shadow: var(--onc-dropdown-shadow);
  padding: 0.35rem;
}
.dropdown-item {
  color: var(--onc-text);
  border-radius: 6px;
  transition: all 0.15s ease;
  padding: 0.4rem 0.75rem;
}
.dropdown-item:hover {
  background: rgba(99,102,241,.10);
  color: var(--onc-heading);
}
.dropdown-divider { border-color: var(--onc-border); }

.breadcrumb              { --bs-breadcrumb-divider-color: var(--onc-muted); }
.breadcrumb-item         { color: var(--onc-muted); }
.breadcrumb-item.active  { color: var(--onc-text); }
.spinner-border          { color: var(--onc-link-color); }

/* ── Tooltip / Popover ────────────────────────────────────────────── */
.tooltip-inner {
  background: var(--onc-raised);
  color: var(--onc-text);
  border-radius: 6px;
  box-shadow: 0 4px 12px rgba(0,0,0,.25);
}
.popover {
  background: var(--onc-glass);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-color: var(--onc-border);
  border-radius: 10px;
  box-shadow: var(--onc-dropdown-shadow);
}
.popover-body  { color: var(--onc-text); }

/* ── Comments column truncation (used by billing_did_maint) ──────── */
.comments-cell {
  max-width: 300px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Match indicator states (billing DID maint) ──────────────────── */
.match-indicator {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  transition: all var(--onc-transition);
}
.match-neutral { background: var(--onc-match-neutral-bg); color: var(--onc-match-neutral-text); }
.match-warning { background: var(--onc-match-warning-bg); color: var(--onc-match-warning-text); }
.match-success { background: var(--onc-match-success-bg); color: var(--onc-match-success-text); }
.match-danger  { background: var(--onc-match-danger-bg);  color: var(--onc-match-danger-text); }

/* ── Gradient text utility ───────────────────────────────────────── */
.onc-gradient-text {
  background: var(--onc-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── Scrollbar — subtle, on-brand ────────────────────────────────── */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}
::-webkit-scrollbar-track {
  background: transparent;
}
::-webkit-scrollbar-thumb {
  background: rgba(99,102,241,.20);
  border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
  background: rgba(99,102,241,.35);
}
[data-bs-theme="light"] ::-webkit-scrollbar-thumb {
  background: rgba(99,102,241,.12);
}
[data-bs-theme="light"] ::-webkit-scrollbar-thumb:hover {
  background: rgba(99,102,241,.22);
}

/* ── Section Links (inline in header) ────────────────────────────── */
.onc-sec-link {
  display: inline-block;
  padding: 0.25rem 0.55rem;
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--onc-header-muted);
  text-decoration: none;
  white-space: nowrap;
  border-radius: 5px;
  transition: all var(--onc-transition);
}
.onc-sec-link:hover {
  color: #fff;
  background: rgba(255,255,255,.12);
}
.onc-sec-link.active {
  color: #fff;
  background: rgba(255,255,255,.18);
  font-weight: 600;
}
.onc-sec-dropdown {
  background: var(--onc-surface);
  border: 1px solid var(--onc-border);
  border-radius: 10px;
  box-shadow: var(--onc-dropdown-shadow);
  padding: 0.35rem;
  min-width: 12rem;
}
.onc-sec-dropdown .dropdown-item {
  color: var(--onc-text);
  font-size: 0.85rem;
  padding: 0.45rem 0.85rem;
  border-radius: 6px;
  transition: all 0.15s ease;
}
.onc-sec-dropdown .dropdown-item:hover {
  background: rgba(99,102,241,.10);
  color: var(--onc-heading);
}
.onc-sec-dropdown .dropdown-item.active {
  background: rgba(99,102,241,.18);
  color: var(--onc-heading);
  font-weight: 600;
}

/* ── AI Branding ──────────────────────────────────────────────────── */
.ai-text { background: var(--onc-gradient-text); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.ai-btn { background: var(--onc-gradient); border: none; color: #fff; }
.ai-btn:hover { opacity: .88; color: #fff; }
.ai-badge { background: var(--onc-gradient); color: #fff; }
[data-bs-theme="light"] .ai-text { background: var(--onc-gradient); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
