/* =============================================================================
   TUDAWE SERVICE OPS — Design System
   Consolidated from Sprints 1–10 + Batches C/P/Q
   Maintainer: AILevelUp.io
   Structure:
     1. Design tokens (single :root)
     2. Dark mode tokens
     3. Base / reset
     4. Layout shell (topbar, sidebar, content)
     5. Navigation
     6. Page structure (headers, containers)
     7. Typography scale
     8. Buttons
     9. Cards & panels
    10. Forms
    11. Tables
    12. Badges & status
    13. Dashboard KPI components
    14. Module-specific: settings, customer, service, finance, knowledge, AI hub
    15. Accessibility (skip link, focus-visible)
    16. Print
    17. Responsive
   ============================================================================= */

/* ─── 1. DESIGN TOKENS ─────────────────────────────────────────────────────── */
:root {
  /* Typography */
  --font-display: 'Sora', ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-body:    'Manrope', ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

  /* Font scale */
  --text-xs:   0.68rem;   /* helper text, labels, badges */
  --text-sm:   0.78rem;   /* table text, secondary labels */
  --text-base: 0.88rem;   /* body text */
  --text-md:   1rem;      /* card titles, panel titles */
  --text-lg:   1.18rem;   /* sub-section headings */
  --text-xl:   1.45rem;   /* page titles (mobile) */
  --text-2xl:  1.65rem;   /* page titles (desktop) */
  --text-kpi:  1.58rem;   /* metric values */

  /* Colors — light mode */
  --app-bg:            #f4f6fa;
  --app-surface:       #ffffff;
  --app-surface-2:     #f7f9fc;
  --app-border:        #e1e7f0;
  --app-border-strong: #c9d3df;
  --app-text:          #101828;
  --app-muted:         #667085;
  --app-link:          #155ca8;

  --app-primary:       #0c3566;
  --app-primary-2:     #155ca8;
  --app-primary-soft:  #eaf3ff;

  --app-success:       #168454;
  --app-success-soft:  #eaf7ef;
  --app-warning:       #d97706;
  --app-warning-soft:  #fff7e6;
  --app-danger:        #c2413b;
  --app-danger-soft:   #fff0f0;
  --app-info-soft:     #e8f5ff;

  /* Sidebar (always dark) */
  --app-sidebar:       #080d17;
  --app-sidebar-2:     #101827;
  --sidebar-width:     236px;
  --topbar-height:     54px;

  /* Shape */
  --app-radius-sm:  8px;
  --app-radius:     12px;
  --app-radius-lg:  16px;
  --app-radius-xl:  20px;

  /* Elevation */
  --app-shadow-xs: 0 2px 8px rgba(16, 24, 40, 0.04);
  --app-shadow-sm: 0 4px 16px rgba(16, 24, 40, 0.055);
  --app-shadow:    0 12px 40px rgba(16, 24, 40, 0.10);
  --app-shadow-lg: 0 24px 64px rgba(16, 24, 40, 0.14);

  /* Component sizes */
  --input-height:    36px;
  --input-height-lg: 42px;
  --btn-radius:      10px;

  /* Focus ring */
  --focus-color:  rgba(21, 92, 168, 0.45);
  --focus-width:  3px;
}

/* ─── 2. DARK MODE TOKENS ──────────────────────────────────────────────────── */
[data-theme="dark"],
.dark-mode {
  --app-bg:            #0d1117;
  --app-surface:       #161b22;
  --app-surface-2:     #1c2433;
  --app-border:        #2d3848;
  --app-border-strong: #3d4f66;
  --app-text:          #e2e8f0;
  --app-muted:         #8b98a5;
  --app-link:          #93c5fd;

  --app-primary:       #60a5fa;
  --app-primary-2:     #93c5fd;
  --app-primary-soft:  #1a2d4d;

  --app-success:       #34d399;
  --app-success-soft:  #0f2419;
  --app-warning:       #fbbf24;
  --app-warning-soft:  #271c09;
  --app-danger:        #f87171;
  --app-danger-soft:   #2a0f0f;
  --app-info-soft:     #0f1f38;

  --app-shadow-xs: 0 2px 8px rgba(0, 0, 0, 0.28);
  --app-shadow-sm: 0 4px 16px rgba(0, 0, 0, 0.30);
  --app-shadow:    0 12px 40px rgba(0, 0, 0, 0.40);
  --app-shadow-lg: 0 24px 64px rgba(0, 0, 0, 0.50);

  --focus-color:  rgba(147, 197, 253, 0.50);
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --app-bg:            #0d1117;
    --app-surface:       #161b22;
    --app-surface-2:     #1c2433;
    --app-border:        #2d3848;
    --app-border-strong: #3d4f66;
    --app-text:          #e2e8f0;
    --app-muted:         #8b98a5;
    --app-link:          #93c5fd;
    --app-primary:       #60a5fa;
    --app-primary-2:     #93c5fd;
    --app-primary-soft:  #1a2d4d;
    --app-success:       #34d399;
    --app-success-soft:  #0f2419;
    --app-warning:       #fbbf24;
    --app-warning-soft:  #271c09;
    --app-danger:        #f87171;
    --app-danger-soft:   #2a0f0f;
    --app-info-soft:     #0f1f38;
    --app-shadow-xs: 0 2px 8px rgba(0, 0, 0, 0.28);
    --app-shadow-sm: 0 4px 16px rgba(0, 0, 0, 0.30);
    --app-shadow:    0 12px 40px rgba(0, 0, 0, 0.40);
    --app-shadow-lg: 0 24px 64px rgba(0, 0, 0, 0.50);
    --focus-color:   rgba(147, 197, 253, 0.50);
  }
}

