/* TrebuchetOS — Design System v2 */

/* ─── Design Tokens ──────────────────────────────────────────────────────── */
:root {
  /* Brand */
  --color-brand-600: #4f46e5;
  --color-brand-500: #6366f1;
  --color-brand-50: #eef2ff;

  /* Neutrals */
  --color-neutral-950: #0c0e14;
  --color-neutral-900: #111827;
  --color-neutral-700: #374151;
  --color-neutral-500: #6b7280;
  --color-neutral-400: #9ca3af;
  --color-neutral-200: #e5e7eb;
  --color-neutral-100: #f3f4f6;
  --color-neutral-50: #f9fafb;

  /* Semantic status */
  --color-success-600: #16a34a;
  --color-success-50: #f0fdf4;
  --color-warning-600: #d97706;
  --color-warning-50: #fffbeb;
  --color-danger-600: #dc2626;
  --color-danger-50: #fef2f2;
  --color-info-600: #2563eb;
  --color-info-50: #eff6ff;

  /* Surfaces */
  --surface-page: #f9fafb;
  --surface-card: #ffffff;
  --surface-muted: #f3f4f6;
  --surface-overlay: rgba(17, 24, 39, 0.45);

  /* Sidebar */
  --sidebar-bg: #ffffff;
  --sidebar-text: #64748b;
  --sidebar-text-active: #111827;
  --sidebar-active-bg: #eef2ff;
  --sidebar-active-border: #6366f1;
  --sidebar-w: 200px;
  --sidebar-collapsed: 60px;

  /* Topbar */
  --topbar-h: 56px;
  --topbar-bg: #ffffff;

  /* Borders */
  --border-default: #e5e7eb;
  --border-strong: #d1d5db;
  --border-focus: #6366f1;

  /* Shadows */
  --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.05);
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06);
  --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.07), 0 2px 4px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.07), 0 4px 6px rgba(0, 0, 0, 0.05);

  /* Radius */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;

  /* Spacing (4px base) */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;

  /* Legacy aliases — kept so older templates still compile */
  --app-surface: var(--surface-card);
  --app-surface-muted: var(--surface-muted);
  --app-border: var(--border-default);
  --app-border-strong: var(--border-strong);
  --app-text: var(--color-neutral-900);
  --app-text-muted: var(--color-neutral-500);
  --app-radius: var(--radius-md);
  --app-radius-sm: var(--radius-sm);
  --app-shadow: var(--shadow-md);
  --app-shadow-sm: var(--shadow-sm);
  --icaap-primary-navy: var(--color-brand-600);
  --icaap-primary-blue: var(--color-brand-500);
  --icaap-accent: var(--color-brand-500);
}

/* ─── Base ───────────────────────────────────────────────────────────────── */
html {
  scrollbar-gutter: stable both-edges;
}

body.dispatch-shell {
  background: var(--surface-page);
  font-size: 14px;
  line-height: 1.5;
  color: var(--color-neutral-700);
  font-family:
    "Inter",
    system-ui,
    -apple-system,
    BlinkMacSystemFont,
    sans-serif;
  overflow-x: hidden;
  margin-bottom: 0;
}

body.dispatch-shell a {
  color: var(--color-brand-600);
}

body.dispatch-shell a:hover {
  color: var(--color-brand-500);
}

/* ─── Shell Layout ───────────────────────────────────────────────────────── */
.dispatch-shell .main-wrapper {
  display: flex;
  position: relative;
  min-height: 100vh;
}

.dispatch-shell .page-wrapper {
  min-height: 100vh;
  background: var(--surface-page);
  width: calc(100% - var(--sidebar-w));
  margin-left: var(--sidebar-w);
  display: flex;
  flex-direction: column;
  transition:
    margin 0.15s ease,
    width 0.15s ease;
}

.dispatch-shell .page-wrapper .page-content {
  flex-grow: 1;
  padding: var(--space-6);
  margin-top: var(--topbar-h);
}

@media (max-width: 767px) {
  .dispatch-shell .page-wrapper .page-content {
    padding: var(--space-4) var(--space-3);
  }
}

/* ─── Sidebar ────────────────────────────────────────────────────────────── */
.dispatch-shell .sidebar {
  position: fixed;
  left: 0;
  top: 0;
  width: var(--sidebar-w) !important;
  min-width: var(--sidebar-w) !important;
  height: 100vh;
  z-index: 999;
  display: flex;
  flex-direction: column;
  background: var(--sidebar-bg);
  border-right: 1px solid var(--border-default);
  transition:
    width 0.15s ease,
    min-width 0.15s ease,
    left 0.25s ease;
}

.dispatch-shell .sidebar .sidebar-header {
  height: var(--topbar-h);
  min-height: var(--topbar-h);
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 var(--space-4);
  flex-shrink: 0;
  border-bottom: 1px solid var(--border-default);
}

.dispatch-shell .sidebar .sidebar-header .sidebar-brand {
  font-weight: 700;
  font-size: 15px;
  color: var(--sidebar-text-active);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  white-space: nowrap;
}

.dispatch-shell .sidebar .sidebar-header .sidebar-brand .brand-icon {
  color: var(--color-brand-500);
  font-size: 18px;
}

.dispatch-shell .sidebar .sidebar-header .sidebar-brand .brand-accent {
  color: var(--color-brand-500);
  font-weight: 300;
}

.dispatch-shell .sidebar .sidebar-header .sidebar-toggler {
  appearance: none;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  width: 20px;
  flex-shrink: 0;
  opacity: 0.5;
  transition: opacity 0.15s;
}

.dispatch-shell .sidebar .sidebar-header .sidebar-toggler:hover {
  opacity: 1;
}

.dispatch-shell .sidebar .sidebar-header .sidebar-toggler:focus-visible {
  outline: 2px solid var(--border-focus);
  outline-offset: 3px;
}

.dispatch-shell .sidebar .sidebar-header .sidebar-toggler span {
  display: block;
  width: 100%;
  border-radius: 3px;
  height: 2px;
  background: var(--color-neutral-500);
}

.dispatch-shell .sidebar .sidebar-header .sidebar-toggler span + span {
  margin-top: 5px;
}

.dispatch-shell .sidebar .sidebar-body {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: var(--space-3) var(--space-2) var(--space-6);
  scrollbar-width: thin;
  scrollbar-color: var(--border-strong) transparent;
}

/* Nav items */
.dispatch-shell .sidebar .sidebar-body .nav {
  flex-direction: column;
}

.dispatch-shell .sidebar .sidebar-body .nav .nav-item.nav-category {
  color: var(--color-neutral-500);
  font-size: 11px;
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.08em;
  padding: var(--space-4) var(--space-3) var(--space-2);
  list-style: none;
}

.dispatch-shell
  .sidebar
  .sidebar-body
  .nav
  .nav-item.nav-category:not(:first-of-type) {
  border-top: 1px solid var(--border-default);
  margin-top: var(--space-2);
}

.dispatch-shell .sidebar .sidebar-body .nav .nav-item .nav-link {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0 var(--space-3);
  height: 36px;
  border-radius: 6px;
  margin: 1px var(--space-2);
  color: var(--sidebar-text);
  font-weight: 500;
  font-size: 13px;
  position: relative;
  text-decoration: none;
  transition:
    color 0.15s,
    background 0.15s;
}

.dispatch-shell .sidebar .sidebar-body .nav .nav-item .nav-link i {
  width: 16px;
  text-align: center;
  font-size: 14px;
  opacity: 0.7;
  flex-shrink: 0;
  transition: opacity 0.15s;
}

.dispatch-shell .sidebar .sidebar-body .nav .nav-item .nav-link .link-title {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dispatch-shell .sidebar .sidebar-body .nav .nav-item .nav-link:hover {
  background: var(--surface-muted);
  color: var(--sidebar-text-active);
}

.dispatch-shell .sidebar .sidebar-body .nav .nav-item .nav-link:hover i {
  opacity: 1;
}

.dispatch-shell .sidebar .sidebar-body .nav .nav-item.active > .nav-link {
  background: var(--sidebar-active-bg);
  color: var(--sidebar-text-active);
  border-left: 3px solid var(--sidebar-active-border);
  padding-left: calc(var(--space-3) - 3px);
}

.dispatch-shell .sidebar .sidebar-body .nav .nav-item.active > .nav-link i {
  opacity: 1;
  color: var(--color-brand-500);
}

/* Sidebar footer */
.dispatch-shell .sidebar-footer {
  padding: var(--space-3) var(--space-4) var(--space-4);
  border-top: 1px solid var(--border-default);
}

.dispatch-shell .sidebar-footer .small {
  color: var(--sidebar-text);
  font-size: 11px;
}

/* ─── Folded Sidebar ─────────────────────────────────────────────────────── */
.dispatch-shell.sidebar-folded .sidebar {
  width: var(--sidebar-collapsed) !important;
  min-width: var(--sidebar-collapsed) !important;
}

.dispatch-shell.sidebar-folded .page-wrapper {
  margin-left: var(--sidebar-collapsed) !important;
  width: calc(100% - var(--sidebar-collapsed)) !important;
}

.dispatch-shell.sidebar-folded .dispatch-topbar.navbar {
  left: var(--sidebar-collapsed) !important;
  width: calc(100% - var(--sidebar-collapsed)) !important;
}

.dispatch-shell.sidebar-folded .sidebar .brand-full,
.dispatch-shell.sidebar-folded .sidebar .link-title,
.dispatch-shell.sidebar-folded .sidebar .nav-category {
  display: none !important;
}

.dispatch-shell.sidebar-folded .sidebar .sidebar-header .sidebar-brand {
  justify-content: center;
}

.dispatch-shell.sidebar-folded .sidebar .nav-item .nav-link {
  justify-content: center;
  padding-left: 0;
  padding-right: 0;
  margin: 1px var(--space-2);
  border-left: none !important;
}

.dispatch-shell.sidebar-folded .sidebar .nav-item.active > .nav-link {
  border-left: none;
  padding-left: 0;
}

.dispatch-shell.sidebar-folded .sidebar .nav-item .nav-link i {
  width: auto;
}

/* ─── Topbar ─────────────────────────────────────────────────────────────── */
.dispatch-shell .dispatch-topbar.navbar {
  position: fixed;
  top: 0;
  right: 0;
  left: var(--sidebar-w);
  width: calc(100% - var(--sidebar-w));
  height: var(--topbar-h);
  min-height: var(--topbar-h);
  background: var(--topbar-bg);
  border-bottom: 1px solid var(--border-default);
  z-index: 978;
  padding: 0;
  transition:
    left 0.15s ease,
    width 0.15s ease;
}

.dispatch-shell.sidebar-folded .dispatch-topbar.navbar {
  left: var(--sidebar-collapsed);
  width: calc(100% - var(--sidebar-collapsed));
}

.dispatch-shell .dispatch-topbar .navbar-content {
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 0 var(--space-5) 0 var(--space-4);
  gap: var(--space-3);
}

/* Mobile sidebar toggle in topbar */
.dispatch-shell .dispatch-topbar .sidebar-toggler {
  display: none;
  height: 100%;
  align-items: center;
  padding: 0 var(--space-4);
  color: var(--color-neutral-500);
  text-decoration: none;
  border-right: 1px solid var(--border-default);
}

.dispatch-shell .dispatch-topbar .sidebar-toggler:hover {
  color: var(--color-neutral-900);
  background: var(--surface-muted);
}

/* Search */
.dispatch-shell .dispatch-topbar .navbar-search-linkedin {
  flex: 0 1 320px;
  max-width: 320px;
}

.dispatch-shell .dispatch-topbar .navbar-search-linkedin .input-group {
  border: 1px solid var(--border-default);
  border-radius: 100px;
  overflow: hidden;
  background: var(--surface-muted);
  height: 36px;
}

.dispatch-shell .dispatch-topbar .navbar-search-linkedin .input-group-text {
  border: none;
  background: transparent;
  color: var(--color-neutral-400);
  padding: 0 var(--space-3);
}

.dispatch-shell .dispatch-topbar .navbar-search-linkedin .form-control {
  border: none;
  box-shadow: none;
  background: transparent;
  font-size: 13px;
  color: var(--color-neutral-900);
  height: 36px;
}

.dispatch-shell
  .dispatch-topbar
  .navbar-search-linkedin
  .form-control::placeholder {
  color: var(--color-neutral-400);
}

/* Topbar nav items */
.dispatch-shell .dispatch-topbar .navbar-nav {
  margin-left: auto !important;
  align-items: center;
  height: var(--topbar-h);
  flex-direction: row;
  flex-wrap: nowrap;
  gap: var(--space-1);
}

.dispatch-shell .dispatch-topbar .linkedin-nav-item {
  display: flex;
  align-items: center;
}

.dispatch-shell .dispatch-topbar .dropdown-toggle::after {
  display: none !important;
}

.dispatch-shell .dispatch-topbar .linkedin-nav-link {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  width: 36px;
  border-radius: var(--radius-md);
  color: var(--color-neutral-500) !important;
  text-decoration: none;
  position: relative;
  transition:
    background 0.15s,
    color 0.15s;
  border: none;
  background: transparent;
  cursor: pointer;
  font-family: inherit;
  font-size: inherit;
}

.dispatch-shell .dispatch-topbar .linkedin-nav-link:hover {
  background: var(--surface-muted);
  color: var(--color-neutral-900) !important;
}

.dispatch-shell .dispatch-topbar .linkedin-nav-link:focus-visible {
  outline: 2px solid var(--border-focus);
  outline-offset: 2px;
}

.dispatch-shell .dispatch-topbar .linkedin-nav-link > i {
  font-size: 16px;
}

.dispatch-shell .dispatch-topbar .linkedin-nav-label {
  display: none;
}

.dispatch-shell .dispatch-topbar .topbar-tenant-switcher {
  height: 34px;
  padding: 0 8px;
  font-size: 13px;
  width: auto;
}

.dispatch-shell .dispatch-topbar .topbar-tenant-initial {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  background: var(--color-brand-600);
  color: #fff;
  font-weight: 600;
  margin-right: 8px;
}

.dispatch-shell .dispatch-topbar .topbar-dropdown-wide-tenant {
  min-width: 270px;
}

.dispatch-shell .dispatch-topbar .topbar-dropdown-wide-create {
  min-width: 200px;
}

.dispatch-shell .dispatch-topbar .topbar-dropdown-wide-profile {
  min-width: 230px;
}

.dispatch-shell .dispatch-topbar .topbar-profile-link {
  width: auto;
  padding: 0 6px;
}

.dispatch-shell .dispatch-topbar .topbar-profile-name {
  font-size: 0.875rem;
}

.dispatch-shell .dispatch-topbar .linkedin-nav-active {
  color: var(--color-brand-600) !important;
  background: var(--color-brand-50);
}

/* Notification badge */
.dispatch-shell .dispatch-topbar .notification-pill {
  position: absolute;
  top: 4px;
  right: 4px;
  font-size: 9px;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  line-height: 16px;
  border-radius: 100px;
  background: var(--color-danger-600);
  color: #fff;
  font-weight: 700;
  z-index: 2;
  pointer-events: none;
  text-align: center;
}

.dispatch-shell .dispatch-topbar .chatterbox-pill {
  position: absolute;
  top: 4px;
  right: 4px;
  font-size: 9px;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  line-height: 16px;
  border-radius: 100px;
  background: var(--color-brand-600);
  color: #fff;
  font-weight: 700;
  z-index: 2;
  pointer-events: none;
  text-align: center;
}

/* Avatar */
.topbar-avatar-circle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  border-radius: 50%;
  background: var(--color-brand-600);
  color: #fff;
  font-size: 12px;
  font-weight: 600;
}