/* ─── 3. BASE / RESET ──────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html { min-height: 100%; scroll-behavior: smooth; }

body.app-body {
  min-height: 100vh;
  margin: 0;
  background: radial-gradient(circle at 14% -8%, rgba(61, 158, 245, 0.10), transparent 28rem),
              linear-gradient(180deg, #f9fbff 0%, var(--app-bg) 42%, #eef2f7 100%);
  color: var(--app-text);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  transition: background-color 200ms ease, color 200ms ease;
}

[data-theme="dark"] body.app-body,
[data-theme="dark"].app-body {
  background: radial-gradient(circle at 14% -8%, rgba(21, 60, 120, 0.18), transparent 28rem),
              linear-gradient(180deg, #0d1421 0%, #0d1117 55%, #090e18 100%);
}

a { color: var(--app-link); text-decoration: none; }
a:hover { color: var(--app-primary); text-decoration: none; }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  color: var(--app-text);
  letter-spacing: -0.03em;
  line-height: 1.12;
}
h1, h2 { font-weight: 700; }
h3, h4 { font-weight: 700; }
h5, h6 { font-weight: 700; }

.text-muted { color: var(--app-muted) !important; }

/* ─── 4. LAYOUT SHELL ──────────────────────────────────────────────────────── */
.app-topbar {
  position: fixed;
  inset: 0 0 auto 0;
  height: var(--topbar-height);
  z-index: 1040;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0 0.9rem;
  color: #fff;
  background: linear-gradient(135deg, #080d17 0%, #101827 55%, #0c3566 100%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.22);
}

.app-shell { display: flex; min-height: 100vh; padding-top: var(--topbar-height); }

.app-content {
  width: calc(100% - var(--sidebar-width));
  margin-left: var(--sidebar-width);
  padding: 0.78rem clamp(0.82rem, 1.35vw, 1.25rem) 1.6rem;
}

/* ─── 5. TOPBAR ELEMENTS ───────────────────────────────────────────────────── */
.topbar-left, .account-area, .brand-lockup, .user-chip {
  display: flex;
  align-items: center;
}
.topbar-left { gap: 0.64rem; min-width: 218px; }
.account-area { gap: 0.48rem; margin-left: auto; }
.brand-lockup { gap: 0.58rem; color: #fff; line-height: 1.05; }
.brand-lockup:hover { color: #fff; }

.brand-mark {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 11px;
  background: linear-gradient(135deg, #fff 0%, #dbeafe 100%);
  color: #0f3d73;
  font-weight: 800;
  font-size: 0.78rem;
  letter-spacing: -0.02em;
  box-shadow: inset 0 0 0 1px rgba(15, 61, 115, 0.06), 0 7px 18px rgba(0, 0, 0, 0.18);
  flex-shrink: 0;
}
.brand-mark img {
  width: 100%; height: 100%;
  border-radius: 10px; padding: 2px;
  object-fit: contain; background: #fff;
}
.brand-copy strong { display: block; font-size: 0.88rem; font-weight: 800; letter-spacing: -0.025em; }
.brand-copy small  { display: block; color: rgba(255,255,255,0.58); font-size: 0.64rem; margin-top: 0.05rem; }

.sidebar-toggle {
  display: none;
  width: 36px; height: 36px;
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: 10px;
  background: rgba(255,255,255,0.08);
  padding: 0.5rem;
  cursor: pointer;
}
.sidebar-toggle span {
  display: block;
  height: 2px;
  margin: 4px 0;
  border-radius: 999px;
  background: #fff;
  transition: transform 180ms ease, opacity 180ms ease;
}
.sidebar-open .sidebar-toggle span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.sidebar-open .sidebar-toggle span:nth-child(2) { opacity: 0; }
.sidebar-open .sidebar-toggle span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

.search-form {
  position: relative;
  display: flex;
  align-items: center;
  width: min(510px, 39vw);
  min-width: 260px;
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 999px;
  background: rgba(255,255,255,0.09);
  backdrop-filter: blur(6px);
  overflow: hidden;
}
.search-icon { position: absolute; left: 0.85rem; color: rgba(255,255,255,0.62); font-size: 1rem; pointer-events: none; }
.search-form input {
  width: 100%; height: 34px;
  border: 0; outline: 0;
  padding: 0 5.25rem 0 2.35rem;
  color: #fff; background: transparent;
  font-size: 0.86rem;
}
.search-form input::placeholder { color: rgba(255,255,255,0.55); }
.search-form button {
  position: absolute; right: 4px;
  height: 26px; border: 0; border-radius: 999px;
  padding: 0 0.78rem;
  color: #0f172a; background: #fff;
  font-size: 0.72rem; font-weight: 800;
  cursor: pointer;
}
.search-form button:hover { background: #e8f0fa; }

.user-chip {
  display: flex; align-items: center;
  gap: 0.44rem;
  padding: 0.16rem 0.45rem 0.16rem 0.16rem;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 999px;
  background: rgba(255,255,255,0.08);
}
.avatar-dot {
  display: grid; place-items: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: #e0edff;
  color: #0f3d73;
  font-weight: 800;
  font-size: 0.8rem;
}
.user-meta strong, .user-meta small { display: block; line-height: 1.1; }
.user-meta strong { max-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 0.78rem; font-weight: 800; color: #fff; }
.user-meta small  { color: rgba(255,255,255,0.58); font-size: 0.62rem; margin-top: 0.1rem; }

.logout-form .btn { padding: 0.23rem 0.58rem; font-size: 0.76rem; border-radius: 9px; }

/* Theme toggle */
.theme-toggle {
  display: flex; align-items: center; justify-content: center;
  width: 30px; height: 30px;
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 9px;
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.72);
  cursor: pointer;
  font-size: 0.9rem;
  line-height: 1;
  transition: background 150ms ease, color 150ms ease;
}
.theme-toggle:hover { background: rgba(255,255,255,0.15); color: #fff; }
.theme-toggle .icon-sun  { display: none; }
.theme-toggle .icon-moon { display: block; }
[data-theme="dark"] .theme-toggle .icon-sun  { display: block; }
[data-theme="dark"] .theme-toggle .icon-moon { display: none; }

.topbar-utility-link {
  display: inline-flex; align-items: center;
  padding: 0.26rem 0.64rem;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 9px;
  color: rgba(255,255,255,0.72);
  font-size: 0.76rem;
  font-weight: 700;
  background: rgba(255,255,255,0.07);
  transition: background 140ms ease, color 140ms ease;
  white-space: nowrap;
}
.topbar-utility-link:hover, .topbar-utility-link.active {
  color: #fff; background: rgba(255,255,255,0.14);
}

/* ─── 6. SIDEBAR ───────────────────────────────────────────────────────────── */
.app-sidebar {
  position: fixed;
  top: var(--topbar-height); bottom: 0; left: 0;
  width: var(--sidebar-width);
  display: flex;
  flex-direction: column;
  padding: 0.68rem 0.58rem 0.85rem;
  overflow-y: auto;
  background: linear-gradient(180deg, #080d17 0%, #101827 100%);
  border-right: 1px solid rgba(255,255,255,0.07);
  z-index: 1030;
}

.sidebar-section {
  flex: 0 0 auto;
  margin-bottom: 0.36rem;
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 12px;
  background: rgba(255,255,255,0.022);
  overflow: hidden;
}
.sidebar-section[open] { padding-bottom: 0.28rem; }
.sidebar-section summary::-webkit-details-marker { display: none; }

.nav-section-label {
  position: relative;
  display: flex; align-items: center; justify-content: space-between;
  gap: 0.7rem;
  margin: 0;
  padding: 0.56rem 0.7rem;
  cursor: pointer;
  color: rgba(255,255,255,0.58);
  font-family: var(--font-mono);
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  user-select: none;
  list-style: none;
}
.nav-section-label::after { content: "+"; font-family: var(--font-body); font-size: 0.9rem; color: rgba(255,255,255,0.38); }
.sidebar-section[open] > .nav-section-label::after { content: "−"; }

.app-nav-link {
  position: relative;
  display: flex; align-items: center;
  min-height: 31px;
  margin: 0.06rem 0.3rem;
  padding: 0.38rem 0.56rem;
  border-radius: 9px;
  color: rgba(255,255,255,0.70);
  font-size: 0.8rem;
  font-weight: 700;
  transition: background 120ms ease, color 120ms ease;
}
.app-nav-link::before {
  content: "";
  flex-shrink: 0;
  width: 5px; height: 5px;
  margin-right: 0.48rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.28);
}
.app-nav-link:hover { color: #fff; background: rgba(255,255,255,0.08); }
.app-nav-link.active {
  color: #fff;
  background: linear-gradient(135deg, rgba(26,124,232,0.95), rgba(12,53,102,0.95));
  box-shadow: 0 10px 28px rgba(26,124,232,0.20);
}
.app-nav-link.active::before { background: #fff; }
.app-nav-link:focus-visible {
  outline: var(--focus-width) solid rgba(147,197,253,0.55);
  outline-offset: 1px;
}

.sidebar-empty-state {
  padding: 0.75rem 0.9rem;
  color: rgba(255,255,255,0.42);
  font-size: 0.8rem;
}

.sidebar-system-strip {
  margin-top: auto;
  padding: 0.55rem 0.7rem;
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 10px;
  background: rgba(255,255,255,0.025);
}
.sidebar-system-label { color: rgba(255,255,255,0.35); font-family: var(--font-mono); font-size: 0.55rem; letter-spacing: 0.14em; text-transform: uppercase; }
.sidebar-system-links { display: flex; gap: 0.5rem; margin-top: 0.28rem; flex-wrap: wrap; }
.sidebar-system-link { color: rgba(255,255,255,0.55); font-size: 0.76rem; font-weight: 700; }
.sidebar-system-link:hover { color: #fff; }

/* Developer branding */
.sidebar-brand-credit {
  margin: auto 0.3rem 0;
  border: 1px solid rgba(255,255,255,0.085);
  border-radius: 13px;
  background: linear-gradient(180deg, rgba(255,255,255,0.045), rgba(255,255,255,0.018));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
  overflow: hidden;
}
.sidebar-brand-credit-link {
  display: flex; align-items: center;
  gap: 0.55rem;
  padding: 0.58rem 0.62rem;
  min-width: 0;
  color: rgba(255,255,255,0.72);
}
.sidebar-brand-credit-link:hover { color: #fff; }
.sidebar-brand-kicker {
  display: block;
  color: rgba(255,255,255,0.36);
  font-family: var(--font-mono);
  font-size: 0.54rem;
  font-weight: 700;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}
.sidebar-brand-name {
  display: block;
  color: rgba(255,255,255,0.78);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  margin-top: 0.1rem;
}
.sidebar-brand-credit-link:hover .sidebar-brand-name { color: #fff; }

.sidebar-backdrop { display: none; }

.app-footer-credit {
  display: none;
  justify-content: center;
  gap: 0.35rem;
  margin-top: 1rem;
  padding: 0.72rem 0.5rem 0;
  border-top: 1px solid var(--app-border);
  color: var(--app-muted);
  font-size: 0.68rem;
  text-align: center;
}
.app-footer-credit-link { display: inline-flex; align-items: center; gap: 0.32rem; color: var(--app-muted); }
.app-footer-credit-link strong { color: var(--app-primary-2); font-weight: 800; }
.app-footer-credit-link:hover strong { color: var(--app-primary); }

/* ─── 7. PAGE STRUCTURE ────────────────────────────────────────────────────── */
.container-fluid { padding-left: 0; padding-right: 0; }

.message-stack { margin-bottom: 0.75rem; }
.message-stack .alert { font-size: 0.86rem; border-radius: 12px; }

.page-header,
.app-content > .d-flex.justify-content-between.align-items-center.mb-3,
.app-content > .d-flex.justify-content-between.align-items-center.mb-4,
.app-content .container-fluid > .d-flex.justify-content-between.align-items-center.mb-4 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  position: relative;
  min-height: 0;
  margin-bottom: 0.68rem !important;
  padding: 0.68rem 0.78rem;
  border: 1px solid var(--app-border);
  border-radius: var(--app-radius-lg);
  background: var(--app-surface);
  box-shadow: var(--app-shadow-sm);
  overflow: hidden;
  transition: background 200ms ease, border-color 200ms ease;
}

/* Accent stripe on page headers in key modules */
.app-content--knowledge .page-header::after,
.app-content--core .page-header::after,
.app-content--dashboard .page-header::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 3px;
  background: linear-gradient(90deg, rgba(21,92,168,0.86), rgba(20,184,166,0.22));
  z-index: 0;
}
.app-content--knowledge .page-header > *,
.app-content--core .page-header > *,
.app-content--dashboard .page-header > * { position: relative; z-index: 1; }

.app-content > h2:first-child {
  margin-bottom: 0.68rem !important;
  padding: 0.68rem 0.78rem;
  border: 1px solid var(--app-border);
  border-radius: var(--app-radius-lg);
  background: var(--app-surface);
  box-shadow: var(--app-shadow-sm);
}

/* ─── 8. TYPOGRAPHY SCALE ──────────────────────────────────────────────────── */
.page-eyebrow {
  margin-bottom: 0.24rem;
  color: var(--app-primary-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.page-header h1,
.page-header h2,
.app-content .container-fluid > .d-flex.justify-content-between.align-items-center.mb-4 h1,
.app-content .container-fluid > .d-flex.justify-content-between.align-items-center.mb-4 h2,
.app-content > h2:first-child {
  margin-bottom: 0.12rem !important;
  font-size: clamp(var(--text-xl), 1.9vw, var(--text-2xl));
}
.page-header p,
.app-content .container-fluid > .d-flex.justify-content-between.align-items-center.mb-4 p {
  font-size: var(--text-sm);
  line-height: 1.4;
  color: var(--app-muted);
  margin: 0;
}
/* ─── 9. BUTTONS ───────────────────────────────────────────────────────────── */
.btn {
  border-radius: var(--btn-radius);
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--text-base);
  letter-spacing: -0.01em;
  transition: background 150ms ease, border-color 150ms ease, box-shadow 150ms ease, transform 80ms ease;
  border-width: 1px;
}
.btn:active { transform: scale(0.98); }
.btn:focus-visible {
  outline: var(--focus-width) solid var(--focus-color);
  outline-offset: 2px;
  box-shadow: none;
}
.btn-sm {
  min-height: 30px;
  padding: 0.3rem 0.64rem;
  font-size: 0.77rem;
  border-radius: 9px;
}
.btn-lg { padding: 0.62rem 1.25rem; font-size: var(--text-md); border-radius: 12px; }

.btn-primary { background: var(--app-primary-2); border-color: var(--app-primary-2); box-shadow: 0 8px 20px rgba(21,92,168,0.15); }
.btn-primary:hover { background: var(--app-primary); border-color: var(--app-primary); }
.btn-secondary { background: #475569; border-color: #475569; }
.btn-secondary:hover { background: #334155; border-color: #334155; }
.btn-success { background: var(--app-success); border-color: var(--app-success); }
.btn-danger { background: var(--app-danger); border-color: var(--app-danger); }

.btn-outline-primary { color: var(--app-primary-2); border-color: #b8c9df; background: var(--app-surface); }
.btn-outline-primary:hover { color: #fff; background: var(--app-primary-2); border-color: var(--app-primary-2); }
.btn-outline-secondary { color: #334155; border-color: var(--app-border-strong); background: var(--app-surface); }
.btn-outline-secondary:hover { background: #0f172a; border-color: #0f172a; color: #fff; }
.btn-outline-danger { color: var(--app-danger); border-color: #fca5a5; background: var(--app-surface); }
.btn-outline-danger:hover { background: var(--app-danger); border-color: var(--app-danger); color: #fff; }

[data-theme="dark"] .btn-outline-primary { color: var(--app-primary-2); border-color: var(--app-border-strong); background: var(--app-surface-2); }
[data-theme="dark"] .btn-outline-secondary { color: var(--app-text); border-color: var(--app-border-strong); background: var(--app-surface-2); }
[data-theme="dark"] .btn-outline-secondary:hover { background: var(--app-surface); color: var(--app-text); border-color: var(--app-border-strong); }

/* ─── 10. CARDS & PANELS ───────────────────────────────────────────────────── */
.card {
  overflow: hidden;
  border: 1px solid var(--app-border);
  border-radius: var(--app-radius);
  background: var(--app-surface);
  box-shadow: var(--app-shadow-sm);
  transition: background 200ms ease, border-color 200ms ease;
}
.card-body { padding: 0.72rem; }
.card h6 {
  color: var(--app-muted);
  font-family: var(--font-mono);
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
}
.card .display-6 {
  font-family: var(--font-display);
  color: var(--app-text);
  font-size: 1.64rem;
  font-weight: 700;
}

.panel {
  padding: 0.74rem;
  border: 1px solid var(--app-border);
  border-radius: var(--app-radius);
  background: var(--app-surface);
  box-shadow: var(--app-shadow-sm);
  transition: background 200ms ease, border-color 200ms ease;
}
.panel-title {
  display: flex; align-items: center; justify-content: space-between;
  gap: 0.55rem;
  margin-bottom: 0.55rem;
}
.panel-title h5 { margin: 0; font-size: var(--text-md); font-weight: 700; }
.panel-title p  { font-size: var(--text-sm); line-height: 1.35; margin: 0; color: var(--app-muted); }

.metric-card {
  position: relative;
  min-height: 88px;
  border: 1px solid var(--app-border);
  border-radius: var(--app-radius-lg);
  background: linear-gradient(180deg, var(--app-surface) 0%, var(--app-surface-2) 100%);
  box-shadow: var(--app-shadow-sm);
  overflow: hidden;
  transition: background 200ms ease, border-color 200ms ease;
}
.metric-card::after {
  content: "";
  position: absolute; right: -22px; top: -28px;
  width: 64px; height: 64px;
  border-radius: 999px;
  background: rgba(61,158,245,0.095);
}
.metric-card .card-body { position: relative; z-index: 1; padding: 0.68rem 0.74rem; }
.metric-label {
  color: var(--app-muted);
  font-family: var(--font-mono);
  font-size: 0.59rem; font-weight: 700; letter-spacing: 0.11em;
  text-transform: uppercase;
}
.metric-value {
  display: block;
  margin: 0.18rem 0 0;
  font-family: var(--font-display);
  font-size: var(--text-kpi);
  line-height: 1.02; font-weight: 800; letter-spacing: -0.055em;
  color: var(--app-text);
}
.metric-note { display: block; margin-top: 0.22rem; font-size: 0.72rem; line-height: 1.2; color: var(--app-muted); }

.compact-list { margin: 0; padding: 0; list-style: none; }
.compact-list li {
  display: flex; justify-content: space-between; gap: 1rem;
  padding: 0.52rem 0;
  border-bottom: 1px solid var(--app-border);
  font-size: var(--text-base);
}
.compact-list li:last-child { border-bottom: 0; }
.compact-list small { color: var(--app-muted); font-size: var(--text-sm); }

.list-group { overflow: hidden; border: 1px solid var(--app-border); border-radius: var(--app-radius); box-shadow: var(--app-shadow-sm); }
.list-group-item { border-color: var(--app-border); padding: 0.72rem 0.9rem; background: var(--app-surface); color: var(--app-text); }

.empty-state {
  padding: 1rem;
  border: 1px dashed var(--app-border-strong);
  border-radius: var(--app-radius);
  color: var(--app-muted);
  background: var(--app-surface-2);
  text-align: center;
  font-size: var(--text-base);
}

/* Dark mode card/panel overrides */
[data-theme="dark"] .card,
[data-theme="dark"] .panel,
[data-theme="dark"] .metric-card,
[data-theme="dark"] .list-group-item { background: var(--app-surface); border-color: var(--app-border); }
[data-theme="dark"] .metric-card { background: linear-gradient(180deg, var(--app-surface) 0%, var(--app-surface-2) 100%); }
[data-theme="dark"] .empty-state { background: var(--app-surface-2); border-color: var(--app-border); }

/* ─── 11. FORMS ────────────────────────────────────────────────────────────── */
.app-content form:not(.search-form):not(.logout-form):not(.row) {
  max-width: 980px;
  padding: 1rem;
  border: 1px solid var(--app-border);
  border-radius: var(--app-radius-lg);
  background: var(--app-surface);
  box-shadow: var(--app-shadow-sm);
}
.app-content form p { margin-bottom: 0.85rem; }

.app-content label {
  display: inline-block;
  margin-bottom: 0.28rem;
  color: #344054;
  font-size: var(--text-sm);
  font-weight: 700;
}
[data-theme="dark"] .app-content label { color: var(--app-text); }

.app-content input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
.app-content select,
.app-content textarea,
.form-control,
.form-select {
  min-height: var(--input-height);
  width: 100%;
  border: 1px solid var(--app-border-strong);
  border-radius: var(--app-radius-sm);
  padding: 0.44rem 0.62rem;
  background: var(--app-surface);
  color: var(--app-text);
  font-size: var(--text-base);
  font-family: var(--font-body);
  box-shadow: none;
  transition: border-color 140ms ease, box-shadow 140ms ease, background 200ms ease;
}
.app-content textarea { min-height: 100px; resize: vertical; }
.form-control-sm, .form-select-sm { min-height: 30px; padding: 0.28rem 0.52rem; font-size: var(--text-sm); border-radius: 8px; }

.app-content input:focus,
.app-content select:focus,
.app-content textarea:focus,
.form-control:focus,
.form-select:focus {
  border-color: var(--app-primary-2);
  box-shadow: 0 0 0 var(--focus-width) var(--focus-color);
  outline: 0;
  background: var(--app-surface);
}

/* Dark mode form inputs */
[data-theme="dark"] .app-content input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]),
[data-theme="dark"] .app-content select,
[data-theme="dark"] .app-content textarea,
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
  background: var(--app-surface-2);
  border-color: var(--app-border-strong);
  color: var(--app-text);
  color-scheme: dark;
}
[data-theme="dark"] .app-content input:focus,
[data-theme="dark"] .app-content select:focus,
[data-theme="dark"] .app-content textarea:focus,
[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus {
  background: var(--app-surface);
  border-color: var(--app-primary-2);
}
[data-theme="dark"] .app-content form:not(.search-form):not(.logout-form):not(.row) {
  background: var(--app-surface);
  border-color: var(--app-border);
}

.helptext, .form-text {
  display: block;
  margin-top: 0.3rem;
  color: var(--app-muted);
  font-size: 0.74rem;
}
.errorlist, .invalid-feedback {
  display: block;
  margin: 0.28rem 0 0;
  padding: 0.5rem 0.72rem;
  border-radius: var(--app-radius-sm);
  color: #991b1b;
  background: var(--app-danger-soft);
  font-size: var(--text-sm);
  list-style: none;
}
[data-theme="dark"] .errorlist, [data-theme="dark"] .invalid-feedback {
  color: #fca5a5;
  background: var(--app-danger-soft);
}

.field-wrap { position: relative; }
.field-wrap .errorlist { margin-top: 0.35rem; }
.required-mark::after { content: " *"; color: var(--app-danger); }

.form-section {
  padding: 0.78rem;
  border: 1px solid var(--app-border);
  border-radius: var(--app-radius);
  background: var(--app-surface);
  margin-bottom: 0.85rem;
  transition: background 200ms ease, border-color 200ms ease;
}
.form-section h5 { margin: 0 0 0.7rem; font-size: 0.94rem; color: var(--app-text); }
[data-theme="dark"] .form-section { background: var(--app-surface); border-color: var(--app-border); }

.clean-row {
  margin-bottom: 0 !important; padding: 0 !important;
  border: 0 !important; border-radius: 0 !important;
  background: transparent !important; box-shadow: none !important;
}

.form-check-wrap {
  display: flex; flex-direction: column; justify-content: center;
}
.form-check-wrap .form-check { min-height: var(--input-height); display: flex; align-items: center; gap: 0.5rem; }
.form-check-wrap label { margin-bottom: 0; }

.form-check-block {
  display: flex; align-items: center;
  gap: 0.5rem; min-height: var(--input-height);
  padding-top: 0.4rem;
}
.form-check-block label { margin: 0; }

.sticky-actions {
  position: sticky; bottom: 0; z-index: 10;
  display: flex; gap: 0.75rem;
  margin-top: 1rem;
  padding: 0.72rem 1rem;
  border: 1px solid var(--app-border);
  border-radius: var(--app-radius-lg);
  background: rgba(255,255,255,0.94);
  box-shadow: var(--app-shadow);
  backdrop-filter: blur(10px);
}
[data-theme="dark"] .sticky-actions { background: rgba(22,27,34,0.94); }

/* Filter row (inline search forms) */
.app-content form.row.g-2,
.app-content form.row.g-3 {
  margin-bottom: 0.72rem !important;
  padding: 0.64rem !important;
  border: 1px solid var(--app-border) !important;
  border-radius: var(--app-radius) !important;
  background: var(--app-surface) !important;
  box-shadow: var(--app-shadow-sm) !important;
}
.app-content .row.g-2:not(form),
.app-content .row.g-3:not(form) {
  --bs-gutter-x: 0.72rem; --bs-gutter-y: 0.72rem;
  margin-bottom: 0.72rem !important;
  padding: 0 !important; border: 0 !important;
  border-radius: 0 !important; background: transparent !important;
  box-shadow: none !important;
}
[data-theme="dark"] .app-content form.row.g-2,
[data-theme="dark"] .app-content form.row.g-3 {
  background: var(--app-surface) !important;
  border-color: var(--app-border) !important;
}

/* ─── 12. TABLES ───────────────────────────────────────────────────────────── */
.table-responsive { border-radius: var(--app-radius); overflow: hidden; }

.app-content table.table {
  width: 100%;
  margin-bottom: 0.72rem;
  border: 1px solid var(--app-border);
  border-collapse: separate;
  border-spacing: 0;
  border-radius: var(--app-radius);
  background: var(--app-surface);
  box-shadow: var(--app-shadow-sm);
  overflow: hidden;
  transition: background 200ms ease, border-color 200ms ease;
}
.table > :not(caption) > * > * {
  padding: 0.5rem 0.64rem;
  border-bottom-color: var(--app-border);
  vertical-align: middle;
  font-size: var(--text-base);
  color: var(--app-text);
  background-color: transparent;
}
.table thead th {
  color: var(--app-muted);
  background: var(--app-surface-2);
  font-family: var(--font-mono);
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--app-border-strong);
  white-space: nowrap;
}
.table thead th.col-num { text-align: right; }
.table td.col-num       { text-align: right; font-variant-numeric: tabular-nums; }
.table tbody tr:last-child td { border-bottom: 0; }
.table-hover > tbody > tr:hover > * { background-color: var(--app-primary-soft) !important; }
.table-striped > tbody > tr:nth-of-type(odd) > * { --bs-table-bg-type: var(--app-surface-2); }
.table-warning > * { background-color: var(--app-warning-soft) !important; }
.table-danger  > * { background-color: var(--app-danger-soft) !important; }
.table-success > * { background-color: var(--app-success-soft) !important; }

/* Dark mode tables */
[data-theme="dark"] .app-content table.table { background: var(--app-surface); border-color: var(--app-border); }
[data-theme="dark"] .table thead th { background: var(--app-surface-2); border-bottom-color: var(--app-border-strong); color: var(--app-muted); }
[data-theme="dark"] .table > :not(caption) > * > * { border-bottom-color: var(--app-border); color: var(--app-text); }
[data-theme="dark"] .table-hover > tbody > tr:hover > * { background-color: var(--app-primary-soft) !important; }
[data-theme="dark"] .table-striped > tbody > tr:nth-of-type(odd) > * { --bs-table-bg-type: rgba(255,255,255,0.025); }

/* ─── 13. BADGES & STATUS ──────────────────────────────────────────────────── */
.badge {
  border-radius: 999px;
  padding: 0.28rem 0.48rem;
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  line-height: 1;
}
.badge.bg-light    { color: #334155 !important; border: 1px solid var(--app-border); background: #f1f5f9 !important; }
.badge.bg-secondary{ background-color: #64748b !important; }
.badge.bg-info     { color: #073b4c !important; background-color: #d7f4ff !important; }
.badge.bg-warning  { color: #7a4b00 !important; background-color: #ffe6a6 !important; }
.badge.bg-success  { background-color: #168454 !important; }
.badge.bg-danger   { background-color: #c2413b !important; }
.badge.bg-primary  { background-color: var(--app-primary-2) !important; }

.badge-soft-warning { color: #7a4b00; background: #fff7e6; border: 1px solid #ffe0a3; border-radius: 999px; padding: 0.28rem 0.48rem; font-size: 0.66rem; font-weight: 800; }
.badge-soft-success { color: #166534; background: #ecfdf3; border: 1px solid #bbf7d0; border-radius: 999px; padding: 0.28rem 0.48rem; font-size: 0.66rem; font-weight: 800; }
.badge-soft-danger  { color: #991b1b; background: #fff1f2; border: 1px solid #fecdd3; border-radius: 999px; padding: 0.28rem 0.48rem; font-size: 0.66rem; font-weight: 800; }
.badge-soft-info    { color: #0c4a6e; background: #e0f2fe; border: 1px solid #bae6fd; border-radius: 999px; padding: 0.28rem 0.48rem; font-size: 0.66rem; font-weight: 800; }

[data-theme="dark"] .badge.bg-light { color: var(--app-text) !important; background: var(--app-surface-2) !important; border-color: var(--app-border); }
[data-theme="dark"] .badge.bg-info  { color: #bae6fd !important; background-color: #0c2f45 !important; }
[data-theme="dark"] .badge.bg-warning { color: #fde68a !important; background-color: #3d2200 !important; }
[data-theme="dark"] .badge-soft-warning { color: #fde68a; background: #271c09; border-color: #4d3200; }
[data-theme="dark"] .badge-soft-success { color: #86efac; background: #0f2419; border-color: #166534; }
[data-theme="dark"] .badge-soft-danger  { color: #fca5a5; background: #2a0f0f; border-color: #7f1d1d; }
[data-theme="dark"] .badge-soft-info    { color: #bae6fd; background: #0c2f45; border-color: #0369a1; }

.status-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--app-border-strong); display: inline-block; }
.status-dot.ok      { background: var(--app-success); }
.status-dot.warning { background: var(--app-warning); }
.status-dot.error   { background: var(--app-danger); }
/* ─── 14. DASHBOARD & KPI COMPONENTS ───────────────────────────────────────── */
.preset-strip {
  display: flex; align-items: center; flex-wrap: wrap;
  gap: 0.5rem; margin-bottom: 0.9rem; padding: 0.72rem;
  border: 1px solid var(--app-border); border-radius: var(--app-radius);
  background: var(--app-surface); box-shadow: var(--app-shadow-sm);
}
[data-theme="dark"] .preset-strip { background: var(--app-surface); border-color: var(--app-border); }
.preset-chip {
  border: 1px solid #b8c9df; border-radius: 999px;
  padding: 0.38rem 0.7rem;
  color: var(--app-primary-2); background: var(--app-surface);
  font-weight: 800; font-size: var(--text-sm); white-space: nowrap;
  cursor: pointer; transition: background 120ms ease, color 120ms ease;
}
.preset-chip:hover, .preset-chip.active {
  color: #fff; background: var(--app-primary-2); border-color: var(--app-primary-2);
}
[data-theme="dark"] .preset-chip { border-color: var(--app-border-strong); background: var(--app-surface-2); }
.preset-help { color: var(--app-muted); font-size: var(--text-sm); }

/* Service command centre KPIs */
.service-hero {
  display: flex; align-items: flex-start;
  justify-content: space-between;
  gap: 1rem; flex-wrap: wrap;
}

.command-strip,
.service-filter-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(96px, 1fr));
  gap: 0.52rem;
  margin-bottom: 0.85rem;
}
.command-strip { grid-template-columns: repeat(auto-fill, minmax(88px, 1fr)); }

.command-kpi,
.service-filter-kpis a {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 0.22rem;
  padding: 0.58rem 0.5rem;
  border: 1px solid var(--app-border);
  border-radius: var(--app-radius);
  background: var(--app-surface);
  color: var(--app-text);
  text-align: center;
  text-decoration: none;
  box-shadow: var(--app-shadow-xs);
  transition: border-color 140ms, background 140ms, box-shadow 140ms, transform 80ms;
  cursor: pointer;
}
.service-filter-kpis a { grid-column: auto; }
.command-kpi:hover, .service-filter-kpis a:hover {
  border-color: var(--app-primary-2);
  background: var(--app-primary-soft);
  box-shadow: var(--app-shadow-sm);
  transform: translateY(-1px);
  color: var(--app-text);
}

.command-kpi span, .service-filter-kpis span {
  color: var(--app-muted);
  font-family: var(--font-mono);
  font-size: 0.6rem; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; white-space: nowrap;
}
.command-kpi strong, .service-filter-kpis strong {
  display: block;
  font-family: var(--font-display);
  font-size: 1.32rem; font-weight: 800; letter-spacing: -0.04em;
  color: var(--app-text); line-height: 1.0;
}
.command-kpi small { color: var(--app-muted); font-size: 0.58rem; line-height: 1.2; text-align: center; }
.command-kpi.warning { border-color: #f6d860; background: var(--app-warning-soft); }
.command-kpi.danger  { border-color: #fca5a5; background: var(--app-danger-soft); }
.command-kpi.warning strong, .command-kpi.warning span { color: #7a4b00; }
.command-kpi.danger strong, .command-kpi.danger span   { color: #991b1b; }

[data-theme="dark"] .command-kpi,
[data-theme="dark"] .service-filter-kpis a { background: var(--app-surface); border-color: var(--app-border); }
[data-theme="dark"] .command-kpi.warning { background: var(--app-warning-soft); border-color: #4d3200; }
[data-theme="dark"] .command-kpi.warning strong, [data-theme="dark"] .command-kpi.warning span { color: #fde68a; }
[data-theme="dark"] .command-kpi.danger  { background: var(--app-danger-soft);  border-color: #7f1d1d; }
[data-theme="dark"] .command-kpi.danger strong,  [data-theme="dark"] .command-kpi.danger span  { color: #fca5a5; }

.service-command-centre .command-strip,
.workshop-board-screen .command-strip,
.field-visit-screen .command-strip,
.operations-hub-screen .command-strip {
  grid-template-columns: repeat(auto-fill, minmax(84px, 1fr));
}
.service-command-centre .command-kpi strong,
.workshop-board-screen .command-kpi strong,
.field-visit-screen .command-kpi strong,
.operations-hub-screen .command-kpi strong { font-size: 1.4rem; }

.dashboard-screen > .row.g-3.mb-4 { margin-bottom: 0.72rem !important; }
.dashboard-screen .metric-card { min-height: 84px; }
.dashboard-screen .metric-value { font-size: 1.5rem; }
.dashboard-screen .panel { min-height: 0; }
.dashboard-screen .row.g-3.mt-1 { margin-top: 0 !important; }

/* App tabs */
.app-tabs {
  gap: 0.42rem; border-bottom: 1px solid var(--app-border);
  padding-bottom: 0.75rem; flex-wrap: wrap;
}
.app-tabs .nav-link {
  border-radius: 999px; color: var(--app-muted);
  background: var(--app-surface-2); font-weight: 700;
  font-size: var(--text-sm); padding: 0.35rem 0.72rem;
  border: 1px solid var(--app-border);
}
.app-tabs .nav-link.active { color: #fff; background: var(--app-primary-2); border-color: var(--app-primary-2); }
.app-tabs .nav-link:focus-visible { outline: var(--focus-width) solid var(--focus-color); outline-offset: 2px; }
[data-theme="dark"] .app-tabs .nav-link { background: var(--app-surface-2); border-color: var(--app-border); color: var(--app-muted); }
[data-theme="dark"] .app-tabs .nav-link.active { color: var(--app-sidebar); background: var(--app-primary-2); }

/* ─── 15. MODULE-SPECIFIC ──────────────────────────────────────────────────── */

/* Settings */
.settings-form {
  max-width: none !important; padding: 0 !important; border: 0 !important;
  border-radius: 0 !important; background: transparent !important; box-shadow: none !important;
}
.settings-grid { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 1rem; align-items: start; }
.settings-panel, .settings-preview-panel { padding: 1rem; }
.settings-summary-card {
  padding: 0.72rem 0.88rem;
  border: 1px solid var(--app-border); border-radius: var(--app-radius);
  background: var(--app-surface); box-shadow: var(--app-shadow-sm);
}
.summary-label { display: block; color: var(--app-muted); font-family: var(--font-mono); font-size: 0.6rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; }
.settings-summary-card strong { display: block; margin-top: 0.2rem; color: var(--app-primary); font-size: 1.2rem; letter-spacing: -0.03em; }
.settings-checklist { margin-top: 1rem; display: grid; gap: 0.5rem; }
.settings-checklist div { display: flex; align-items: center; gap: 0.5rem; color: #334155; font-weight: 700; font-size: var(--text-base); }
[data-theme="dark"] .settings-checklist div { color: var(--app-text); }

/* Customer / Detail views */
.detail-list { display: grid; grid-template-columns: minmax(110px, 0.45fr) 1fr; gap: 0.5rem 0.78rem; margin: 0; }
.detail-list dt { color: var(--app-muted); font-family: var(--font-mono); font-size: 0.66rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; }
.detail-list dd { margin: 0; color: var(--app-text); font-size: var(--text-base); }
.contact-card, .site-card {
  padding: 0.85rem;
  border: 1px solid var(--app-border); border-radius: var(--app-radius);
  background: var(--app-surface); box-shadow: var(--app-shadow-xs);
}
[data-theme="dark"] .contact-card, [data-theme="dark"] .site-card { background: var(--app-surface-2); }

.timeline-list li { align-items: flex-start; }
.timeline-list small { display: block; margin-top: 0.28rem; }
.inner-panel { box-shadow: none; }
.no-panel-row { padding: 0 !important; border: 0 !important; background: transparent !important; box-shadow: none !important; }

/* Finance subnav */
.finance-subnav {
  display: flex; gap: 0.38rem; padding: 0.38rem;
  overflow-x: auto; border: 1px solid var(--app-border);
  border-radius: var(--app-radius-lg);
  background: var(--app-surface); box-shadow: var(--app-shadow-sm);
  margin-bottom: 0.85rem; scrollbar-width: none;
}
.finance-subnav::-webkit-scrollbar { display: none; }
.finance-subnav-link {
  flex: 0 0 auto; display: inline-flex; align-items: center;
  min-height: 30px; padding: 0.38rem 0.68rem; border-radius: 999px;
  color: var(--app-muted); font-size: var(--text-sm); font-weight: 700; white-space: nowrap;
  transition: background 120ms, color 120ms;
}
.finance-subnav-link:hover { color: var(--app-primary); background: var(--app-primary-soft); }
.finance-subnav-link.active { color: #fff; background: linear-gradient(135deg, var(--app-primary-2), var(--app-primary)); box-shadow: 0 8px 20px rgba(20,85,159,0.16); }
[data-theme="dark"] .finance-subnav { background: var(--app-surface); border-color: var(--app-border); }
[data-theme="dark"] .finance-subnav-link.active { color: var(--app-sidebar); }

.finance-workflow-board, .finance-handoff-panel {
  border: 1px solid var(--app-border); border-radius: var(--app-radius);
  background: var(--app-surface); box-shadow: var(--app-shadow-sm);
}
.finance-workflow-board { padding: 0.78rem; }
.finance-workflow-header { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 0.68rem; }
.finance-workflow-header strong, .finance-handoff-panel strong { display: block; color: var(--app-text); font-size: 0.9rem; line-height: 1.25; }
.finance-workflow-header span { display: block; margin-top: 0.14rem; color: var(--app-muted); font-size: var(--text-sm); }

/* Quotation builder */
.quote-builder-form { max-width: none !important; }
.section-title-row { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; margin-bottom: 0.85rem; }
.section-title-row h5 { margin: 0; }
.quote-line-stack { display: grid; gap: 0.75rem; }
.quote-line-card {
  padding: 0.88rem; border: 1px solid var(--app-border); border-radius: var(--app-radius);
  background: var(--app-surface); box-shadow: var(--app-shadow-xs);
}
[data-theme="dark"] .quote-line-card { background: var(--app-surface); }
.quote-grand-total { color: var(--app-text); font-size: clamp(1.75rem, 3.5vw, 2.6rem); font-weight: 900; letter-spacing: -0.06em; }
.quote-lines-table td, .quote-lines-table th { white-space: nowrap; }
.quote-lines-table td:first-child, .quote-lines-table th:first-child { min-width: 240px; white-space: normal; }
.quote-action-grid form { max-width: none !important; padding: 0 !important; border: 0 !important; border-radius: 0 !important; background: transparent !important; box-shadow: none !important; }
.delete-line-check { color: var(--app-danger); font-weight: 700; }

/* Knowledge / AI Hub */
.knowledge-result-card, .global-result-card, .answer-panel,
.management-brief-grid .panel, .risk-radar-grid .panel, .service-brain-grid .panel {
  transition: border-color 150ms, box-shadow 150ms, transform 150ms;
}
.knowledge-result-card:hover, .global-result-card:hover,
.management-brief-grid .panel:hover, .risk-radar-grid .panel:hover,
.service-brain-grid .panel:hover {
  border-color: rgba(21,92,168,0.28);
  box-shadow: 0 12px 30px rgba(16,24,40,0.072);
  transform: translateY(-1px);
}
[data-theme="dark"] .knowledge-result-card:hover, [data-theme="dark"] .global-result-card:hover,
[data-theme="dark"] .management-brief-grid .panel:hover {
  border-color: rgba(147,197,253,0.25);
  box-shadow: 0 12px 30px rgba(0,0,0,0.30);
}
.global-search-panel .row.g-3, .ask-brain-form .row.g-3,
.app-content--knowledge form.panel .row.g-3 { align-items: end; }
.guardrail-event-row, .quality-review-row { border-left: 3px solid transparent; }
.guardrail-event-row.is-open, .quality-review-row.is-pending { border-left-color: #f59e0b; }
.guardrail-event-row.is-high { border-left-color: #dc2626; }

/* Sidebar section control variant */
.sidebar-section--controls {
  background: linear-gradient(180deg, rgba(21,92,168,0.12), rgba(255,255,255,0.025));
  border-color: rgba(97,165,255,0.17);
}
.sidebar-section--controls .nav-section-label { color: rgba(191,219,254,0.74); }
.sidebar-section--controls .app-nav-link::before { background: rgba(147,197,253,0.72); }

/* Page header accent for specific apps */
.app-content--knowledge .page-header,
.app-content--core .page-header,
.app-content--dashboard .page-header { overflow: hidden; position: relative; }

/* Business card preview (settings) */
.business-card-preview {
  padding: 1rem; border: 1px solid var(--app-border); border-radius: var(--app-radius);
  background: linear-gradient(180deg, var(--app-surface), var(--app-surface-2));
}
.business-logo-preview, .business-logo-placeholder { width: 60px; height: 60px; margin-bottom: 0.72rem; border-radius: var(--app-radius); }
.business-logo-preview { object-fit: contain; border: 1px solid var(--app-border); background: #fff; }
.business-logo-placeholder { display: grid; place-items: center; color: #fff; background: var(--app-primary-2); font-weight: 800; font-size: 1.2rem; }
.business-card-preview h6 { margin-bottom: 0.28rem; color: var(--app-text); font-size: 0.96rem; text-transform: none; letter-spacing: -0.01em; }
.business-card-preview p  { color: var(--app-muted); font-size: var(--text-base); }

/* ─── 16. LOGIN PAGE ───────────────────────────────────────────────────────── */
body.login-page {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  margin: 0;
  background:
    radial-gradient(circle at 18% 22%, rgba(61,158,245,0.14), transparent 30rem),
    linear-gradient(145deg, #080d17 0%, #0c1e3b 55%, #101827 100%);
  font-family: var(--font-body);
  font-size: 14px;
  -webkit-font-smoothing: antialiased;
}
.login-shell {
  width: 100%;
  max-width: 420px;
  padding: 1.25rem;
}
.login-brand {
  display: flex; flex-direction: column; align-items: center;
  gap: 0.7rem; margin-bottom: 2rem; text-align: center;
}
.login-brand-mark {
  display: grid; place-items: center;
  width: 54px; height: 54px; border-radius: 16px;
  background: linear-gradient(135deg, #fff 0%, #dbeafe 100%);
  color: #0f3d73; font-weight: 800; font-size: 1.1rem;
  box-shadow: 0 12px 32px rgba(0,0,0,0.28);
  overflow: hidden;
}
.login-brand-mark img { width: 100%; height: 100%; object-fit: contain; border-radius: 14px; padding: 3px; background: #fff; }
.login-brand-name { color: #fff; font-family: var(--font-display); font-size: 1.22rem; font-weight: 700; letter-spacing: -0.025em; margin: 0; }
.login-brand-sub  { color: rgba(255,255,255,0.52); font-size: 0.8rem; margin: 0; }
.login-card {
  padding: 1.5rem;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 20px;
  background: rgba(255,255,255,0.04);
  backdrop-filter: blur(12px);
  box-shadow: 0 28px 72px rgba(0,0,0,0.42);
}
.login-card h2 { color: #fff; font-size: 1.1rem; font-weight: 700; margin-bottom: 0.22rem; }
.login-card .login-sub { color: rgba(255,255,255,0.52); font-size: 0.82rem; margin-bottom: 1.35rem; }
.login-card label {
  display: block; margin-bottom: 0.3rem;
  color: rgba(255,255,255,0.72); font-size: 0.8rem; font-weight: 700;
}
.login-card .form-control {
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 10px;
  color: #fff; font-size: 0.9rem; min-height: 42px;
}
.login-card .form-control::placeholder { color: rgba(255,255,255,0.35); }
.login-card .form-control:focus {
  background: rgba(255,255,255,0.11);
  border-color: rgba(147,197,253,0.55);
  box-shadow: 0 0 0 3px rgba(147,197,253,0.18);
  color: #fff;
}
.login-card .field-mb { margin-bottom: 1rem; }
.login-card .btn-login {
  width: 100%; padding: 0.62rem; font-size: 0.9rem; font-weight: 800;
  background: linear-gradient(135deg, #155ca8, #0c3566);
  border: 0; border-radius: 10px; color: #fff;
  box-shadow: 0 10px 28px rgba(21,92,168,0.30);
  transition: box-shadow 150ms, transform 80ms;
  cursor: pointer; margin-top: 0.35rem;
}
.login-card .btn-login:hover { box-shadow: 0 14px 36px rgba(21,92,168,0.42); }
.login-card .btn-login:active { transform: scale(0.99); }
.login-card .btn-login:focus-visible { outline: 3px solid rgba(147,197,253,0.55); outline-offset: 2px; }
.login-error {
  padding: 0.6rem 0.8rem; margin-bottom: 1rem;
  border: 1px solid rgba(248,113,113,0.28);
  border-radius: 10px; background: rgba(248,113,113,0.10);
  color: #fca5a5; font-size: 0.82rem; font-weight: 600;
}
.login-footer {
  margin-top: 1.5rem; text-align: center;
  color: rgba(255,255,255,0.3); font-size: 0.7rem;
}
.login-footer a { color: rgba(255,255,255,0.45); }
.login-footer a:hover { color: rgba(255,255,255,0.7); }

/* ─── 17. ACCESSIBILITY ────────────────────────────────────────────────────── */
.skip-link {
  position: fixed; left: 0.75rem; top: 0.5rem; z-index: 2000;
  transform: translateY(-140%);
  padding: 0.48rem 0.7rem; border-radius: 999px;
  color: #fff; background: var(--app-primary-2);
  font-weight: 800; font-size: 0.82rem;
  box-shadow: var(--app-shadow);
  transition: transform 140ms ease;
  text-decoration: none;
}
.skip-link:focus { color: #fff; transform: translateY(0); outline: 3px solid rgba(255,255,255,0.65); outline-offset: 2px; }

/* Global focus-visible — prevents focus rings on mouse clicks */
:focus:not(:focus-visible) { outline: none; box-shadow: none; }
:focus-visible { outline: var(--focus-width) solid var(--focus-color); outline-offset: 2px; }

/* Override Bootstrap's focus which removes box-shadow */
.btn:focus-visible,
.form-control:focus,
.form-select:focus,
.app-nav-link:focus-visible,
.preset-chip:focus-visible,
.finance-subnav-link:focus-visible,
.app-tabs .nav-link:focus-visible {
  outline: var(--focus-width) solid var(--focus-color);
  outline-offset: 2px;
}

/* ─── 18. PRINT ─────────────────────────────────────────────────────────────── */
@media print {
  .app-topbar, .app-sidebar, .sidebar-backdrop,
  .app-footer-credit, .page-header .btn, .panel-title .btn, .sticky-actions,
  .finance-subnav, .preset-strip { display: none !important; }
  .app-shell { padding-top: 0; display: block; }
  .app-content { width: 100%; margin-left: 0; padding: 0; }
  body.app-body { background: #fff; color: #000; font-size: 11px; }
  .panel, .card, .metric-card, .table { box-shadow: none !important; break-inside: avoid; }
  .table { border: 1px solid #ccc; }
  a { color: #000; text-decoration: none; }
  .badge { border: 1px solid #ccc; }
}

/* ─── 19. RESPONSIVE ────────────────────────────────────────────────────────── */
@media (max-width: 1180px) {
  :root { --sidebar-width: 226px; }
  .search-form { width: min(360px, 34vw); }
  .topbar-left { min-width: 198px; }
  .settings-grid { grid-template-columns: 1fr; }
}

@media (max-width: 991px) {
  :root { --topbar-height: 54px; }

  .sidebar-toggle { display: flex; align-items: center; justify-content: center; }
  .brand-copy small { display: none; }
  .topbar-left { min-width: auto; }
  .search-form { display: none; }
  .account-area { gap: 0.32rem; }
  .topbar-utility-link { display: none; }

  .app-sidebar {
    transform: translateX(-105%);
    transition: transform 180ms ease;
    z-index: 1050;
    width: min(86vw, 310px);
  }
  .sidebar-open .app-sidebar { transform: translateX(0); }

  .sidebar-backdrop {
    position: fixed;
    inset: var(--topbar-height) 0 0 0;
    z-index: 1045;
    display: none;
    background: rgba(15, 23, 42, 0.52);
  }
  .sidebar-open .sidebar-backdrop { display: block; }

  .app-content { width: 100%; margin-left: 0; padding: 0.68rem 0.65rem 1.35rem; }

  .page-header,
  .app-content > .d-flex.justify-content-between.align-items-center.mb-3,
  .app-content > .d-flex.justify-content-between.align-items-center.mb-4,
  .app-content .container-fluid > .d-flex.justify-content-between.align-items-center.mb-4 {
    flex-direction: column;
    align-items: flex-start;
    padding: 0.68rem;
    gap: 0.6rem;
  }
  .page-header .d-flex,
  .app-content .container-fluid > .d-flex.justify-content-between.align-items-center.mb-4 > .d-flex { width: 100%; }
  .page-header .btn,
  .app-content .container-fluid > .d-flex.justify-content-between.align-items-center.mb-4 .btn { flex: 1 1 auto; }

  .app-content table.table { display: block; overflow-x: auto; white-space: nowrap; -webkit-overflow-scrolling: touch; }
  .app-content table.table td:first-child,
  .app-content table.table th:first-child { white-space: normal; min-width: 160px; }

  .command-strip { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .service-filter-kpis { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .command-kpi { padding: 0.48rem 0.4rem; }
  .command-kpi strong, .service-filter-kpis strong { font-size: 1.18rem; }

  .section-title-row { flex-direction: column; }
  .detail-list { grid-template-columns: minmax(90px, 0.4fr) 1fr; }
  .panel-title { align-items: flex-start; }

  .app-footer-credit { display: flex; }
  .sticky-actions { flex-direction: column; }
  .preset-strip { align-items: stretch; }

  @media (prefers-color-scheme: dark) {
    .app-sidebar details.sidebar-section:not([open]) .app-nav-link { display: none; }
  }
  .app-sidebar details.sidebar-section:not([open]) .app-nav-link { display: none; }

  .company-brain-grid, .management-brief-grid,
  .risk-radar-grid, .service-brain-grid { gap: 0.72rem; }
}

@media (max-width: 768px) {
  .command-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .settings-grid { grid-template-columns: 1fr; }
}

@media (max-width: 575px) {
  body.app-body { font-size: 13.5px; }
  .app-topbar { padding: 0 0.56rem; }
  .brand-mark { width: 32px; height: 32px; }
  .brand-copy strong { font-size: 0.82rem; }
  .account-area { gap: 0.28rem; }
  .logout-form .btn { padding-inline: 0.45rem; }
  .page-eyebrow { font-size: 0.56rem; letter-spacing: 0.15em; }
  .page-header h1, .page-header h2,
  .app-content .container-fluid > .d-flex.justify-content-between.align-items-center.mb-4 h1,
  .app-content > h2:first-child { font-size: 1.14rem; }
  .metric-card { min-height: 78px; }
  .metric-value { font-size: 1.3rem; }
  .metric-note { font-size: 0.68rem; }
  .panel { padding: 0.66rem; }
  .table > :not(caption) > * > * { padding: 0.42rem 0.52rem; font-size: 0.8rem; }
  .command-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.4rem; }
  .command-kpi strong { font-size: 1.1rem; }
  .detail-list { grid-template-columns: 1fr; }
  .preset-chip { flex: 1 1 42%; }
  .login-shell { padding: 0.85rem; }
  .login-card { padding: 1.15rem; }
}

/* =============================================================================
   2026-06 Frontend standardization pass
   Purpose: normalize older templates and newer module screens under one compact
   business-app layer without changing backend logic.
   ============================================================================= */

/* Global density + spacing normalization */
body[data-ui-density="compact"] {
  --topbar-height: 52px;
  --sidebar-width: 232px;
  --input-height: 34px;
  --text-base: 0.86rem;
  --text-sm: 0.76rem;
  --text-xs: 0.66rem;
}

.app-content > * + * { margin-top: 0.75rem; }
.app-content .mb-4 { margin-bottom: 0.82rem !important; }
.app-content .mb-3 { margin-bottom: 0.68rem !important; }
.app-content .mt-4 { margin-top: 0.82rem !important; }
.app-content .mt-3 { margin-top: 0.68rem !important; }
.app-content .g-4 { --bs-gutter-x: 0.82rem; --bs-gutter-y: 0.82rem; }
.app-content .g-3 { --bs-gutter-x: 0.72rem; --bs-gutter-y: 0.72rem; }
.app-content .g-2 { --bs-gutter-x: 0.52rem; --bs-gutter-y: 0.52rem; }

/* Page headers: support both explicit page-header and older mb-4 header blocks */
.service-hero,
.compact-page-header,
.service-page-header,
.brain-page-header,
.app-content .container-fluid > .mb-4:has(.page-eyebrow),
.app-content .container-fluid > .mb-3:has(.page-eyebrow) {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.72rem !important;
  padding: 0.68rem 0.78rem;
  border: 1px solid var(--app-border);
  border-radius: var(--app-radius-lg);
  background: var(--app-surface);
  box-shadow: var(--app-shadow-sm);
}
.service-hero > div:first-child,
.compact-page-header > div:first-child,
.service-page-header > div:first-child,
.brain-page-header > div:first-child { min-width: 0; }
.page-shell { display: grid; gap: 0.72rem; }
.app-content h1.h3,
.app-content h2.h3,
.app-content .h3 { font-size: clamp(1.12rem, 1.6vw, 1.42rem); letter-spacing: -0.035em; }
.app-content h5,
.app-content .h5 { font-size: 0.96rem; }
.app-content p { color: var(--app-text); }
.app-content small,
.app-content .small { color: var(--app-muted); font-size: var(--text-sm); }

/* Utility classes replacing inline styles */
.form-plain,
.app-content .form-plain,
.app-content form.form-plain,
.app-content form.d-inline,
.app-content form.btn-group,
.app-content .btn-group form {
  max-width: none !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}
.min-w-110 { min-width: 110px; }
.min-w-120 { min-width: 120px; }
.min-w-220 { min-width: 220px; }
.min-w-260 { min-width: 260px; }
.w-90 { width: 90px; }
.w-120 { width: 120px; }
.sticky-review-panel { position: sticky; top: calc(var(--topbar-height) + 16px); }

/* Cards, metrics, and older aliases */
.panel-card,
.form-panel,
.filter-bar,
.mini-card,
.kpi-card {
  border: 1px solid var(--app-border);
  border-radius: var(--app-radius);
  background: var(--app-surface);
  box-shadow: var(--app-shadow-sm);
}
.panel-card,
.form-panel,
.filter-bar,
.mini-card { padding: 0.74rem; }
.kpi-card {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 82px;
  padding: 0.68rem 0.74rem;
  overflow: hidden;
}
.kpi-card span,
.stat-card .small,
.stat-card .text-muted {
  color: var(--app-muted) !important;
  font-family: var(--font-mono);
  font-size: 0.6rem !important;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
}
.kpi-card strong,
.stat-card .fs-3,
.stat-card .fs-4,
.stat-card .fs-5,
.stat-card .fs-6 {
  display: block;
  margin-top: 0.16rem;
  color: var(--app-text);
  font-family: var(--font-display);
  font-size: clamp(1rem, 1.7vw, 1.38rem) !important;
  font-weight: 800 !important;
  letter-spacing: -0.045em;
  line-height: 1.05;
}
.kpi-card small { margin-top: 0.16rem; color: var(--app-muted); font-size: 0.7rem; line-height: 1.25; }
.stat-card { min-height: 82px; }
.stat-card .card-body { padding: 0.68rem 0.74rem; }
.mini-card h3 { margin-bottom: 0.32rem; font-size: 0.98rem; }
.mini-card p { margin-bottom: 0; color: var(--app-muted); font-size: var(--text-sm); }
.filter-bar { margin-bottom: 0.72rem; }

/* Panels */
.panel h5:first-child,
.panel > h5:first-child { margin-bottom: 0.55rem; }
.panel-title { min-height: 30px; }
.panel-title .btn { flex-shrink: 0; }
.inner-panel { border: 1px solid var(--app-border); border-radius: var(--app-radius); background: var(--app-surface-2); }
.border,
.rounded,
.rounded-4 { border-color: var(--app-border) !important; }
.bg-white { background-color: var(--app-surface) !important; }

/* Forms: compact, scan-friendly defaults */
.app-content form:not(.search-form):not(.logout-form):not(.row):not(.form-plain) {
  max-width: min(1040px, 100%);
}
.app-content form.panel,
.app-content form.form-panel,
.app-content form.panel-card {
  max-width: min(1040px, 100%) !important;
}
.app-content form p {
  display: flex;
  flex-direction: column;
  gap: 0.18rem;
  margin: 0 0 0.64rem;
}
.app-content form p:last-child { margin-bottom: 0; }
.form-grid-two {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.72rem;
}
.form-grid-two > p,
.form-grid-two > .field-wrap { margin-bottom: 0 !important; }
.form-grid-two .grid-full { grid-column: 1 / -1; }
.form-actions,
.app-content form > button:last-child,
.app-content form > .btn:last-child { margin-top: 0.2rem; }
.field-wrap { min-width: 0; }
.app-content .form-label,
.app-content label {
  color: var(--app-text);
  font-size: var(--text-sm);
  line-height: 1.2;
}
.app-content input[type="file"] { padding: 0.35rem 0.5rem; }
.app-content input[type="checkbox"],
.app-content input[type="radio"],
.form-check-input {
  width: 1rem;
  height: 1rem;
  margin-top: 0;
  border-color: var(--app-border-strong);
  cursor: pointer;
}
.form-check { display: flex; align-items: center; gap: 0.42rem; min-height: 1.5rem; padding-left: 0; }
.form-check .form-check-input { float: none; margin-left: 0; }
.form-check-label { margin: 0 !important; font-size: var(--text-sm); }
.app-content input[aria-invalid="true"],
.app-content select[aria-invalid="true"],
.app-content textarea[aria-invalid="true"] { border-color: var(--app-danger); }
.required-mark::after,
label.is-required::after { content: " *"; color: var(--app-danger); font-weight: 800; }

/* Tables: compact business data tables */
.table-responsive {
  width: 100%;
  border: 1px solid var(--app-border);
  border-radius: var(--app-radius);
  background: var(--app-surface);
  box-shadow: var(--app-shadow-sm);
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}
.table-responsive > .table { border: 0 !important; border-radius: 0 !important; box-shadow: none !important; margin-bottom: 0 !important; }
.app-content table.table { font-variant-numeric: tabular-nums; }
.table > :not(caption) > * > * { padding: 0.42rem 0.58rem; }
.table.table-sm > :not(caption) > * > * { padding: 0.36rem 0.52rem; }
.table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  box-shadow: inset 0 -1px 0 var(--app-border-strong);
}
.table td.text-end,
.table th.text-end,
.table .is-numeric,
.table .num-col,
.table .col-num,
.table .money-col,
.table .amount-col {
  text-align: right !important;
  font-variant-numeric: tabular-nums;
}
.table th:last-child:empty,
.table td:last-child:has(.btn),
.table td.actions,
.table .action-cell { width: 1%; white-space: nowrap; text-align: right; }
.table .btn-sm { min-height: 26px; padding: 0.22rem 0.5rem; font-size: 0.72rem; }
.table small { line-height: 1.25; }
.table caption { caption-side: top; padding: 0.45rem 0.58rem; color: var(--app-muted); font-size: var(--text-sm); }

/* Status flow and compact lists */
.status-flow-list { display: grid; gap: 0.42rem; }
.status-flow-row,
.status-flow-list > div,
.meta-list > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.48rem 0;
  border-bottom: 1px solid var(--app-border);
}
.status-flow-list > div:last-child,
.meta-list > div:last-child { border-bottom: 0; }
.meta-list { display: grid; gap: 0.1rem; }
.detail-list-wide { grid-template-columns: minmax(140px, 0.36fr) 1fr; }

/* Business settings accordion */
.settings-accordion-panel {
  border: 1px solid var(--app-border);
  border-radius: var(--app-radius);
  background: var(--app-surface);
  box-shadow: var(--app-shadow-xs);
  overflow: hidden;
}
.settings-accordion-panel + .settings-accordion-panel { margin-top: 0.62rem; }
.settings-section-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.68rem 0.78rem;
  color: var(--app-text);
  cursor: pointer;
  list-style: none;
}
.settings-section-summary::-webkit-details-marker { display: none; }
.settings-section-summary::after { content: "+"; color: var(--app-muted); font-weight: 800; }
.settings-accordion-panel[open] > .settings-section-summary::after { content: "−"; }
.settings-section-body { padding: 0 0.78rem 0.78rem; }

/* Bootstrap component dark-mode fixes */
[data-theme="dark"] .table-responsive,
[data-theme="dark"] .panel-card,
[data-theme="dark"] .form-panel,
[data-theme="dark"] .filter-bar,
[data-theme="dark"] .mini-card,
[data-theme="dark"] .kpi-card,
[data-theme="dark"] .settings-accordion-panel,
[data-theme="dark"] .service-hero,
[data-theme="dark"] .compact-page-header,
[data-theme="dark"] .service-page-header,
[data-theme="dark"] .brain-page-header,
[data-theme="dark"] .app-content .container-fluid > .mb-4:has(.page-eyebrow),
[data-theme="dark"] .app-content .container-fluid > .mb-3:has(.page-eyebrow) {
  background: var(--app-surface);
  border-color: var(--app-border);
}
[data-theme="dark"] .inner-panel,
[data-theme="dark"] .table-light > * { background: var(--app-surface-2) !important; color: var(--app-text) !important; }
[data-theme="dark"] .bg-white { background-color: var(--app-surface) !important; }
[data-theme="dark"] .modal-content,
[data-theme="dark"] .dropdown-menu,
[data-theme="dark"] .popover {
  color: var(--app-text);
  background: var(--app-surface);
  border-color: var(--app-border);
}
[data-theme="dark"] .dropdown-item { color: var(--app-text); }
[data-theme="dark"] .dropdown-item:hover,
[data-theme="dark"] .dropdown-item:focus { color: var(--app-text); background: var(--app-surface-2); }
[data-theme="dark"] .alert { border-color: var(--app-border); }
[data-theme="dark"] .alert-success { color: #86efac; background: #0f2419; }
[data-theme="dark"] .alert-warning { color: #fde68a; background: #271c09; }
[data-theme="dark"] .alert-danger { color: #fca5a5; background: #2a0f0f; }
[data-theme="dark"] .alert-info { color: #bae6fd; background: #0c2f45; }
[data-theme="dark"] .page-link { color: var(--app-link); background: var(--app-surface); border-color: var(--app-border); }
[data-theme="dark"] .page-item.active .page-link { color: #06101f; background: var(--app-primary-2); border-color: var(--app-primary-2); }
[data-theme="dark"] .btn-close { filter: invert(1) grayscale(100%) brightness(180%); }
[data-theme="dark"] .text-bg-light { color: var(--app-text) !important; background: var(--app-surface-2) !important; }
[data-theme="dark"] .text-bg-dark { color: #fff !important; background: #020617 !important; }

/* Responsive audit breakpoints */
@media (max-width: 1440px) {
  .app-content { padding-left: 0.9rem; padding-right: 0.9rem; }
}

@media (max-width: 1024px) {
  body[data-ui-density="compact"] { --sidebar-width: 224px; }
  .brand-copy small { display: none; }
  .user-meta strong { max-width: 96px; }
  .app-content .container-fluid > .mb-4:has(.page-eyebrow),
  .app-content .container-fluid > .mb-3:has(.page-eyebrow) { flex-wrap: wrap; }
}

@media (max-width: 768px) {
  .service-hero,
  .compact-page-header,
  .service-page-header,
  .brain-page-header,
  .app-content .container-fluid > .mb-4:has(.page-eyebrow),
  .app-content .container-fluid > .mb-3:has(.page-eyebrow) {
    flex-direction: column;
    align-items: stretch;
    padding: 0.64rem;
  }
  .service-hero .d-flex,
  .compact-page-header .d-flex,
  .service-page-header .d-flex,
  .brain-page-header .d-flex { width: 100%; }
  .service-hero .btn,
  .compact-page-header .btn,
  .service-page-header .btn,
  .brain-page-header .btn { flex: 1 1 auto; }
  .form-grid-two { grid-template-columns: 1fr; }
  .table-responsive { border-radius: 10px; }
  .table-responsive > .table { min-width: 720px; }
  .sticky-review-panel { position: static; }
  .settings-section-body { padding: 0 0.64rem 0.64rem; }
}

@media (max-width: 390px) {
  body[data-ui-density="compact"] { --topbar-height: 50px; }
  .brand-copy strong { max-width: 148px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .user-chip { display: none; }
  .theme-toggle { width: 28px; height: 28px; }
  .app-content { padding: 0.55rem 0.5rem 1rem; }
  .page-header,
  .service-hero,
  .compact-page-header,
  .service-page-header,
  .brain-page-header { border-radius: 12px; }
  .command-strip,
  .service-filter-kpis { grid-template-columns: 1fr 1fr; }
  .kpi-card,
  .metric-card,
  .stat-card { min-height: 74px; }
  .app-content form:not(.search-form):not(.logout-form):not(.row):not(.form-plain),
  .panel,
  .panel-card,
  .form-panel,
  .mini-card { padding: 0.62rem; }
  .sticky-actions { padding: 0.62rem; }
}

/* =============================================================================
   2026-06-24 Comprehensive UI repair pass
   Root fix: the app must remain usable even when Bootstrap CDN utilities/grid
   are unavailable. These local fallbacks also correct the screenshot regressions:
   full-width KPI bars, invisible primary-link buttons, raw tab bullets,
   crowded header actions, stretched filters, and weak board/detail layouts.
   ============================================================================= */

/* Local Bootstrap utility/grid fallback -------------------------------------- */
.container-fluid { width: 100%; max-width: 100%; margin-inline: auto; }
.row {
  --bs-gutter-x: 0.75rem;
  --bs-gutter-y: 0.75rem;
  display: flex;
  flex-wrap: wrap;
  margin-top: calc(-1 * var(--bs-gutter-y));
  margin-right: calc(-0.5 * var(--bs-gutter-x));
  margin-left: calc(-0.5 * var(--bs-gutter-x));
}
.row > * {
  min-width: 0;
  width: 100%;
  max-width: 100%;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  margin-top: var(--bs-gutter-y);
}
.g-0 { --bs-gutter-x: 0; --bs-gutter-y: 0; }
.g-1 { --bs-gutter-x: 0.25rem; --bs-gutter-y: 0.25rem; }
.g-2 { --bs-gutter-x: 0.5rem; --bs-gutter-y: 0.5rem; }
.g-3 { --bs-gutter-x: 0.75rem; --bs-gutter-y: 0.75rem; }
.g-4 { --bs-gutter-x: 1rem; --bs-gutter-y: 1rem; }
.col { flex: 1 0 0%; }
.col-auto { flex: 0 0 auto; width: auto; }
.col-12 { flex: 0 0 auto; width: 100%; }
.col-10 { flex: 0 0 auto; width: 83.333333%; }
.col-9 { flex: 0 0 auto; width: 75%; }
.col-8 { flex: 0 0 auto; width: 66.666667%; }
.col-7 { flex: 0 0 auto; width: 58.333333%; }
.col-6 { flex: 0 0 auto; width: 50%; }
.col-5 { flex: 0 0 auto; width: 41.666667%; }
.col-4 { flex: 0 0 auto; width: 33.333333%; }
.col-3 { flex: 0 0 auto; width: 25%; }
.col-2 { flex: 0 0 auto; width: 16.666667%; }
.col-1 { flex: 0 0 auto; width: 8.333333%; }
@media (min-width: 576px) {
  .col-sm { flex: 1 0 0%; }
  .col-sm-auto { flex: 0 0 auto; width: auto; }
  .col-sm-12 { flex: 0 0 auto; width: 100%; }
  .col-sm-10 { flex: 0 0 auto; width: 83.333333%; }
  .col-sm-9 { flex: 0 0 auto; width: 75%; }
  .col-sm-8 { flex: 0 0 auto; width: 66.666667%; }
  .col-sm-7 { flex: 0 0 auto; width: 58.333333%; }
  .col-sm-6 { flex: 0 0 auto; width: 50%; }
  .col-sm-5 { flex: 0 0 auto; width: 41.666667%; }
  .col-sm-4 { flex: 0 0 auto; width: 33.333333%; }
  .col-sm-3 { flex: 0 0 auto; width: 25%; }
  .col-sm-2 { flex: 0 0 auto; width: 16.666667%; }
}
@media (min-width: 768px) {
  .col-md { flex: 1 0 0%; }
  .col-md-auto { flex: 0 0 auto; width: auto; }
  .col-md-12 { flex: 0 0 auto; width: 100%; }
  .col-md-10 { flex: 0 0 auto; width: 83.333333%; }
  .col-md-9 { flex: 0 0 auto; width: 75%; }
  .col-md-8 { flex: 0 0 auto; width: 66.666667%; }
  .col-md-7 { flex: 0 0 auto; width: 58.333333%; }
  .col-md-6 { flex: 0 0 auto; width: 50%; }
  .col-md-5 { flex: 0 0 auto; width: 41.666667%; }
  .col-md-4 { flex: 0 0 auto; width: 33.333333%; }
  .col-md-3 { flex: 0 0 auto; width: 25%; }
  .col-md-2 { flex: 0 0 auto; width: 16.666667%; }
}
@media (min-width: 992px) {
  .col-lg { flex: 1 0 0%; }
  .col-lg-auto { flex: 0 0 auto; width: auto; }
  .col-lg-12 { flex: 0 0 auto; width: 100%; }
  .col-lg-10 { flex: 0 0 auto; width: 83.333333%; }
  .col-lg-9 { flex: 0 0 auto; width: 75%; }
  .col-lg-8 { flex: 0 0 auto; width: 66.666667%; }
  .col-lg-7 { flex: 0 0 auto; width: 58.333333%; }
  .col-lg-6 { flex: 0 0 auto; width: 50%; }
  .col-lg-5 { flex: 0 0 auto; width: 41.666667%; }
  .col-lg-4 { flex: 0 0 auto; width: 33.333333%; }
  .col-lg-3 { flex: 0 0 auto; width: 25%; }
  .col-lg-2 { flex: 0 0 auto; width: 16.666667%; }
}
@media (min-width: 1200px) {
  .col-xl { flex: 1 0 0%; }
  .col-xl-auto { flex: 0 0 auto; width: auto; }
  .col-xl-12 { flex: 0 0 auto; width: 100%; }
  .col-xl-10 { flex: 0 0 auto; width: 83.333333%; }
  .col-xl-9 { flex: 0 0 auto; width: 75%; }
  .col-xl-8 { flex: 0 0 auto; width: 66.666667%; }
  .col-xl-7 { flex: 0 0 auto; width: 58.333333%; }
  .col-xl-6 { flex: 0 0 auto; width: 50%; }
  .col-xl-5 { flex: 0 0 auto; width: 41.666667%; }
  .col-xl-4 { flex: 0 0 auto; width: 33.333333%; }
  .col-xl-3 { flex: 0 0 auto; width: 25%; }
  .col-xl-2 { flex: 0 0 auto; width: 16.666667%; }
}
@media (min-width: 1400px) {
  .col-xxl { flex: 1 0 0%; }
  .col-xxl-auto { flex: 0 0 auto; width: auto; }
  .col-xxl-12 { flex: 0 0 auto; width: 100%; }
  .col-xxl-6 { flex: 0 0 auto; width: 50%; }
  .col-xxl-4 { flex: 0 0 auto; width: 33.333333%; }
  .col-xxl-3 { flex: 0 0 auto; width: 25%; }
  .col-xxl-2 { flex: 0 0 auto; width: 16.666667%; }
}

.d-flex { display: flex !important; }
.d-grid { display: grid !important; }
.d-block { display: block !important; }
.d-inline { display: inline !important; }
.d-inline-block { display: inline-block !important; }
.d-inline-flex { display: inline-flex !important; }
.flex-wrap { flex-wrap: wrap !important; }
.flex-nowrap { flex-wrap: nowrap !important; }
.flex-column { flex-direction: column !important; }
.align-items-start { align-items: flex-start !important; }
.align-items-center { align-items: center !important; }
.align-items-end { align-items: flex-end !important; }
.align-middle { vertical-align: middle !important; }
.justify-content-between { justify-content: space-between !important; }
.justify-content-end { justify-content: flex-end !important; }
.justify-content-center { justify-content: center !important; }
.gap-1 { gap: 0.25rem !important; }
.gap-2 { gap: 0.5rem !important; }
.gap-3 { gap: 0.75rem !important; }
.gap-4 { gap: 1rem !important; }
.w-100 { width: 100% !important; }
.h-100 { height: 100% !important; }
.text-end { text-align: right !important; }
.text-center { text-align: center !important; }
.text-start { text-align: left !important; }
.text-decoration-none { text-decoration: none !important; }
.fw-bold { font-weight: 800 !important; }
.fw-semibold { font-weight: 700 !important; }
.fw-normal { font-weight: 500 !important; }
.mt-0 { margin-top: 0 !important; }
.mt-1 { margin-top: 0.25rem !important; }
.mt-2 { margin-top: 0.5rem !important; }
.mt-3 { margin-top: 0.75rem !important; }
.mt-4 { margin-top: 1rem !important; }
.mb-0 { margin-bottom: 0 !important; }
.mb-1 { margin-bottom: 0.25rem !important; }
.mb-2 { margin-bottom: 0.5rem !important; }
.mb-3 { margin-bottom: 0.75rem !important; }
.mb-4 { margin-bottom: 1rem !important; }
.ms-1 { margin-left: 0.25rem !important; }
.me-1 { margin-right: 0.25rem !important; }
.p-0 { padding: 0 !important; }
.p-1 { padding: 0.25rem !important; }
.p-2 { padding: 0.5rem !important; }
.p-3 { padding: 0.75rem !important; }
.px-0 { padding-left: 0 !important; padding-right: 0 !important; }
.small { font-size: var(--text-sm) !important; }

/* Buttons: make anchor buttons visible without Bootstrap -------------------- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 0.35rem; min-height: 34px; white-space: nowrap; text-align: center; text-decoration: none !important; cursor: pointer; }
.btn-primary,
.btn-secondary,
.btn-success,
.btn-danger,
.btn-info,
.btn-dark { color: #fff !important; }
.btn-primary:visited,
.btn-secondary:visited,
.btn-success:visited,
.btn-danger:visited,
.btn-info:visited,
.btn-dark:visited { color: #fff !important; }
.btn-outline-light { color: #fff !important; border-color: rgba(255,255,255,0.55) !important; background: rgba(255,255,255,0.08) !important; }
.btn-outline-light:hover { background: rgba(255,255,255,0.18) !important; }
.btn-outline-success { color: var(--app-success) !important; border-color: rgba(22,132,84,0.42); background: var(--app-surface); }
.btn-outline-success:hover { color: #fff !important; background: var(--app-success); border-color: var(--app-success); }
.btn-outline-dark { color: var(--app-text) !important; border-color: var(--app-border-strong); background: var(--app-surface); }
.btn-group { display: inline-flex; flex-wrap: wrap; gap: 0.35rem; align-items: center; }
.btn-group > .btn { border-radius: 9px !important; }

/* Badges and status chips --------------------------------------------------- */
.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  max-width: 100%;
  padding: 0.22rem 0.46rem;
  border-radius: 999px;
  font-size: 0.66rem;
  font-weight: 800;
  line-height: 1.05;
  white-space: normal;
  vertical-align: middle;
  border: 1px solid transparent;
}
.text-bg-light,
.bg-light { color: #29405d !important; background-color: #eef4fb !important; border-color: #d8e4f1 !important; }
.text-bg-secondary,
.bg-secondary { color: #fff !important; background-color: #64748b !important; }
.text-bg-success,
.bg-success { color: #fff !important; background-color: var(--app-success) !important; }
.text-bg-warning,
.bg-warning { color: #7a4b00 !important; background-color: #fee49a !important; }
.text-bg-danger,
.bg-danger { color: #fff !important; background-color: var(--app-danger) !important; }
.text-bg-info,
.bg-info { color: #08334d !important; background-color: #bae6fd !important; }
.text-bg-primary,
.bg-primary { color: #fff !important; background-color: var(--app-primary-2) !important; }
.text-bg-dark,
.bg-dark { color: #fff !important; background-color: #111827 !important; }
.text-dark { color: #111827 !important; }
.table td .badge + .badge,
.compact-list .badge + .badge { margin-left: 0.2rem; }
[data-theme="dark"] .text-bg-light,
[data-theme="dark"] .bg-light { color: var(--app-text) !important; background-color: var(--app-surface-2) !important; border-color: var(--app-border) !important; }
[data-theme="dark"] .text-bg-warning,
[data-theme="dark"] .bg-warning { color: #fde68a !important; background-color: #3d2200 !important; }
[data-theme="dark"] .text-dark { color: #111827 !important; }

/* Page headers and action bars --------------------------------------------- */
.page-header,
.service-hero,
.compact-page-header,
.service-page-header,
.brain-page-header,
.company-brain-header,
.customer-profile-header,
.app-content .container-fluid > .mb-4:has(.page-eyebrow),
.app-content .container-fluid > .mb-3:has(.page-eyebrow) {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 0.85rem !important;
}
.page-header > div:first-child,
.service-hero > div:first-child,
.compact-page-header > div:first-child,
.service-page-header > div:first-child,
.brain-page-header > div:first-child,
.company-brain-header > div:first-child,
.customer-profile-header > div:first-child {
  flex: 1 1 420px;
  min-width: 0;
}
.page-header > .d-flex,
.service-hero > .d-flex,
.compact-page-header > .d-flex,
.service-page-header > .d-flex,
.brain-page-header > .d-flex,
.company-brain-header > .d-flex,
.customer-profile-header > .d-flex,
.page-header > div:last-child:has(.btn),
.app-content .container-fluid > .mb-4:has(.page-eyebrow) > .d-flex,
.app-content .container-fluid > .mb-3:has(.page-eyebrow) > .d-flex {
  flex: 0 1 720px;
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
  align-items: center !important;
  gap: 0.38rem !important;
}
.page-header .btn,
.service-hero .btn,
.compact-page-header .btn,
.service-page-header .btn,
.brain-page-header .btn,
.company-brain-header .btn,
.customer-profile-header .btn {
  min-height: 28px;
  padding: 0.25rem 0.55rem;
  border-radius: 8px;
  font-size: 0.72rem;
  line-height: 1.05;
}

/* Compact KPI/stat grids ---------------------------------------------------- */
.no-panel-row { display: flex !important; flex-wrap: wrap !important; width: auto; }
.no-panel-row > * { min-width: 0; }
.metric-card,
.kpi-card,
.stat-card {
  min-height: 78px !important;
  height: 100%;
  border-radius: 12px !important;
}
.metric-card .card-body,
.stat-card .card-body { padding: 0.6rem 0.66rem !important; }
.metric-label,
.kpi-card span,
.stat-card .small,
.stat-card .text-muted {
  font-size: 0.56rem !important;
  letter-spacing: 0.075em !important;
}
.metric-value,
.kpi-card strong,
.stat-card .fs-3,
.stat-card .fs-4,
.stat-card .fs-5,
.stat-card .fs-6 {
  font-size: clamp(1.08rem, 1.18vw, 1.42rem) !important;
}
.metric-note,
.kpi-card small { font-size: 0.66rem !important; }

/* Forms: desktop grid fallback and no stretched controls -------------------- */
.app-content form.row.g-2,
.app-content form.row.g-3,
.app-content form.row {
  max-width: none !important;
  align-items: end;
}
.app-content form.row.g-2 > *,
.app-content form.row.g-3 > *,
.app-content form.row > * { min-width: 0; }
.app-content form.row .btn { min-height: var(--input-height); }
.app-content form.row .d-flex { align-items: center; }
@media (min-width: 768px) {
  .app-content form.row.g-2 .col-md-2,
  .app-content form.row.g-2 .col-md-3,
  .app-content form.row.g-2 .col-md-4,
  .app-content form.row.g-3 .col-md-2,
  .app-content form.row.g-3 .col-md-3,
  .app-content form.row.g-3 .col-md-4 { flex-grow: 0; }
}

/* Tables: consistent compact density, responsive wrappers, readable badges --- */
.table { width: 100%; color: var(--app-text); vertical-align: middle; border-collapse: separate; border-spacing: 0; }
.table th,
.table td { border-bottom: 1px solid var(--app-border); }
.table thead th {
  background: var(--app-surface-2) !important;
  color: var(--app-muted) !important;
  font-family: var(--font-mono);
  font-size: 0.58rem !important;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
}
.table tbody td { font-size: 0.8rem; line-height: 1.28; }
.table tbody tr:hover td { background: rgba(21,92,168,0.045); }
.table-striped > tbody > tr:nth-of-type(odd) > * { background: rgba(15, 61, 115, 0.018); }
.table-warning > * { background-color: #fff7e6 !important; }
.service-table td:nth-child(3),
.service-table th:nth-child(3) { min-width: 145px; }
.service-table td:nth-child(5),
.service-table th:nth-child(5) { min-width: 220px; }
.service-table td:last-child { min-width: 130px; }
.table td .btn { min-width: max-content; }
.table td .badge { margin-top: 0.08rem; margin-bottom: 0.08rem; }
[data-theme="dark"] .table thead th { background: var(--app-surface-2) !important; color: var(--app-muted) !important; }
[data-theme="dark"] .table tbody tr:hover td { background: rgba(147,197,253,0.055); }
[data-theme="dark"] .table-striped > tbody > tr:nth-of-type(odd) > * { background: rgba(255,255,255,0.018); }
[data-theme="dark"] .table-warning > * { background-color: #271c09 !important; }

/* Tabs fallback when Bootstrap CSS/JS is unavailable ------------------------ */
.nav { display: flex; flex-wrap: wrap; gap: 0.35rem; margin: 0; padding-left: 0; list-style: none; }
.nav-item { list-style: none; }
.nav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0.3rem 0.58rem;
  border: 1px solid var(--app-border);
  border-radius: 999px;
  color: var(--app-link);
  background: var(--app-surface-2);
  font-size: 0.74rem;
  font-weight: 800;
  line-height: 1;
  cursor: pointer;
}
.nav-link:hover { border-color: var(--app-primary-2); background: var(--app-primary-soft); }
.nav-link.active { color: #fff; background: var(--app-primary-2); border-color: var(--app-primary-2); }
.tab-content { width: 100%; }
.tab-pane { display: none; }
.tab-pane.show,
.tab-pane.active { display: block; }
.customer-workspace .app-tabs { margin-bottom: 0.72rem !important; padding-bottom: 0.58rem; }
[data-theme="dark"] .nav-link { color: var(--app-link); background: var(--app-surface-2); border-color: var(--app-border); }
[data-theme="dark"] .nav-link.active { color: #07111f; background: var(--app-primary-2); border-color: var(--app-primary-2); }

/* Detail pages and definition lists ---------------------------------------- */
.detail-list,
.meta-list {
  display: grid !important;
  grid-template-columns: minmax(125px, 0.34fr) minmax(0, 1fr);
  gap: 0.34rem 0.75rem;
  margin: 0;
}
.detail-list dt,
.meta-list dt {
  color: var(--app-muted);
  font-family: var(--font-mono);
  font-size: 0.58rem;
  font-weight: 800;
  letter-spacing: 0.065em;
  text-transform: uppercase;
}
.detail-list dd,
.meta-list dd { margin: 0; min-width: 0; color: var(--app-text); }
.customer-profile-header + .row .panel,
.customer-workspace,
.knowledge-detail-layout .panel { min-height: 0; }
.customer-workspace .panel-title { margin-bottom: 0.58rem; }
.contact-card,
.site-card,
.mini-record-card {
  padding: 0.68rem;
  border: 1px solid var(--app-border);
  border-radius: 12px;
  background: var(--app-surface-2);
  box-shadow: var(--app-shadow-xs);
}
[data-theme="dark"] .contact-card,
[data-theme="dark"] .site-card,
[data-theme="dark"] .mini-record-card { background: var(--app-surface-2); }

/* Knowledge screens --------------------------------------------------------- */
.company-brain-grid,
.management-brief-grid,
.risk-radar-grid,
.service-brain-grid,
.management-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 430px), 1fr));
  gap: 0.72rem;
}
.knowledge-detail-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: 0.72rem;
  align-items: start;
}
.knowledge-meta-panel { position: sticky; top: calc(var(--topbar-height) + 0.85rem); }
.compact-knowledge-list { display: grid; gap: 0.38rem; }
.knowledge-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  min-width: 0;
  padding: 0.48rem 0;
  border-bottom: 1px solid var(--app-border);
  color: var(--app-text);
}
.knowledge-row:last-child { border-bottom: 0; }
.knowledge-row > span { min-width: 0; }
.knowledge-row strong { color: var(--app-link); }
.knowledge-row small { display: inline; margin-left: 0.16rem; color: var(--app-muted); }
.knowledge-row .badge,
.knowledge-row em { flex: 0 0 auto; font-style: normal; }
.management-brief-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.72rem;
}
.management-brief-strip div { display: grid; gap: 0.12rem; }
.management-brief-strip strong { color: var(--app-muted); font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.065em; text-transform: uppercase; }
.management-brief-strip span { color: var(--app-text); font-weight: 800; }

/* Workshop board ------------------------------------------------------------ */
.workshop-board-screen .row.g-3.no-panel-row {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(285px, 1fr));
  gap: 0.72rem;
  margin: 0 !important;
}
.workshop-board-screen .row.g-3.no-panel-row > * {
  width: auto !important;
  padding: 0 !important;
  margin: 0 !important;
}
.workshop-lane {
  display: flex;
  flex-direction: column;
  min-height: 240px;
}
.workshop-lane .panel-title {
  padding-bottom: 0.45rem;
  border-bottom: 1px solid var(--app-border);
}
.workshop-card-stack { display: grid; gap: 0.55rem; align-content: start; }
.mini-record-card { background: var(--app-surface); }
.mini-record-card.is-overdue { border-color: #f0bd54; background: var(--app-warning-soft); }
.mini-record-card a { font-size: 0.82rem; }
.mini-record-card small { color: var(--app-muted); }
[data-theme="dark"] .mini-record-card { background: var(--app-surface-2); }
[data-theme="dark"] .mini-record-card.is-overdue { border-color: #4d3200; background: var(--app-warning-soft); }

/* Lists need to read as rows, not raw blocks -------------------------------- */
.compact-list li {
  align-items: center;
  min-width: 0;
}
.compact-list li > span:first-child { min-width: 0; }
.compact-list li > span:last-child,
.compact-list li > .badge { flex: 0 0 auto; }
.compact-list small { display: block; }

/* Mobile and tablet refinements -------------------------------------------- */
@media (max-width: 1024px) {
  .page-header,
  .service-hero,
  .compact-page-header,
  .service-page-header,
  .brain-page-header,
  .company-brain-header,
  .customer-profile-header { flex-wrap: wrap !important; }
  .page-header > .d-flex,
  .service-hero > .d-flex,
  .compact-page-header > .d-flex,
  .service-page-header > .d-flex,
  .brain-page-header > .d-flex,
  .company-brain-header > .d-flex,
  .customer-profile-header > .d-flex,
  .page-header > div:last-child:has(.btn) {
    flex: 1 1 100%;
    justify-content: flex-start !important;
  }
  .knowledge-detail-layout { grid-template-columns: 1fr; }
  .knowledge-meta-panel { position: static; }
}
@media (max-width: 768px) {
  .table-responsive > .table { min-width: 760px; }
  .management-brief-strip { grid-template-columns: 1fr; }
  .page-header .btn,
  .service-hero .btn,
  .compact-page-header .btn,
  .service-page-header .btn,
  .brain-page-header .btn,
  .company-brain-header .btn,
  .customer-profile-header .btn { flex: 0 1 auto !important; }
  .detail-list,
  .meta-list { grid-template-columns: 1fr; gap: 0.16rem; }
  .detail-list dt:not(:first-child),
  .meta-list dt:not(:first-child) { margin-top: 0.36rem; }
}
@media (max-width: 390px) {
  .row { --bs-gutter-x: 0.5rem; --bs-gutter-y: 0.5rem; }
  .col-6,
  .col-sm-6,
  .col-md-6,
  .col-lg-6,
  .col-xl-6 { width: 50%; }
  .page-header .btn,
  .service-hero .btn,
  .compact-page-header .btn,
  .service-page-header .btn,
  .brain-page-header .btn,
  .company-brain-header .btn,
  .customer-profile-header .btn { min-height: 30px; font-size: 0.7rem; }
  .metric-card,
  .kpi-card,
  .stat-card { min-height: 70px !important; }
  .metric-value,
  .kpi-card strong { font-size: 1.08rem !important; }
  .workshop-board-screen .row.g-3.no-panel-row { grid-template-columns: 1fr; }
}

/* Print report readability -------------------------------------------------- */
@media print {
  .app-topbar,
  .app-sidebar,
  .sidebar-backdrop,
  .page-header .btn,
  .app-footer-credit,
  .sidebar-brand-credit { display: none !important; }
  .app-content { width: 100% !important; margin-left: 0 !important; padding: 0 !important; }
  .page-header,
  .panel,
  .metric-card,
  .kpi-card,
  .table-responsive { border-color: #d0d5dd !important; box-shadow: none !important; }
  .table thead th { position: static !important; }
}

/* Final correction: Bootstrap-style breakpoint columns must collapse below their breakpoint. */
@media (max-width: 390px) {
  .col-sm-6,
  .col-md-6,
  .col-lg-6,
  .col-xl-6 { width: 100%; }
  .col-6 { width: 50%; }
}
.page-actions { display: flex !important; flex-wrap: wrap !important; align-items: center !important; justify-content: flex-end !important; gap: 0.38rem !important; }
.btn-readable { color: #fff !important; }
.table-action-btn { max-width: none !important; overflow: visible !important; text-overflow: clip !important; }