/* Topbar dropdowns */
.dispatch-shell .dispatch-topbar .dropdown {
  position: relative;
  overflow: visible;
}

.topbar-dropdown-menu {
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: 4px 0 8px;
  background: var(--surface-card);
  min-width: 200px;
  position: absolute !important;
  margin-top: 0 !important;
}

.dispatch-shell .dispatch-topbar .topbar-dropdown-menu {
  top: calc(100% + 8px) !important;
  margin-top: 0 !important;
}

.topbar-dropdown-section-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-neutral-500);
  padding: 8px 16px 4px;
}

.topbar-dropdown-item {
  font-size: 13px;
  color: var(--color-neutral-700);
  padding: 7px 16px;
  display: block;
  text-decoration: none;
  transition: background 0.1s;
}

.topbar-dropdown-item:hover {
  background: var(--surface-muted);
  color: var(--color-neutral-900);
}

.topbar-dropdown-item.text-danger:hover {
  background: var(--color-danger-50);
  color: var(--color-danger-600) !important;
}

/* ─── Mobile sidebar ─────────────────────────────────────────────────────── */
@media (max-width: 991px) {
  .dispatch-shell .dispatch-topbar .sidebar-toggler {
    display: inline-flex;
  }

  .dispatch-shell .sidebar {
    left: calc(-1 * var(--sidebar-w));
  }

  .dispatch-shell.sidebar-open .sidebar {
    left: 0;
    box-shadow: 8px 0 32px rgba(0, 0, 0, 0.3);
  }

  .dispatch-shell .page-wrapper {
    margin-left: 0 !important;
    width: 100% !important;
  }

  .dispatch-shell .dispatch-topbar.navbar {
    left: 0 !important;
    width: 100% !important;
  }

  .dispatch-shell.sidebar-open::before {
    content: "";
    position: fixed;
    inset: 0;
    background: var(--surface-overlay);
    z-index: 990;
  }
}

/* ─── Auth / Public Pages ────────────────────────────────────────────────── */
.dispatch-auth {
  background:
    radial-gradient(
      circle at top left,
      rgba(59, 130, 246, 0.12),
      transparent 34%
    ),
    radial-gradient(
      circle at bottom right,
      rgba(245, 158, 11, 0.12),
      transparent 30%
    ),
    linear-gradient(180deg, #f8fafc 0%, #eef4fb 100%);
}

.dispatch-auth .auth-shell {
  display: flex;
  min-height: 100vh;
  padding: var(--space-3);
}

.dispatch-auth .auth-grid {
  display: grid;
  grid-template-columns: 45% 55%;
  width: 100%;
  max-width: 1240px;
  margin: 0 auto;
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 28px 80px rgba(15, 23, 42, 0.12);
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(16px);
}

.dispatch-auth .auth-grid-single {
  grid-template-columns: 1fr;
  max-width: 560px;
}

.dispatch-auth .auth-panel {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
}

.dispatch-auth .auth-panel-brand {
  position: relative;
  color: var(--color-neutral-900);
  text-align: left;
  background:
    radial-gradient(
      circle at top right,
      rgba(59, 130, 246, 0.2),
      transparent 28%
    ),
    linear-gradient(
      160deg,
      rgba(255, 255, 255, 0.98) 0%,
      rgba(241, 245, 249, 0.95) 100%
    );
}

.dispatch-auth .auth-panel-brand::before {
  content: "";
  position: absolute;
  inset: 24px;
  border-radius: 24px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  pointer-events: none;
}

.dispatch-auth .auth-brand-inner {
  max-width: 440px;
  position: relative;
  z-index: 1;
}

.dispatch-auth .auth-brand-mark {
  width: 56px;
  height: 56px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(
    135deg,
    rgba(37, 99, 235, 0.16),
    rgba(245, 158, 11, 0.14)
  );
  color: var(--color-brand-700);
  font-size: 22px;
  margin-bottom: var(--space-4);
}

.dispatch-auth .auth-brand-kicker {
  display: inline-flex;
  align-items: center;
  margin-bottom: var(--space-3);
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(37, 99, 235, 0.08);
  color: var(--color-brand-700);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.dispatch-auth .auth-brand-title {
  font-size: 34px;
  font-weight: 700;
  margin-bottom: var(--space-2);
  color: var(--color-neutral-900);
}

.dispatch-auth .auth-brand-sub {
  color: var(--color-neutral-600);
  margin-bottom: var(--space-4);
  max-width: 420px;
}

.dispatch-auth .auth-feature-list {
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 0;
}

.dispatch-auth .auth-feature-list li {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(148, 163, 184, 0.16);
  color: var(--color-neutral-800);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.04);
}

.dispatch-auth .auth-feature-icon {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(37, 99, 235, 0.1);
  color: var(--color-brand-700);
  flex: 0 0 auto;
}

.dispatch-auth .auth-panel-form {
  background:
    radial-gradient(
      circle at top left,
      rgba(37, 99, 235, 0.05),
      transparent 24%
    ),
    linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
}

.dispatch-auth .auth-card {
  width: 100%;
  max-width: 420px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(148, 163, 184, 0.16);
  border-radius: 24px;
  padding: var(--space-6);
  box-shadow: 0 24px 70px rgba(15, 23, 42, 0.12);
}

.dispatch-auth .auth-card-single {
  max-width: none;
}

.dispatch-auth .auth-card-badge {
  display: inline-flex;
  align-items: center;
  margin-bottom: var(--space-3);
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(16, 185, 129, 0.12);
  color: #047857;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.dispatch-auth .auth-card h1 {
  margin: 0 0 var(--space-2) 0;
  font-size: 28px;
  color: var(--color-neutral-950);
}

.dispatch-auth .auth-card p.sub {
  color: var(--color-neutral-600);
  margin-bottom: var(--space-5);
}

.dispatch-auth .auth-card .form-control,
.dispatch-auth .auth-card .input-group .form-control {
  background: #fff;
}

.dispatch-auth .auth-submit {
  height: 44px;
  font-weight: 600;
  border-radius: 14px;
}

.dispatch-auth .auth-footer {
  color: var(--color-neutral-500) !important;
}

@media (max-width: 900px) {
  .dispatch-auth .auth-grid {
    grid-template-columns: 1fr;
    border-radius: 0;
    box-shadow: none;
  }
  .dispatch-auth .auth-panel-brand {
    display: none;
  }
  .dispatch-auth .auth-panel-form {
    padding: var(--space-6) var(--space-3);
  }
  .dispatch-auth .auth-panel {
    min-height: auto;
  }
}

@media (max-width: 900px) {
  .dispatch-auth .auth-grid-single {
    max-width: 100%;
  }
}
/* ─── Breadcrumbs ────────────────────────────────────────────────────────── */
.dispatch-shell .dispatch-page-toolbar {
  margin-bottom: var(--space-3);
}

.dispatch-shell .dispatch-breadcrumb {
  margin-bottom: 0;
  padding: 0;
  background: transparent;
  font-size: 13px;
}

.dispatch-shell .dispatch-breadcrumb .breadcrumb-item {
  color: var(--color-neutral-500);
}

.dispatch-shell
  .dispatch-breadcrumb
  .breadcrumb-item
  + .breadcrumb-item::before {
  color: var(--color-neutral-400);
  content: "/";
}

.dispatch-shell .dispatch-breadcrumb a {
  color: var(--color-neutral-500);
  text-decoration: none;
}

.dispatch-shell .dispatch-breadcrumb a:hover {
  color: var(--color-neutral-900);
  text-decoration: underline;
}

.dispatch-shell .dispatch-breadcrumb .breadcrumb-item.active {
  color: var(--color-neutral-900);
  font-weight: 500;
}

/* Search results grouped layout */
.search-results-group h3 {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-neutral-500);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.search-result-item {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 12px 16px;
  margin-bottom: 8px;
  transition:
    box-shadow 0.12s,
    transform 0.08s;
}

.search-result-item:hover {
  box-shadow: var(--shadow-sm);
  transform: translateY(-2px);
  text-decoration: none;
}

.search-result-item .fw-semibold {
  color: var(--color-neutral-900);
}

@media (max-width: 767px) {
  .search-result-item {
    padding: 10px 12px;
  }
}

/* ─── Page Header ────────────────────────────────────────────────────────── */
.app-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  padding-bottom: var(--space-5);
  margin-bottom: var(--space-6);
  border-bottom: 1px solid var(--border-default);
  background: transparent;
  border-radius: 0;
  box-shadow: none;
}

.app-page-eyebrow {
  color: var(--color-neutral-500);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--space-1);
}

.app-page-heading {
  min-width: 0;
}

.dispatch-page-title,
.app-page-header .dispatch-page-title {
  color: var(--color-neutral-900);
  font-size: 22px;
  line-height: 1.25;
  font-weight: 600;
  margin: 0;
  letter-spacing: 0;
}

.app-page-subtitle {
  color: var(--color-neutral-500);
  font-size: 14px;
  margin-top: var(--space-1);
}

.app-page-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
  flex-wrap: wrap;
  flex-shrink: 0;
}

/* ─── Filter Bar ─────────────────────────────────────────────────────────── */
.app-filter-bar {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: var(--space-2);
  padding: var(--space-2);
  min-height: 48px;
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-4);
  box-shadow: var(--shadow-xs);
  overflow-x: auto;
  scrollbar-width: thin;
}

.app-filter-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  justify-self: start;
  margin-bottom: var(--space-2);
}

.app-filter-toggle[aria-expanded="true"] {
  margin-bottom: var(--space-2);
}

.app-filter-bar.is-collapsed {
  display: none;
}

.app-filter-bar.filter-stacked {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: var(--space-2);
}

.app-filter-bar.row {
  margin-left: 0;
  margin-right: 0;
}

.app-filter-bar > *,
.app-filter-bar .filter-primary > *,
.app-filter-bar .filter-advanced > * {
  min-width: 0;
}

.app-filter-bar .filter-primary,
.app-filter-bar .filter-advanced {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: var(--space-2);
  width: auto;
  flex: 0 0 auto;
}

.app-filter-bar .filter-advanced {
  padding-top: 0;
  border-top: 0;
}

.app-filter-bar .filter-field {
  flex: 0 0 180px;
  min-width: 0;
}

.app-filter-bar .filter-field-sm {
  flex: 0 0 140px;
  min-width: 0;
}

.app-filter-bar .filter-field-lg,
.app-filter-bar .filter-grow {
  flex: 0 0 260px;
  min-width: 0;
}

.app-filter-bar .form-label {
  margin: 0 0 2px;
  color: var(--color-neutral-500);
  font-size: 11px;
  font-weight: 600;
  line-height: 1.2;
}

.app-filter-bar .form-control,
.app-filter-bar .form-select {
  height: 32px;
  min-height: 32px;
  padding-top: 0;
  padding-bottom: 0;
  font-size: 13px;
}

.app-filter-bar .btn {
  height: 32px;
  min-height: 32px;
  padding-inline: 12px;
  font-size: 12px;
}

.app-filter-bar .filter-check,
.app-filter-bar .form-check {
  min-height: 32px;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin: 0;
  color: var(--color-neutral-700);
  font-size: 12px;
  white-space: nowrap;
}

.app-filter-bar .filter-search {
  flex: 0 0 320px;
  min-width: 0;
  min-height: 32px;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-neutral-400);
  padding: 0 var(--space-3);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  background: var(--surface-card);
}

.app-filter-bar .filter-search input {
  border: none;
  outline: none;
  background: transparent;
  font-size: 13px;
  color: var(--color-neutral-900);
  width: 100%;
}

.app-filter-bar .filter-search input::placeholder {
  color: var(--color-neutral-400);
}

.app-filter-bar .filter-divider {
  width: 1px;
  height: 24px;
  background: var(--border-default);
  flex-shrink: 0;
  margin: 0 var(--space-1);
}

.app-filter-bar select.filter-select {
  border: none;
  outline: none;
  background: transparent;
  font-size: 13px;
  color: var(--color-neutral-700);
  padding: 0 var(--space-3);
  min-height: 32px;
  cursor: pointer;
}

.app-filter-bar .filter-actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: nowrap;
  flex: 0 0 auto;
  gap: var(--space-2);
}

/* ─── Cards ──────────────────────────────────────────────────────────────── */
.dispatch-shell .page-content .card,
.app-panel {
  background: var(--surface-card);
  border: 1px solid var(--border-default) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-sm) !important;
}

.dispatch-shell .page-content .card-header {
  background: var(--surface-card);
  border-bottom: 1px solid var(--border-default);
  color: var(--color-neutral-900);
  font-weight: 600;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0 !important;
}

/* ─── Tables ─────────────────────────────────────────────────────────────── */
.dispatch-shell .page-content table thead.table-light th,
.dispatch-shell .page-content .table thead th {
  background: var(--surface-muted) !important;
  color: var(--color-neutral-500) !important;
  border-color: var(--border-default) !important;
  border-bottom: 2px solid var(--border-default) !important;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: var(--space-3) var(--space-4);
}

.dispatch-shell .table {
  color: var(--color-neutral-700);
}

.dispatch-shell .table > :not(caption) > * > * {
  border-bottom-color: var(--color-neutral-100);
  padding: 0 var(--space-4);
  height: 52px;
  vertical-align: middle;
}

.dispatch-shell .table-hover > tbody > tr:hover > *,
.dispatch-shell .table tbody tr:hover > * {
  background: var(--color-neutral-50);
}

/* Table wrap pattern */
.data-table-wrap {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.data-table-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border-default);
}

.data-table-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  border-top: 1px solid var(--border-default);
  font-size: 13px;
  color: var(--color-neutral-500);
}

/* ─── Form Controls ──────────────────────────────────────────────────────── */
.dispatch-shell .form-control,
.dispatch-shell .form-select,
.dispatch-auth .form-control,
.dispatch-auth .form-select {
  height: 36px;
  padding: 0 var(--space-3);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  font-size: 14px;
  color: var(--color-neutral-900);
  background: var(--surface-card);
  transition:
    border-color 0.15s,
    box-shadow 0.15s;
}

.dispatch-shell .form-control:focus,
.dispatch-shell .form-select:focus,
.dispatch-auth .form-control:focus,
.dispatch-auth .form-select:focus {
  border-color: var(--border-focus);
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.12);
  outline: none;
}

.dispatch-shell .form-label,
.dispatch-auth .form-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--color-neutral-700);
  margin-bottom: 6px;
}

.dispatch-shell textarea.form-control,
.dispatch-auth textarea.form-control {
  height: auto;
  padding: var(--space-2) var(--space-3);
}

/* ─── Tabs ───────────────────────────────────────────────────────────────── */
.dispatch-shell .nav-tabs {
  border-bottom-color: var(--border-default);
}

.dispatch-shell .nav-tabs .nav-link {
  color: var(--color-neutral-500);
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
  font-weight: 500;
  font-size: 13px;
}

.dispatch-shell .nav-tabs .nav-link.active {
  color: var(--color-neutral-900);
  border-color: var(--border-default) var(--border-default) var(--surface-card);
  font-weight: 600;
}

/* ─── Metric Grid ────────────────────────────────────────────────────────── */
.app-metric-grid {
  display: grid;
  /* Force 4 cards per row on large screens */
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-3);
  align-items: stretch;
  grid-auto-rows: 1fr;
}

.app-metric-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-5);
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
  transition:
    transform 0.16s ease,
    box-shadow 0.16s ease,
    border-color 0.16s ease;
  min-height: 0;
  height: 100%;
}

.app-metric-card:hover {
  transform: translateY(-2px);
  border-color: var(--border-strong);
  box-shadow: var(--shadow-md);
}

/* Report panels: make panels equal height and table areas scrollable */
.report-panel {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-4);
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  height: 100%;
}

.report-panel > h2 {
  margin: 0 0 var(--space-2) 0;
  font-size: 16px;
}

.dashboard-table {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 160px;
}

.dashboard-table .table-responsive {
  overflow: auto;
  max-height: 260px; /* clamp preview height */
}

.dashboard-table.expanded .table-responsive {
  max-height: none;
}

.dashboard-show-more {
  font-size: 0.9rem;
  padding: 0.25rem 0.5rem;
}

.app-metric-topline {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-2);
}

.app-metric-label {
  color: var(--color-neutral-500);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.app-metric-value {
  color: var(--color-neutral-900);
  font-size: 28px;
  line-height: 1.2;
  font-weight: 700;
  overflow-wrap: anywhere;
}

.app-metric-icon {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}

.app-metric-icon.tone-default {
  background: var(--color-neutral-100);
  color: var(--color-neutral-500);
}
.app-metric-icon.tone-money {
  background: var(--color-success-50);
  color: var(--color-success-600);
}
.app-metric-icon.tone-warning {
  background: var(--color-warning-50);
  color: var(--color-warning-600);
}
.app-metric-icon.tone-danger {
  background: var(--color-danger-50);
  color: var(--color-danger-600);
}
.app-metric-icon.tone-brand {
  background: var(--color-brand-50);
  color: var(--color-brand-600);
}
.app-metric-icon.tone-info {
  background: var(--color-info-50);
  color: var(--color-info-600);
}

.app-metric-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  margin-top: auto;
}

.app-metric-hint,
.app-metric-meta {
  color: var(--color-neutral-500);
  font-size: 12px;
  line-height: 1.3;
}

.app-metric-meta {
  background: var(--color-neutral-100);
  border-radius: 100px;
  font-weight: 600;
  padding: 2px 8px;
  white-space: nowrap;
}

.app-metric-trend-up {
  color: var(--color-success-600);
  font-size: 12px;
  font-weight: 600;
}
.app-metric-trend-down {
  color: var(--color-danger-600);
  font-size: 12px;
  font-weight: 600;
}

/* ─── Hub Card Grid ──────────────────────────────────────────────────────── */
.app-hub-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-4);
}

.app-hub-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  color: var(--color-neutral-700) !important;
  text-decoration: none;
  transition:
    transform 0.2s,
    box-shadow 0.2s,
    border-color 0.2s;
}

.app-hub-card:hover {
  transform: translateY(-1px);
  border-color: var(--color-brand-600);
  box-shadow: var(--shadow-md);
}

.app-hub-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.app-hub-icon {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  background: var(--color-brand-50);
  color: var(--color-brand-600);
  font-size: 18px;
}

.app-hub-meta {
  color: var(--color-neutral-500);
  background: var(--color-neutral-100);
  border-radius: 100px;
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
}

.app-hub-title {
  color: var(--color-neutral-900);
  font-weight: 600;
  font-size: 15px;
}

.app-hub-description {
  color: var(--color-neutral-500);
  font-size: 13px;
  line-height: 1.5;
  margin-top: var(--space-1);
}

.app-hub-highlights {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-1) var(--space-3);
  margin-top: var(--space-2);
}

.app-hub-highlights span {
  color: var(--color-neutral-500);
  font-size: 12px;
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.app-hub-highlights span::before {
  content: "•";
  color: var(--color-brand-500);
}

.app-hub-action {
  color: var(--color-brand-600);
  font-size: 13px;
  font-weight: 500;
  margin-top: auto;
  padding-top: var(--space-3);
  border-top: 1px solid var(--border-default);
}

.app-hub-action:hover {
  text-decoration: underline;
}

/* ─── Command Strip ──────────────────────────────────────────────────────── */
.app-command-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.app-command-item {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  box-shadow: var(--shadow-xs);
}

.app-command-label {
  color: var(--color-neutral-500);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.app-command-value {
  color: var(--color-neutral-900);
  font-weight: 600;
  font-size: 15px;
  margin-top: var(--space-1);
}

/* ─── Empty State ────────────────────────────────────────────────────────── */
.app-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 60px var(--space-4);
  color: var(--color-neutral-500);
}

.app-empty-state .empty-icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--color-neutral-100);
  color: var(--color-neutral-400);
  display: grid;
  place-items: center;
  font-size: 22px;
  margin-bottom: var(--space-4);
}

.app-empty-state .empty-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--color-neutral-700);
  margin-bottom: var(--space-2);
}

.app-empty-state .empty-sub {
  font-size: 13px;
  color: var(--color-neutral-500);
  margin-bottom: var(--space-5);
}

/* ─── Status Badges ──────────────────────────────────────────────────────── */
.status-badge {
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 var(--space-2);
  border-radius: 100px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.3px;
  white-space: nowrap;
}

.status-badge-success {
  background: var(--color-success-50);
  color: var(--color-success-600);
}
.status-badge-warning {
  background: var(--color-warning-50);
  color: var(--color-warning-600);
}
.status-badge-danger {
  background: var(--color-danger-50);
  color: var(--color-danger-600);
}
.status-badge-info {
  background: var(--color-info-50);
  color: var(--color-info-600);
}
.status-badge-neutral {
  background: var(--color-neutral-100);
  color: var(--color-neutral-700);
}

/* Legacy alias */
.app-status-badge {
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 var(--space-2);
  border-radius: 100px;
  font-size: 11px;
  font-weight: 600;
  background: var(--color-neutral-100) !important;
  color: var(--color-neutral-700) !important;
  border: none !important;
}

/* ─── Pipeline / Kanban ──────────────────────────────────────────────────── */
.pipeline-column {
  background: var(--color-neutral-50);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-3);
  min-height: 220px;
}

.pipeline-column-title {
  color: var(--color-neutral-700);
  font-weight: 600;
  font-size: 13px;
  margin-bottom: var(--space-3);
}

/* ─── Dispatch Board ─────────────────────────────────────────────────────── */
.dispatch-board-shell {
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: var(--space-3);
  align-items: start;
}

.dispatch-queue,
.dispatch-grid-wrap,
.dispatch-drawer {
  border: 1px solid var(--border-default);
  background: var(--surface-card);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.dispatch-queue {
  min-height: 580px;
  padding: var(--space-3);
}

.dispatch-pane-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.dispatch-card-list {
  display: grid;
  gap: var(--space-2);
}

.dispatch-grid-wrap {
  overflow: auto;
}

.dispatch-grid {
  display: grid;
  min-width: 760px;
}

.dispatch-grid-corner,
.dispatch-lane-head,
.dispatch-time-label,
.dispatch-slot {
  border-right: 1px solid var(--color-neutral-200);
  border-bottom: 1px solid var(--color-neutral-200);
}

.dispatch-grid-corner,
.dispatch-lane-head {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--surface-muted);
  padding: var(--space-2) var(--space-3);
  font-size: 12px;
  font-weight: 600;
}

.dispatch-time-label {
  background: var(--color-neutral-50);
  color: var(--color-neutral-500);
  font-size: 11px;
  font-weight: 600;
  padding: var(--space-2) var(--space-3);
}

.dispatch-slot {
  min-height: 92px;
  padding: var(--space-1);
  background: var(--surface-card);
}

.dispatch-slot.drag-over {
  outline: 2px solid var(--color-info-600);
  outline-offset: -2px;
  background: var(--color-info-50);
}

.dispatch-visit-card {
  width: 100%;
  display: grid;
  gap: 2px;
  text-align: left;
  border: 1px solid var(--border-default);
  border-left: 4px solid var(--color-neutral-400);
  background: var(--surface-card);
  border-radius: var(--radius-sm);
  padding: var(--space-2);
  color: var(--color-neutral-700);
  transition: border-color 0.15s;
}

.dispatch-visit-card:hover {
  border-color: var(--border-strong);
}

.dispatch-visit-card .visit-time {
  color: var(--color-neutral-700);
  font-size: 11px;
  font-weight: 600;
}

.dispatch-visit-card .visit-meta {
  color: var(--color-neutral-500);
  font-size: 11px;
}

.dispatch-visit-card .visit-flags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.dispatch-visit-card .visit-flags em {
  background: var(--color-warning-50);
  color: var(--color-warning-600);
  border-radius: var(--radius-sm);
  font-size: 10px;
  font-style: normal;
  padding: 1px 4px;
}

.dispatch-visit-card.priority-high,
.dispatch-visit-card.priority-urgent {
  border-left-color: var(--color-danger-600);
}
.dispatch-visit-card.priority-normal {
  border-left-color: var(--color-info-600);
}
.dispatch-visit-card.priority-low {
  border-left-color: var(--color-neutral-400);
}

.dispatch-drawer {
  position: fixed;
  right: 18px;
  top: 80px;
  bottom: 18px;
  width: min(380px, calc(100vw - 24px));
  padding: var(--space-4);
  overflow: auto;
  transform: translateX(calc(100% + 28px));
  transition: transform 0.18s ease;
  z-index: 1040;
}

.dispatch-drawer.open {
  transform: translateX(0);
}

/* ─── Report Panels ──────────────────────────────────────────────────────── */
.report-filter-bar,
.report-panel {
  border: 1px solid var(--border-default);
  background: var(--surface-card);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-4);
}

.report-panel h2 {
  color: var(--color-neutral-900);
  font-size: 14px;
  font-weight: 600;
  margin: 0 0 var(--space-3);
}

.report-list {
  display: grid;
  gap: var(--space-2);
}

.report-bar-row {
  display: grid;
  grid-template-columns: minmax(110px, 0.8fr) minmax(120px, 2fr) minmax(
      84px,
      auto
    );
  gap: var(--space-2);
  align-items: center;
}

.report-bar-label,
.report-bar-value {
  color: var(--color-neutral-700);
  font-size: 13px;
  font-weight: 600;
  min-width: 0;
  overflow-wrap: anywhere;
}

.report-bar-value {
  text-align: right;
}

.report-bar-track {
  height: 8px;
  overflow: hidden;
  border-radius: 100px;
  background: var(--color-neutral-100);
}

.report-bar-fill {
  height: 100%;
  border-radius: 100px;
  background: var(--color-brand-600);
}

/* ─── Auth Shell ─────────────────────────────────────────────────────────── */
.auth-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: var(--space-8) var(--space-4);
  background: var(--surface-page);
}

.auth-card {
  width: min(100%, 420px);
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}

.auth-brand {
  padding: var(--space-6) var(--space-6) var(--space-5);
  border-bottom: 1px solid var(--border-default);
  background: var(--surface-muted);
}

.auth-brand-mark {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-md);
  display: grid;
  place-items: center;
  color: #fff;
  background: var(--color-brand-600);
  margin-bottom: var(--space-4);
  font-size: 20px;
}

.auth-brand h1 {
  font-size: 20px;
  font-weight: 700;
  margin: 0;
  color: var(--color-neutral-900);
}

.auth-brand p {
  color: var(--color-neutral-500);
  margin: var(--space-1) 0 0;
  font-size: 14px;
}

.auth-form {
  padding: var(--space-6);
}

.auth-form .btn {
  min-height: 40px;
  border-radius: var(--radius-md);
  font-weight: 600;
}

/* ─── Confirm Dialog ─────────────────────────────────────────────────────── */
.app-confirm-dialog {
  --bs-modal-width: min(92vw, 400px);
}

.app-confirm-dialog .modal-content {
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
}

.app-confirm-dialog .modal-header {
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-5) var(--space-5) var(--space-3);
  border-bottom: none;
}

.app-confirm-dialog .modal-title {
  color: var(--color-neutral-900);
  font-size: 16px;
  font-weight: 600;
  line-height: 1.25;
}

.app-confirm-dialog .app-confirm-kicker {
  color: var(--color-neutral-500);
  font-size: 13px;
  margin-top: var(--space-1);
}

.app-confirm-dialog .app-confirm-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}

.app-confirm-dialog .app-confirm-icon.icon-warning {
  background: var(--color-warning-50);
  color: var(--color-warning-600);
}

.app-confirm-dialog .app-confirm-icon.icon-danger {
  background: var(--color-danger-50);
  color: var(--color-danger-600);
}

.app-confirm-dialog .app-confirm-icon.icon-info {
  background: var(--color-info-50);
  color: var(--color-info-600);
}

.app-confirm-dialog .modal-body {
  color: var(--color-neutral-700);
  padding: 0 var(--space-5) var(--space-5) 76px;
  font-size: 14px;
}

.app-confirm-dialog .modal-footer {
  gap: var(--space-2);
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid var(--border-default);
}

.app-confirm-dialog .btn {
  min-width: 88px;
}

@media (max-width: 575px) {
  .app-confirm-dialog .modal-body {
    padding-left: var(--space-5);
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   PUBLIC PAGES  (Pay, Estimate viewer, status screens)
   ═══════════════════════════════════════════════════════════════════════════ */

.public-card {
  width: min(100%, 480px);
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}

.public-card-wide {
  width: min(100%, 880px);
}

/* Header bar inside a public card */
.public-card-header {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-6);
  background: var(--surface-muted);
  border-bottom: 1px solid var(--border-default);
}

.public-brand-mark {
  width: 38px;
  height: 38px;
  border-radius: var(--radius-md);
  background: var(--color-brand-600);
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 17px;
  flex-shrink: 0;
  margin-top: 2px;
}

.public-card-eyebrow {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-neutral-500);
  margin-bottom: var(--space-1);
}

.public-card-title {
  font-size: 17px;
  font-weight: 600;
  color: var(--color-neutral-900);
  line-height: 1.25;
}

.public-card-meta {
  font-size: 13px;
  color: var(--color-neutral-500);
  margin-top: 2px;
}

/* Sections with dividers */
.public-card-section {
  border-bottom: 1px solid var(--border-default);
}

/* Body padding */
.public-card-body {
  padding: var(--space-5) var(--space-6);
}

/* Footer (terms, actions) */
.public-card-footer {
  padding: var(--space-5) var(--space-6);
  background: var(--surface-muted);
  border-top: 1px solid var(--border-default);
}

/* Section heading label */
.public-section-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-neutral-500);
  margin-bottom: var(--space-2);
}

/* Balance row */
.public-balance-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4) 0;
  margin-bottom: var(--space-4);
  border-bottom: 1px solid var(--border-default);
}

.public-balance-label {
  font-size: 14px;
  color: var(--color-neutral-700);
  font-weight: 500;
}

.public-balance-amount {
  font-size: 22px;
  font-weight: 700;
  color: var(--color-neutral-900);
}

/* Inline alert strip */
.public-alert {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  font-size: 14px;
  margin-bottom: var(--space-4);
}

.public-alert-danger {
  background: var(--color-danger-50);
  color: var(--color-danger-600);
  border-left: 3px solid var(--color-danger-600);
}

.public-alert-warning {
  background: var(--color-warning-50);
  color: var(--color-warning-600);
  border-left: 3px solid var(--color-warning-600);
}

/* Totals grid */
.public-totals-grid {
  display: grid;
  gap: var(--space-2);
  max-width: 320px;
  margin-left: auto;
}

.public-totals-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 14px;
  color: var(--color-neutral-700);
}

.public-totals-divider {
  height: 1px;
  background: var(--border-default);
  margin: var(--space-1) 0;
}

.public-totals-grand {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-neutral-900);
}

.public-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  font-size: 13px;
  color: var(--color-neutral-500);
}

/* Status result screens (success / error / warning) */
.public-status-block {
  padding: var(--space-10) var(--space-8);
  text-align: center;
}

.public-status-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 22px;
  margin: 0 auto var(--space-4);
  flex-shrink: 0;
}

.public-status-icon.icon-success {
  background: var(--color-success-50);
  color: var(--color-success-600);
}

.public-status-icon.icon-danger {
  background: var(--color-danger-50);
  color: var(--color-danger-600);
}

.public-status-icon.icon-warning {
  background: var(--color-warning-50);
  color: var(--color-warning-600);
}

.public-status-icon.icon-neutral {
  background: var(--color-neutral-100);
  color: var(--color-neutral-600);
}

.public-status-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--color-neutral-900);
  margin-bottom: var(--space-2);
}

.public-status-desc {
  font-size: 14px;
  color: var(--color-neutral-500);
  max-width: 320px;
  margin: 0 auto;
  line-height: 1.6;
}

/* Public form controls */
.public-card .form-control,
.public-card .form-select {
  height: 40px;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  font-size: 14px;
  transition:
    border-color 0.15s,
    box-shadow 0.15s;
}

.public-card .form-control:focus,
.public-card .form-select:focus {
  border-color: var(--color-brand-600);
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.12);
  outline: none;
}

.public-card .form-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--color-neutral-700);
  margin-bottom: var(--space-1);
}

.public-card .input-group-text {
  background: var(--surface-muted);
  border-color: var(--border-default);
  color: var(--color-neutral-500);
}

/* Public page table override */
.public-card .app-data-table thead th {
  padding: 10px var(--space-6);
}

.public-card .app-data-table tbody td {
  padding: 10px var(--space-6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   PHASE 5 — SETTINGS LAYOUT
   ═══════════════════════════════════════════════════════════════════════════ */

.settings-layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--space-6);
  align-items: start;
}

.settings-nav {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-2) 0;
  position: sticky;
  top: calc(var(--topbar-h) + var(--space-4));
}

.settings-nav-section {
  padding: var(--space-3) var(--space-4) var(--space-1);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-neutral-400);
}

.settings-nav-link {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-4);
  font-size: 14px;
  color: var(--color-neutral-600);
  text-decoration: none;
  border-radius: 0;
  transition:
    background 0.12s,
    color 0.12s;
}

.settings-nav-link i {
  width: 16px;
  text-align: center;
  color: var(--color-neutral-400);
  transition: color 0.12s;
}

.settings-nav-link:hover {
  background: var(--surface-muted);
  color: var(--color-neutral-900);
}

.settings-nav-link:hover i {
  color: var(--color-neutral-600);
}

.settings-nav-link.active {
  background: var(--color-brand-50);
  color: var(--color-brand-600);
  font-weight: 600;
}

.settings-nav-link.active i {
  color: var(--color-brand-600);
}

.settings-content {
  display: grid;
  gap: var(--space-5);
}

.settings-section {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.settings-section-header {
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--border-default);
  background: var(--surface-muted);
}

.settings-section-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--color-neutral-900);
  margin: 0;
}

.settings-section-desc {
  font-size: 13px;
  color: var(--color-neutral-500);
  margin-top: var(--space-1);
}

.settings-section-body {
  padding: var(--space-5);
}

.settings-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-8);
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--border-default);
}

.settings-row:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.settings-row-label {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-neutral-900);
  flex: 0 0 220px;
}

.settings-row-hint {
  font-size: 13px;
  color: var(--color-neutral-500);
  margin-top: var(--space-1);
}

.settings-row-control {
  flex: 1;
}

@media (max-width: 767px) {
  .settings-layout {
    grid-template-columns: 1fr;
  }

  .settings-nav {
    position: static;
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-1);
    padding: var(--space-2);
  }

  .settings-nav-link {
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
  }

  .settings-nav-section {
    display: none;
  }

  .settings-row {
    flex-direction: column;
    gap: var(--space-3);
  }

  .settings-row-label {
    flex: none;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   PHASE 6 — POLISH: TRANSITIONS, HOVER STATES, RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════════ */

/* Sidebar nav link smooth transitions */
.dispatch-shell .sidebar .nav-link {
  transition:
    background 0.12s ease,
    color 0.12s ease,
    padding-left 0.12s ease;
}

.dispatch-shell .sidebar .nav-link:hover .link-title {
  color: var(--sidebar-text-active);
}

/* Hub card hover lift */
.app-hub-card {
  transition:
    box-shadow 0.18s ease,
    transform 0.18s ease,
    border-color 0.18s ease;
}

.app-hub-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--color-brand-300, #a5b4fc);
  text-decoration: none;
}

/* Metric card hover lift */
.app-metric-card {
  transition:
    box-shadow 0.18s ease,
    transform 0.18s ease;
}

.app-metric-card:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

/* Data table row hover */
.app-data-table tbody tr {
  transition: background 0.1s;
}

/* Status badge appear */
.status-badge {
  transition: opacity 0.15s;
}

/* Topbar avatar */
.topbar-avatar-circle {
  transition: box-shadow 0.15s;
}

.topbar-avatar-circle:hover {
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2);
}

/* Public card hover (estimate viewer) */
.public-card {
  transition: box-shadow 0.18s ease;
}

/* Smooth page fade-in */
@keyframes pageFadeIn {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.dispatch-shell .page-content {
  animation: pageFadeIn 0.2s ease both;
}

/* ─── Responsive: Main layout ────────────────────────────────────────────── */

@media (max-width: 991px) {
  .dispatch-shell {
    grid-template-columns: 1fr;
  }

  .dispatch-shell .sidebar {
    display: none;
  }

  .dispatch-shell .topbar {
    grid-column: 1;
  }

  .dispatch-shell .page-content {
    grid-column: 1;
  }
}

@media (max-width: 767px) {
  .app-hub-grid {
    grid-template-columns: 1fr;
  }

  .app-metric-grid {
    grid-template-columns: 1fr 1fr;
  }

  .app-page-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
  }

  .app-page-actions {
    width: 100%;
  }

  .app-filter-bar {
    height: auto;
    flex-wrap: nowrap;
    padding: var(--space-2) var(--space-3);
    gap: var(--space-2);
  }

  .app-filter-bar .filter-search {
    min-width: 0;
    width: auto;
    padding-right: 0;
  }

  .app-filter-bar .filter-actions {
    width: auto;
    padding-left: 0;
  }
}

@media (max-width: 575px) {
  .app-metric-grid {
    grid-template-columns: 1fr;
  }

  .public-card-header {
    flex-wrap: wrap;
  }

  .public-status-block {
    padding: var(--space-8) var(--space-5);
  }

  .public-card-body,
  .public-card-footer {
    padding: var(--space-4);
  }

  .public-totals-grid {
    max-width: 100%;
  }

  .auth-shell {
    padding: var(--space-4) var(--space-3);
  }
}

/* ─── List Group ─────────────────────────────────────────────────────────── */
.dispatch-shell .list-group,
.dispatch-auth .list-group {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.dispatch-shell .list-group-item,
.dispatch-auth .list-group-item {
  border-color: var(--border-default);
  color: var(--color-neutral-700);
  padding: var(--space-3) var(--space-4);
}

.dispatch-shell .list-group-item-action:hover {
  background: var(--color-neutral-50);
}

/* ─── Alerts ─────────────────────────────────────────────────────────────── */
.dispatch-shell .alert:empty,
.dispatch-auth .alert:empty {
  display: none;
}

/* ─── Admin / Role pickers ───────────────────────────────────────────────── */
.user-create-form .form-check {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-height: 100%;
}

.user-role-select {
  min-height: 10.5rem;
}

.user-branch-check {
  margin-top: 1.55rem;
}

.user-state-form {
  width: 100%;
  max-width: 16rem;
}

.role-picker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
  gap: var(--space-3);
}

.role-picker-item {
  display: block;
  margin: 0;
  position: relative;
}

.role-picker-input {
  position: absolute;
  inset: 0;
  margin: 0;
  opacity: 0;
  cursor: pointer;
}

.role-picker-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-height: 100%;
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  background: var(--surface-card);
  transition:
    border-color 0.15s,
    box-shadow 0.15s,
    transform 0.15s;
}

.role-picker-input:checked + .role-picker-card {
  border-color: var(--color-brand-600);
  box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.15);
  transform: translateY(-1px);
}

.role-picker-input:focus-visible + .role-picker-card {
  outline: 0;
  box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.18);
}

.role-picker-name {
  color: var(--color-neutral-900);
  font-weight: 600;
}

.role-picker-hint {
  color: var(--color-neutral-500);
  font-size: 12px;
  line-height: 1.3;
}

/* ─── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 991px) {
  .app-metric-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .app-hub-grid,
  .app-command-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dispatch-board-shell {
    grid-template-columns: 1fr;
  }

  .dispatch-queue {
    min-height: 0;
  }

  .report-bar-row {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .report-bar-value {
    text-align: left;
  }
}

@media (max-width: 767px) {
  .app-page-header {
    flex-direction: column;
  }

  .app-page-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .app-metric-grid {
    grid-template-columns: 1fr;
  }

  .app-hub-grid,
  .app-command-strip {
    grid-template-columns: 1fr;
  }
}
