﻿/* =====================================================================
   Tunwal Ops ERP — internal-tool stylesheet
   See skills.md §2.A for the design philosophy this file applies.
   ===================================================================== */

/* ---------- 1. Design tokens (single source of truth) ---------------- */
:root {
  /* Type scale */
  --fs-xxs: 11px;
  --fs-xs:  12px;
  --fs-sm:  13px;
  --fs-md:  14px;   /* body */
  --fs-lg:  16px;
  --fs-xl:  20px;
  --fs-xxl: 24px;

  /* Spacing scale (4-based) */
  --sp-1: 4px;
  --sp-2: 8px;
  --sp-3: 12px;
  --sp-4: 16px;
  --sp-5: 24px;
  --sp-6: 32px;
  --sp-7: 48px;

  /* Radius */
  --r-sm: 4px;
  --r-md: 6px;
  --r-lg: 8px;
  --r-xl: 12px;
  --r-pill: 999px;

  /* Colour — neutral 60% */
  --bg:           #eef2f8;       /* page */
  --surface:      #ffffff;       /* cards, tables, inputs */
  --surface-2:    #f6f8fc;       /* alt rows, subtle backgrounds */
  --surface-3:    #e9eef6;       /* hover, chips */
  --border:       #e3e8f1;       /* dividers, input borders — lighter; lean on shadow */
  --border-strong:#c7cedb;       /* emphasized dividers */
  --fg:           #1a1d23;       /* primary text */
  --fg-2:         #3d4754;       /* secondary text */
  --muted:        #6a7382;       /* tertiary / hints */

  /* Colour — brand 10% */
  --primary:        #1b4d8f;
  --primary-fg:     #ffffff;
  --primary-soft:   #e7effb;
  --primary-hover:  #163e72;
  --grad-brand:     linear-gradient(135deg, #245aa0 0%, #163e72 100%);
  --danger-hover:   #921e1e;
  --danger-fg-inv:  #ffffff;

  /* Colour — semantic */
  --success:      #1d8a3b;
  --success-bg:   #e3f5e1;
  --success-fg:   #14572a;

  --warn:         #b06b00;
  --warn-bg:      #fde8c8;
  --warn-fg:      #6f4a0c;

  --danger:       #b53030;
  --danger-bg:    #fde8e8;
  --danger-fg:    #8a1f1f;

  --info-bg:      #d6dffb;
  --info-fg:      #1b2f5d;

  /* Shadow */
  --shadow-sm: 0 1px 2px rgba(20, 30, 50, 0.05), 0 1px 1px rgba(20, 30, 50, 0.04);
  --shadow-md: 0 2px 4px rgba(20, 30, 50, 0.05), 0 10px 24px rgba(20, 30, 50, 0.08);
  --shadow-lg: 0 18px 40px rgba(20, 30, 50, 0.14), 0 6px 12px rgba(20, 30, 50, 0.06);

  /* Layout */
  --container-w: 1180px;
  --topbar-h:    52px;
  --sidebar-w:   240px;
}

/* ---------- 2. Base & reset ----------------------------------------- */
* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  font: var(--fs-md)/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  color: var(--fg);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
}
a { color: var(--primary); }
a:hover { text-decoration: underline; }
hr { border: 0; border-top: 1px solid var(--border); margin: var(--sp-4) 0; }

/* ---------- 3. Topbar (thin: brand + user dropdown only) ------------ */
.topbar {
  display: flex; align-items: center;
  padding: var(--sp-2) var(--sp-4);
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  box-shadow: 0 1px 3px rgba(20, 30, 50, 0.05);
  gap: var(--sp-3);
  min-height: var(--topbar-h);
  position: sticky; top: 0; z-index: 100;
}
.brand { flex-shrink: 0; }
.brand a { display: inline-flex; align-items: center; gap: var(--sp-2); font-weight: 700; color: var(--primary); text-decoration: none; font-size: var(--fs-lg); letter-spacing: -0.01em; }
.brand a::before {
  content: ""; display: inline-block; flex-shrink: 0;
  width: 30px; height: 30px; border-radius: 6px;
  background: url('/public/img/tunwal-logo.png') center/contain no-repeat;
}
.brand a:hover { text-decoration: none; opacity: 0.9; }
.topbar-spacer { flex: 1; }

.sidebar-toggle {
  display: none;
  align-items: center; justify-content: center;
  width: 36px; height: 36px; padding: 0;
  border: 1px solid var(--border); border-radius: var(--r-sm);
  background: var(--surface);
  font-size: 18px; cursor: pointer;
}

/* (Legacy .nav styles kept below; only the account-area dropdown still uses .navgroup.) */
.nav { display: flex; gap: var(--sp-1); align-items: center; flex: 1; }
.nav .navspacer { flex: 1; }
.nav .navlink, .nav .navtrigger {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-md);
  color: var(--fg); text-decoration: none;
  background: none; border: none; cursor: pointer;
  font: inherit; line-height: 1.2;
  transition: background 120ms ease;
}
.nav .navlink:hover, .nav .navtrigger:hover { text-decoration: none; }
.nav .navlink:hover, .nav .navtrigger:hover { background: var(--surface-3); }
.nav .navcaret { font-size: 9px; color: var(--muted); }

.navgroup { position: relative; }

/* The dropdown menu — a real visible card, no pseudo-element trickery.
   No visual gap to the trigger: menu sits flush against the trigger so the
   hover area is continuous (cursor never leaves the hover zone). */
.navgroup .navmenu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  margin: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-md);
  min-width: 220px;
  padding: var(--sp-1);
  z-index: 1000;
}

/* Open on hover OR via .open class (JS toggles for click/keyboard) */
.navgroup:hover > .navmenu,
.navgroup:focus-within > .navmenu,
.navgroup.open > .navmenu { display: block; }

.navgroup .navmenu a,
.navgroup .navmenu button {
  display: block; width: 100%;
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-sm);
  color: var(--fg); text-decoration: none;
  font: inherit; text-align: left;
  background: none; border: none; cursor: pointer;
}
.navgroup .navmenu a:hover,
.navgroup .navmenu button:hover { background: var(--surface-3); }
.navgroup .navmenu-right { left: auto; right: 0; }
.navgroup .navlogout {
  margin: var(--sp-1) 0 0; padding: var(--sp-1) 0 0;
  border-top: 1px solid var(--border);
}
.navgroup .navlogout button { color: var(--danger); width: 100%; }

/* Caret rotates 180° when the dropdown is open */
.navcaret { display: inline-block; transition: transform 150ms ease; }
.navgroup:hover > .navtrigger .navcaret,
.navgroup:focus-within > .navtrigger .navcaret,
.navgroup.open > .navtrigger .navcaret { transform: rotate(180deg); }

.nav .navaccount .who { color: var(--muted); font-size: var(--fs-sm); }
.nav .navaccount .role { font-size: var(--fs-xxs); }

@media (max-width: 900px) {
  .topbar { padding: var(--sp-2) var(--sp-3); }
  .navgroup .navmenu, .navgroup .navmenu-right { left: 0; right: auto; }
  .nav .navaccount .who { display: none; }
}

/* ---------- 4. App shell: sidebar + main content -------------------- */
/* Flexbox shell so the sidebar can be absent (login page) without leaving an
   empty 240 px reservation. Sidebar is a fixed-width flex item; main takes
   the rest. When no sidebar is rendered, main is the sole flex item taking
   100 % width — `.container { margin: 0 auto }` then centres it in viewport. */
.app-shell {
  display: flex;
  min-height: calc(100vh - var(--topbar-h) - 60px);
}
.app-shell > main { flex: 1 1 auto; min-width: 0; }   /* min-width:0 lets long tables not overflow */

.sidebar {
  flex: 0 0 var(--sidebar-w);   /* fixed width, no shrink, no grow */
  background: linear-gradient(180deg, var(--surface) 0%, var(--surface-2) 100%);
  border-right: 1px solid var(--border);
  padding: var(--sp-3) var(--sp-2);
  position: sticky;
  top: var(--topbar-h);
  align-self: flex-start;
  height: calc(100vh - var(--topbar-h));
  overflow-y: auto;
  display: flex; flex-direction: column;
}
.sidebar-overlay {
  display: none;
  position: fixed; inset: var(--topbar-h) 0 0 0;
  background: rgba(15, 18, 23, 0.45);
  z-index: 90;
}

.sidenav { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.sidenav .sidelink, .sidenav .sidegroup-head {
  display: block;
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-md);
  color: var(--fg);
  text-decoration: none;
  font-size: var(--fs-md);
  line-height: 1.3;
}
.sidenav .sidelink:hover, .sidenav .sidegroup-head:hover {
  background: var(--surface-3);
  text-decoration: none;
}
.sidenav .sidelink.active {
  background: var(--primary-soft);
  color: var(--primary);
  font-weight: 600;
  box-shadow: inset 3px 0 0 var(--primary);
}
.sidenav .sidelink.home { font-weight: 500; }

.sidenav .sidegroup { margin-top: var(--sp-3); display: flex; flex-direction: column; gap: 1px; }
.sidenav .sidegroup-row {
  display: flex; align-items: center;
  /* Head label gets the full row click area; toggle button sits flush right. */
}
.sidenav .sidegroup-head {
  flex: 1;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--fg-2);
  font-weight: 700;
  padding-top: var(--sp-2);
  padding-bottom: var(--sp-1);
}
.sidenav .sidegroup-head:hover { color: var(--fg-2); background: transparent; }
.sidenav .sidegroup-head.active { background: transparent; color: var(--primary); }
.sidenav .sidegroup-toggle {
  background: transparent; border: 0; color: var(--muted);
  padding: 4px 10px; cursor: pointer; font-size: 11px;
  line-height: 1; border-radius: var(--r-sm);
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 28px;
  transition: color 120ms, background-color 120ms;
}
.sidenav .sidegroup-toggle:hover { color: var(--fg); background: var(--surface-2); }
.sidenav .sidegroup-toggle .caret { display: inline-block; transition: transform 120ms; }
.sidenav .sidegroup .sidelink {
  padding-left: var(--sp-4);
  font-size: var(--fs-sm);
  color: var(--fg-2);
}
/* Collapsible behaviour — when `.collapsed` is on the sidegroup, hide the items. */
.sidenav .sidegroup-items {
  display: flex; flex-direction: column; gap: 1px;
  overflow: hidden;
  max-height: 600px;
  transition: max-height 180ms ease-out;
}
.sidenav .sidegroup.collapsed .sidegroup-items {
  max-height: 0;
}

/* ---------- 30a. Search-icon button (filter bars) ----------------- */
/* Wrap the search text input + its icon button so they look like one control. */
.filters .search-input {
  display: inline-flex; align-items: stretch;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--surface);
  overflow: hidden;
}
.filters .search-input input[type="text"] {
  border: 0; border-radius: 0; outline: 0;
  padding: var(--sp-2) var(--sp-3);
  background: transparent;
  min-width: 240px;
}
.filters .search-input input[type="text"]:focus {
  outline: 0;
}
.filters .search-input:focus-within {
  outline: 2px solid var(--primary);
  outline-offset: -1px;
  border-color: var(--primary);
}
.filters .search-icon-btn {
  background: var(--surface-2);
  border: 0;
  border-left: 1px solid var(--border);
  padding: 0 var(--sp-3);
  cursor: pointer; font-size: 14px;
  display: flex; align-items: center; justify-content: center;
  min-width: 36px;
  color: var(--fg-2);
  transition: background-color 120ms, color 120ms;
}
.filters .search-icon-btn:hover { background: var(--primary); color: white; }

/* ---------- 30. Topbar back button ---------------------------------- */
.topbar .back-btn {
  display: inline-flex; align-items: center; gap: 4px;
  background: transparent; border: 1px solid var(--border);
  color: var(--fg-2); cursor: pointer;
  padding: 4px 12px; border-radius: var(--r-sm);
  font: inherit; font-size: var(--fs-xs); font-weight: 500;
  margin-left: var(--sp-3);
  transition: background-color 120ms, color 120ms, border-color 120ms;
}
.topbar .back-btn:hover { background: var(--surface-2); color: var(--fg); border-color: var(--fg-2); }
.topbar .back-btn:focus-visible { outline: 2px solid var(--primary); outline-offset: 1px; }
.topbar .back-btn .back-arrow { font-size: 14px; line-height: 1; }
.topbar .back-btn .back-label { margin-left: 4px; }
@media (max-width: 600px) {
  .topbar .back-btn { padding: 4px 8px; margin-left: var(--sp-2); }
  .topbar .back-btn .back-label { display: none; }  /* mobile: keep arrow only */
}

.sidebar-foot {
  padding: var(--sp-2) var(--sp-3);
  border-top: 1px solid var(--border);
  margin-top: var(--sp-3);
}

.container { max-width: var(--container-w); margin: 0 auto; padding: var(--sp-5); width: 100%; }
.footer {
  text-align: center; padding: var(--sp-3) var(--sp-5);
  color: var(--muted); font-size: var(--fs-xs);
  border-top: 1px solid var(--border); background: var(--surface);
}

/* Mobile: sidebar slides in from left as an overlay (taken out of the flex
   flow via position:fixed). Main becomes the only in-flow flex item. */
@media (max-width: 900px) {
  .sidebar {
    flex: none;
    position: fixed;
    top: var(--topbar-h);
    left: 0;
    width: 260px;
    height: calc(100vh - var(--topbar-h));
    transform: translateX(-100%);
    transition: transform 200ms ease;
    z-index: 95;
    box-shadow: var(--shadow-lg);
  }
  .sidebar.open { transform: translateX(0); }
  .sidebar-overlay.open { display: block; }
  .sidebar-toggle { display: inline-flex; }
}

/* ---------- 5. Typography ------------------------------------------- */
h1 { font-size: var(--fs-xxl); font-weight: 700; margin: 0 0 var(--sp-4); line-height: 1.2; letter-spacing: -0.02em; }
h2 { font-size: var(--fs-lg); font-weight: 600; margin: var(--sp-5) 0 var(--sp-2); line-height: 1.3; }
h3 { font-size: var(--fs-md); font-weight: 600; margin: var(--sp-4) 0 var(--sp-2); }
p  { margin: var(--sp-2) 0; }
.muted { color: var(--muted); }
.small { font-size: var(--fs-xs); }
.fg2   { color: var(--fg-2); }
.tabular { font-variant-numeric: tabular-nums; }

/* ---------- 6. Forms ------------------------------------------------- */
label { display: block; margin: var(--sp-3) 0; font-weight: 500; color: var(--fg-2); font-size: var(--fs-sm); }
input, select, textarea {
  width: 100%;
  padding: var(--sp-2) var(--sp-3);
  font: inherit;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--surface);
  color: var(--fg);
  line-height: 1.4;
}
input:focus, select:focus, textarea:focus {
  outline: 2px solid var(--primary);
  outline-offset: -1px;
  border-color: var(--primary);
}
textarea { resize: vertical; min-height: 60px; }
input[type="checkbox"], input[type="radio"] { width: auto; }
.narrow { max-width: 440px; }

/* ---------- 7. Buttons ---------------------------------------------- */
button, .button {
  display: inline-flex; align-items: center; gap: var(--sp-1);
  padding: var(--sp-2) var(--sp-3);
  border: 1px solid var(--border);
  background: var(--surface);
  border-radius: var(--r-sm);
  cursor: pointer; font: inherit; color: var(--fg);
  text-decoration: none; line-height: 1.4;
  transition: background 120ms ease, border-color 120ms ease;
}
button:hover, .button:hover { background: var(--surface-3); border-color: var(--border-strong); text-decoration: none; }
button:focus-visible, .button:focus-visible { outline: 2px solid var(--primary); outline-offset: 1px; }
button.primary, .button.primary {
  background: var(--grad-brand); color: var(--primary-fg);
  border-color: var(--primary-hover); font-weight: 600;
  box-shadow: 0 1px 2px rgba(22, 62, 114, 0.25);
}
button.primary:hover, .button.primary:hover { background: var(--primary-hover); border-color: var(--primary-hover); box-shadow: 0 2px 6px rgba(22, 62, 114, 0.30); }
button.danger, .button.danger {
  background: var(--danger); color: var(--danger-fg-inv); border-color: var(--danger);
}
button.danger:hover, .button.danger:hover { background: var(--danger-hover); border-color: var(--danger-hover); }
button.small, .button.small { padding: var(--sp-1) var(--sp-2); font-size: var(--fs-xs); }
button.link {
  background: none; border: none; padding: 0;
  color: var(--primary); cursor: pointer; text-decoration: underline;
}

/* ---------- 8. Cards ------------------------------------------------- */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-5);
  box-shadow: var(--shadow-md);
}
.card.narrow { max-width: 440px; margin: var(--sp-6) auto; }
/* All cards in the .grid share the same height per row AND across rows,
   regardless of content length. Combined with `.dash-actions { margin-top: auto }`
   the action buttons sit on the same baseline across every tile. */
.grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  grid-auto-rows: 1fr;
  align-items: stretch;
  gap: var(--sp-4);
}
.card h2 { margin-top: 0; }
.card h2:first-child { margin-top: 0; }

/* ---------- 9. Tables ----------------------------------------------- */
.data {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  margin: var(--sp-3) 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
}
.data th, .data td {
  padding: var(--sp-2) var(--sp-3);
  text-align: left;
  border-bottom: 1px solid var(--border);
  vertical-align: top;
  line-height: 1.4;
}
.data tbody tr:last-child td { border-bottom: 0; }
.data th {
  font-weight: 600;
  background: var(--surface-2);
  color: var(--fg-2);
  font-size: var(--fs-sm);
  position: sticky;
  top: 0;
  z-index: 1;
}
.data tbody tr:hover { background: var(--surface-2); }
.data tbody tr:nth-child(even) { background: rgba(248, 250, 252, 0.4); }
.data tbody tr:nth-child(even):hover { background: var(--surface-2); }
.data td.num, .data th.num { text-align: right; font-variant-numeric: tabular-nums; }
.data tfoot tr.totals td {
  border-top: 2px solid var(--border-strong);
  background: var(--surface-2);
  font-weight: 500;
}
.data td a { font-weight: 500; }
.data .empty-row td {
  text-align: center;
  color: var(--muted);
  padding: var(--sp-6) var(--sp-3);
  font-size: var(--fs-sm);
}

tr.below-reorder { background: var(--danger-bg) !important; }
tr.below-reorder td:first-child { box-shadow: inset 4px 0 0 var(--danger); }

/* ---------- 10. Tags & pills (unified) ------------------------------ */
/* All status/category/role badges share this base. */
.tag, .role, .status, .shipstatus, .cat, .action {
  display: inline-block;
  padding: 2px var(--sp-2);
  border-radius: var(--r-pill);
  font-size: var(--fs-xxs);
  font-weight: 500;
  background: var(--surface-3);
  color: var(--fg-2);
  line-height: 1.5;
  letter-spacing: 0.2px;
  white-space: nowrap;
}
.cat, .action {
  border-radius: var(--r-sm);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.action { font-family: ui-monospace, Menlo, Consolas, monospace; text-transform: none; letter-spacing: 0; }

/* Role variants */
.role-admin         { background: var(--warn-bg);   color: var(--warn-fg); }
.role-store_manager { background: var(--success-bg);color: var(--success-fg); }
.role-hr            { background: var(--info-bg);   color: var(--info-fg); }
.role-viewer        { background: var(--surface-3); color: var(--fg-2); }

/* Employee status */
.status-active      { background: var(--success-bg);color: var(--success-fg); }
.status-on_leave    { background: var(--warn-bg);   color: var(--warn-fg); }
.status-exited      { background: var(--surface-3); color: var(--muted); }

/* Shipment status */
.shipstatus-in_transit { background: var(--warn-bg);   color: var(--warn-fg); }
.shipstatus-received   { background: var(--success-bg);color: var(--success-fg); }
.shipstatus-partial    { background: var(--info-bg);   color: var(--info-fg); }
.shipstatus-cancelled  { background: var(--surface-3); color: var(--muted); }

/* Material category */
.cat-packaging        { background: var(--warn-bg);   color: var(--warn-fg); }
.cat-raw              { background: var(--info-bg);   color: var(--info-fg); }
.cat-component        { background: var(--success-bg);color: var(--success-fg); }
.cat-finished_vehicle { background: #f3d6f5;          color: #5d1b4f; }

/* Audit action variants */
.action-failed_login        { background: var(--danger-bg);  color: var(--danger-fg); }
.action-login, .action-logout { background: var(--primary-soft); color: var(--info-fg); }

/* Movement-type variants (used on /movements) */
.mvtype { display: inline-block; padding: 2px var(--sp-2); border-radius: var(--r-sm); font-size: var(--fs-xxs); background: var(--surface-3); font-family: ui-monospace, Menlo, Consolas, monospace; color: var(--fg-2); }
.mvtype-purchase, .mvtype-shipment_receipt, .mvtype-production_in,
.mvtype-adjust_in, .mvtype-opening_balance, .mvtype-transfer_in {
  background: var(--success-bg); color: var(--success-fg);
}
.mvtype-dispatch, .mvtype-production_out, .mvtype-adjust_out, .mvtype-transfer_out {
  background: var(--danger-bg); color: var(--danger-fg);
}
.qty-in  { color: var(--success-fg); font-weight: 600; }
.qty-out { color: var(--danger-fg);  font-weight: 600; }

/* ---------- 11. Alerts ---------------------------------------------- */
.error, .success, .flash {
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-md);
  margin-bottom: var(--sp-4);
  font-size: var(--fs-sm);
  border: 1px solid transparent;
}
.error   { background: var(--danger-bg);  color: var(--danger-fg);  border-color: rgba(181, 48, 48, 0.18); }
.success { background: var(--success-bg); color: var(--success-fg); border-color: rgba(29, 138, 59, 0.18); }
.flash   { background: var(--primary-soft); color: var(--info-fg);  border-color: rgba(27, 77, 143, 0.15); }

/* ---------- 12. Key-value lists (detail pages) ---------------------- */
dl.kv {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: var(--sp-1) var(--sp-4);
  margin: var(--sp-4) 0;
  padding: var(--sp-4);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
}
dl.kv dt { font-weight: 500; color: var(--muted); font-size: var(--fs-sm); padding: var(--sp-1) 0; }
dl.kv dd { margin: 0; padding: var(--sp-1) 0; }

/* ---------- 13. Filters & pagers ------------------------------------ */
.filters {
  display: flex; gap: var(--sp-2); margin-bottom: var(--sp-4);
  align-items: center; flex-wrap: wrap;
}
.filters input { flex: 1; min-width: 180px; }
.filters select { width: auto; min-width: 120px; }
.filters label { margin: 0; }
.pager { display: flex; gap: var(--sp-3); margin-top: var(--sp-4); align-items: center; }
.pager .muted { margin: 0 auto; }

/* ---------- 14. Line form (shipment + purchase add-line) ------------ */
.line-form {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--sp-2) var(--sp-3);
  align-items: end;
  background: var(--surface);
  padding: var(--sp-4);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
}
.line-form label { margin: 0; }
.line-form button { grid-column: -2 / -1; }

/* ---------- 15. Misc ------------------------------------------------- */
.json { white-space: pre-wrap; word-break: break-word; background: var(--surface-2); padding: var(--sp-2); border-radius: var(--r-sm); font-size: var(--fs-xs); margin: var(--sp-1) 0; font-family: ui-monospace, Menlo, Consolas, monospace; }

/* ---------- 16. Login page (centered) ------------------------------ */
.login-shell {
  min-height: calc(100vh - var(--topbar-h) - 60px);
  display: flex; align-items: center; justify-content: center;
  padding: var(--sp-5);
  background:
    radial-gradient(900px 420px at 50% -8%, rgba(36, 90, 160, 0.10), transparent 70%),
    var(--bg);
}
.login-shell .card {
  width: 100%; max-width: 400px;
  box-shadow: var(--shadow-lg);
  border-radius: var(--r-xl);
  padding: var(--sp-7) var(--sp-6) var(--sp-6);
}
.login-shell .card::before {
  content: "T"; display: grid; place-items: center;
  width: 52px; height: 52px; margin: 0 0 var(--sp-4);
  border-radius: 14px; background: var(--grad-brand);
  color: #fff; font-size: 26px; font-weight: 800;
  box-shadow: var(--shadow-md);
}
.login-shell h1 { font-size: var(--fs-xxl); letter-spacing: -0.02em; }

/* ---------- 16.5 Login — modern landing-page style ----------------- */
.login-page { margin: 0; }
.login-stage {
  position: relative; min-height: 100vh; overflow: hidden;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 48px 24px; color: #fff;
  background:
    radial-gradient(900px 620px at 14% 16%, rgba(196, 24, 43, 0.55), transparent 58%),
    radial-gradient(820px 600px at 88% 86%, rgba(63, 165, 53, 0.32), transparent 60%),
    radial-gradient(680px 460px at 92% 6%, rgba(255, 255, 255, 0.07), transparent 60%),
    linear-gradient(135deg, #270a10 0%, #190709 52%, #0d1110 100%);
}
.login-orb { position: absolute; border-radius: 50%; filter: blur(72px); opacity: 0.5; pointer-events: none; }
.login-orb-1 { width: 380px; height: 380px; background: #d11f33; top: -90px; left: -60px; animation: orbFloat 15s ease-in-out infinite; }
.login-orb-2 { width: 420px; height: 420px; background: #3fa535; bottom: -120px; right: -80px; animation: orbFloat 19s ease-in-out infinite reverse; }
@keyframes orbFloat { 0%, 100% { transform: translate(0, 0); } 50% { transform: translate(26px, -26px); } }

.login-grid {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px; align-items: center;
  width: 100%; max-width: 1000px;
}

.login-brand { animation: loginRise 700ms cubic-bezier(.2, .7, .2, 1) both; }
.login-pill {
  display: inline-flex; align-items: center; gap: 8px; margin-bottom: 22px;
  padding: 6px 14px; border-radius: 999px; font-size: 13px; font-weight: 600; letter-spacing: 0.02em;
  background: rgba(255, 255, 255, 0.10); border: 1px solid rgba(255, 255, 255, 0.18);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
}
.login-pill-dot { width: 8px; height: 8px; border-radius: 50%; background: #3fde62; box-shadow: 0 0 10px #3fde62; }
.login-brand-logo {
  width: 78px; height: auto; display: block; margin-bottom: 22px;
  background: #fff; border-radius: 18px; padding: 9px; box-shadow: 0 16px 40px rgba(0, 0, 0, 0.4);
}
.login-brand h1 { font-size: 42px; line-height: 1.08; margin: 0 0 16px; font-weight: 800; letter-spacing: -0.03em; color: #fff; }
.login-grad {
  background: linear-gradient(100deg, #ff6b7a, #ffd27a 55%, #7dff8e);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.login-lede { font-size: 17px; line-height: 1.55; opacity: 0.86; margin: 0 0 24px; max-width: 440px; }
.login-feats { list-style: none; padding: 0; margin: 0 0 24px; display: grid; gap: 11px; }
.login-feats li { position: relative; padding-left: 30px; font-size: 14.5px; opacity: 0.9; }
.login-feats li::before {
  content: "\2713"; position: absolute; left: 0; top: 0;
  width: 20px; height: 20px; border-radius: 50%;
  background: linear-gradient(135deg, #d11f33, #3fa535); color: #fff;
  display: grid; place-items: center; font-size: 11px; font-weight: 800;
}
.login-motto { font-size: 15px; font-style: italic; opacity: 0.8; margin: 0; }

.login-card {
  position: relative;
  background: rgba(255, 255, 255, 0.96);
  -webkit-backdrop-filter: blur(18px); backdrop-filter: blur(18px);
  border: 1px solid rgba(255, 255, 255, 0.55); border-radius: 22px;
  padding: 36px 34px 28px; color: var(--fg);
  box-shadow: 0 40px 80px rgba(0, 0, 0, 0.45);
  animation: loginRise 700ms cubic-bezier(.2, .7, .2, 1) 120ms both;
}
.login-card h2 { font-size: 26px; margin: 0; letter-spacing: -0.02em; color: var(--fg); }
.login-card-sub { color: var(--muted); font-size: 13px; margin: 4px 0 0; }
.login-card label { display: block; margin-top: 16px; font-weight: 600; font-size: 13.5px; color: var(--fg-2); }
.login-card input { width: 100%; margin-top: 6px; }
.login-submit {
  width: 100%; margin-top: 22px; padding: 12px; border: 0; border-radius: 10px;
  background: linear-gradient(135deg, #d11f33, #a3162a); color: #7dff8e;
  font-weight: 700; font-size: 15px; letter-spacing: 0.04em; cursor: pointer;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.30);
  box-shadow: 0 8px 20px rgba(163, 22, 42, 0.35);
  transition: background 150ms, box-shadow 150ms, transform 150ms, color 150ms;
}
/* explicit hover bg + colour so the generic button:hover (light grey) can't win */
.login-submit:hover {
  background: linear-gradient(135deg, #b81a2d, #871222);
  color: #9dffb0;
  box-shadow: 0 12px 28px rgba(163, 22, 42, 0.45), 0 0 0 1px rgba(63, 165, 53, 0.5);
  transform: translateY(-1px);
}
.login-submit:active { transform: translateY(0); box-shadow: 0 6px 16px rgba(163, 22, 42, 0.42); }

/* Forgot password — present now, wired up next phase */
.login-forgot { margin-top: 12px; text-align: center; }
.login-forgot summary {
  display: inline-block; cursor: pointer; list-style: none;
  font-size: 13px; font-weight: 600; color: #a3162a;
}
.login-forgot summary::-webkit-details-marker { display: none; }
.login-forgot summary:hover { text-decoration: underline; }
.login-forgot p { margin: 8px auto 0; max-width: 300px; font-size: 12.5px; color: var(--muted); line-height: 1.45; }
.login-card-foot { margin-top: 16px; text-align: center; color: var(--muted); font-size: 12px; }

.login-credit { position: relative; z-index: 1; margin: 28px 0 0; font-size: 12.5px; color: rgba(255, 255, 255, 0.6); }
.login-credit strong { color: rgba(255, 255, 255, 0.9); font-weight: 700; }

@keyframes loginRise { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }

@media (max-width: 880px) {
  .login-grid { grid-template-columns: 1fr; gap: 30px; max-width: 430px; }
  .login-brand { text-align: center; }
  .login-pill, .login-brand-logo { margin-left: auto; margin-right: auto; }
  .login-brand h1 { font-size: 32px; }
  .login-lede { margin-left: auto; margin-right: auto; }
  .login-feats { display: none; }
}
@media (prefers-reduced-motion: reduce) { .login-orb, .login-brand, .login-card { animation: none; } }

/* ---------- 17. Home dashboard accents ------------------------------ */
.kpi {
  display: grid; gap: var(--sp-1);
  padding: var(--sp-3) 0;
}
.kpi .num {
  font-size: var(--fs-xxl);
  font-weight: 600;
  line-height: 1.1;
  font-variant-numeric: tabular-nums;
  color: var(--fg);
}
.kpi .label { color: var(--muted); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.5px; }
.card.dash {
  border-top: 3px solid var(--primary);
  /* Flex column so .dash-actions can sit at the bottom regardless of how much
     content the card has — keeps tile bottoms aligned in a grid row. */
  display: flex;
  flex-direction: column;
}
/* Card-tone modifiers (warn/success/danger) share names with alert utility
   classes (.success at line ~480, etc.). Without these resets the alert
   styles bleed into the dashboard tile — green background, 8px padding,
   text color override. Specificity 030 here beats the 010 alert rules,
   so we explicitly reset every property the alert utilities set. */
.card.dash.warn,
.card.dash.success,
.card.dash.danger {
  background: var(--surface);
  color: inherit;
  padding: var(--sp-5);
  margin: 0;                       /* alert utility sets margin-bottom: 16px */
  font-size: inherit;              /* alert utility sets fs-sm */
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}
.card.dash.warn    { border-top: 3px solid var(--warn); }
.card.dash.success { border-top: 3px solid var(--success); }
.card.dash.danger  { border-top: 3px solid var(--danger); }
.dash-actions {
  display: flex; gap: var(--sp-2); flex-wrap: wrap;
  margin-top: auto;        /* push to bottom of the card */
  padding-top: var(--sp-3);
}
.dash-actions a { font-size: var(--fs-sm); }

/* ---------- 18. Active page in nav --------------------------------- */
.nav .navlink.active,
.nav .navtrigger.active { background: var(--primary-soft); color: var(--info-fg); font-weight: 500; }
.navgroup .navmenu a.active { background: var(--primary-soft); color: var(--info-fg); font-weight: 500; }

/* ---------- 19. Mobile table scroll wrap --------------------------- */
.table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; margin: var(--sp-3) 0; border-radius: var(--r-md); }
.table-scroll > .data { margin: 0; }

/* Make sure tables inside scroll wrappers don't collapse weirdly */
@media (max-width: 720px) {
  .data { font-size: var(--fs-sm); }
  .data th, .data td { padding: var(--sp-1) var(--sp-2); }
  .container { padding: var(--sp-3); }
}

/* ---------- 20. Dark mode (token override) ------------------------- */
[data-theme="dark"] {
  --bg:           #0f1217;
  --surface:      #181c25;
  --surface-2:    #1f2530;
  --surface-3:    #2a3140;
  --border:       #2e3644;
  --border-strong:#3d4658;
  --fg:           #e6e8ed;
  --fg-2:         #b6bdc8;
  --muted:        #828b9a;

  --primary:        #5a92e8;
  --primary-fg:     #0f1217;
  --primary-soft:   #1f3056;
  --primary-hover:  #4078cf;
  --danger-hover:   #c25555;
  --danger-fg-inv:  #ffffff;

  --success:      #56c374;
  --success-bg:   #1d3a25;
  --success-fg:   #aaeab8;

  --warn:         #e0a04a;
  --warn-bg:      #3e2b15;
  --warn-fg:      #f3cf95;

  --danger:       #e07070;
  --danger-bg:    #3e1d1d;
  --danger-fg:    #f3b9b9;

  --info-bg:      #1e2a4d;
  --info-fg:      #b9caf9;

  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.35);
  --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.45);
}
[data-theme="dark"] .data tbody tr:nth-child(even) { background: rgba(31, 37, 48, 0.4); }
[data-theme="dark"] tr.below-reorder { background: #4a2222 !important; }
[data-theme="dark"] .cat-finished_vehicle { background: #3a1f3a; color: #f0c6e8; }
/* (button hover handled by token swap above) */

/* ---------- 20b. Blue theme (token override + blue sidebar) --------- */
/* Requested: NOT dark-blue — light-blue surfaces everywhere, with the sidebar
   in a strong blue. The sidebar gets explicit overrides (below) because in
   light/dark it leans on the neutral --surface tokens, which would otherwise
   make it light here too. */
[data-theme="blue"] {
  --bg:            #e9f1fd;       /* page — light blue */
  --surface:       #ffffff;       /* cards — clean white for contrast */
  --surface-2:     #e7f0fc;       /* alt rows, subtle backgrounds */
  --surface-3:     #d6e4f8;       /* hover, chips */
  --border:        #cbdef3;
  --border-strong: #a6c6ea;
  --fg:            #15233c;       /* navy text on light blue */
  --fg-2:          #37507a;
  --muted:         #5d76a0;

  --primary:       #1f6fe0;
  --primary-fg:    #ffffff;
  --primary-soft:  #dbe9fb;
  --primary-hover: #155bc4;
  --grad-brand:    linear-gradient(135deg, #2f7ce8 0%, #155bc4 100%);
  --danger-hover:  #921e1e;
  --danger-fg-inv: #ffffff;

  --success:    #1d8a3b;  --success-bg: #ddf2e4;  --success-fg: #14572a;
  --warn:       #b06b00;  --warn-bg:    #fbeac8;  --warn-fg:    #6f4a0c;
  --danger:     #b53030;  --danger-bg:  #fbe3e3;  --danger-fg:  #8a1f1f;
  --info-bg:    #d4e3fb;  --info-fg:    #1b2f5d;

  --shadow-sm: 0 1px 2px rgba(20, 50, 90, 0.06), 0 1px 1px rgba(20, 50, 90, 0.05);
  --shadow-md: 0 2px 4px rgba(20, 50, 90, 0.06), 0 10px 24px rgba(20, 50, 90, 0.10);
  --shadow-lg: 0 18px 40px rgba(20, 50, 90, 0.16), 0 6px 12px rgba(20, 50, 90, 0.08);
}
/* Strong-blue sidebar with light text (overrides the neutral --surface
   gradient used in light/dark). */
[data-theme="blue"] .sidebar {
  background: linear-gradient(180deg, #205fbe 0%, #174f9d 100%);
  border-right-color: #133f80;
}
[data-theme="blue"] .sidenav .sidelink { color: #eaf2ff; }
[data-theme="blue"] .sidenav .sidegroup .sidelink { color: #c9ddf7; }
[data-theme="blue"] .sidenav .sidegroup-head { color: #bcd3f2; }
[data-theme="blue"] .sidenav .sidelink:hover,
[data-theme="blue"] .sidenav .sidegroup-head:hover { background: rgba(255, 255, 255, 0.14); }
[data-theme="blue"] .sidenav .sidelink.active {
  background: rgba(255, 255, 255, 0.18);
  color: #ffffff;
  box-shadow: inset 3px 0 0 #ffd45e;   /* warm rail reads clearly on blue */
}
[data-theme="blue"] .sidenav .sidegroup-head.active { color: #ffffff; }
[data-theme="blue"] .sidenav .sidegroup-toggle { color: #bcd2f0; }
[data-theme="blue"] .sidenav .sidegroup-toggle:hover { color: #ffffff; background: rgba(255, 255, 255, 0.12); }
[data-theme="blue"] .sidebar-foot { color: #bcd3f2; border-top-color: rgba(255, 255, 255, 0.18); }

/* ---------- 20c. Theme switcher (account dropdown) ----------------- */
/* Scoped under .navmenu so these beat the generic menu-item button rules
   (.navgroup .navmenu button — which force display:block / width:100% / left). */
.navgroup .navmenu .theme-seg { display: flex; align-items: center; flex-wrap: wrap; gap: 5px; padding: 7px var(--sp-3); }
.navgroup .navmenu .theme-seg-label { flex: 0 0 100%; font-size: var(--fs-xs); color: var(--muted); margin-bottom: 2px; }
.navgroup .navmenu .theme-seg-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 5px;
  width: auto; text-align: center;
  border: 1px solid var(--border); background: var(--surface-2); color: var(--fg-2);
  padding: 3px 9px; border-radius: var(--r-pill); font-size: var(--fs-xs); font-weight: 500; cursor: pointer;
  transition: background-color 120ms, color 120ms, border-color 120ms;
}
.navgroup .navmenu .theme-seg-btn:hover { background: var(--surface-3); color: var(--fg); border-color: var(--border-strong); }
.navgroup .navmenu .theme-seg-btn.active { background: var(--primary-soft); color: var(--primary); border-color: var(--primary); font-weight: 600; }
.theme-dot { width: 11px; height: 11px; border-radius: 50%; border: 1px solid rgba(0, 0, 0, 0.18); flex: none; }
.theme-dot-light { background: #ffffff; }
.theme-dot-blue { background: #2f6fe0; }
.theme-dot-dark { background: #181c25; }

/* ---------- 21. Keyboard shortcut help modal ----------------------- */
.kbd-help-shell {
  display: none;
  position: fixed; inset: 0;
  background: rgba(15, 18, 23, 0.55);
  z-index: 2000;
  align-items: center; justify-content: center;
  padding: var(--sp-4);
}
.kbd-help-shell.open { display: flex; }
.kbd-help-shell .card { max-width: 480px; width: 100%; }
kbd {
  display: inline-block;
  padding: 1px 6px;
  border: 1px solid var(--border-strong);
  border-bottom-width: 2px;
  border-radius: var(--r-sm);
  background: var(--surface-2);
  font: 500 11px ui-monospace, Menlo, Consolas, monospace;
  color: var(--fg);
  min-width: 18px; text-align: center;
}
.kbd-table { width: 100%; }
.kbd-table td { padding: var(--sp-1) var(--sp-2); }
.kbd-table td:first-child { white-space: nowrap; width: 1%; }

/* ---------- 22. Empty-state CTA box (replaces "No X match") -------- */
.empty-state {
  text-align: center;
  padding: var(--sp-6) var(--sp-4);
  color: var(--muted);
}
.empty-state h3 { color: var(--fg-2); margin: 0 0 var(--sp-1); }
.empty-state p { margin: 0 0 var(--sp-3); font-size: var(--fs-sm); }
.empty-state .button { margin-top: var(--sp-1); }
.data .empty-row td .empty-state { padding: var(--sp-5) var(--sp-3); }

/* ---------- 23. Sticky filter bar ---------------------------------- */
.filters.sticky, .filters {
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--bg);
  padding: var(--sp-3) 0;
  margin-bottom: var(--sp-3);
  border-bottom: 1px solid transparent;
  transition: border-color 200ms ease;
}
.filters.sticky-active, .filters:not(:first-of-type),
.filters.is-stuck { border-bottom-color: var(--border); }
/* Pull the page background up under the filters so content doesn't bleed through */

/* ---------- 24. Toasts (auto-dismissing notifications) ------------- */
.toast-container {
  position: fixed; top: calc(var(--topbar-h) + var(--sp-3)); right: var(--sp-4);
  z-index: 1500;
  display: flex; flex-direction: column; gap: var(--sp-2);
  pointer-events: none;
  max-width: 360px;
}
.toast {
  pointer-events: auto;
  background: var(--surface);
  color: var(--fg);
  border: 1px solid var(--border);
  border-left: 4px solid var(--primary);
  border-radius: var(--r-md);
  padding: var(--sp-2) var(--sp-3);
  box-shadow: var(--shadow-md);
  font-size: var(--fs-sm);
  display: flex; align-items: flex-start; gap: var(--sp-2);
  animation: toast-in 220ms ease-out;
}
.toast.success { border-left-color: var(--success); }
.toast.warn    { border-left-color: var(--warn); }
.toast.danger  { border-left-color: var(--danger); }
.toast .toast-msg { flex: 1; }
.toast .toast-close {
  background: none; border: none; padding: 2px 6px;
  color: var(--muted); cursor: pointer; font: inherit; line-height: 1;
}
.toast.leaving { animation: toast-out 220ms ease-in forwards; }
@keyframes toast-in  { from { transform: translateX(20px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes toast-out { from { transform: translateX(0); opacity: 1; } to { transform: translateX(20px); opacity: 0; } }

/* Hide the legacy inline flash blocks (rendered through partials/flash.ejs);
   the same partial now emits a .toast inside .toast-container instead. */

/* ---------- 25. Breadcrumbs ---------------------------------------- */
.breadcrumbs {
  font-size: var(--fs-sm);
  color: var(--muted);
  margin: 0 0 var(--sp-3);
  display: flex; flex-wrap: wrap; gap: var(--sp-1);
  align-items: center;
}
.breadcrumbs a { color: var(--muted); text-decoration: none; }
.breadcrumbs a:hover { color: var(--fg); text-decoration: underline; }
.breadcrumbs .sep { opacity: 0.5; }
.breadcrumbs .current { color: var(--fg); font-weight: 500; }

/* ---------- 26. Form inline validation hints ----------------------- */
label .req { color: var(--danger); margin-left: 2px; font-weight: 600; }
label .hint { color: var(--muted); font-weight: 400; font-size: var(--fs-xs); margin-left: var(--sp-2); }
label .counter { float: right; color: var(--muted); font-weight: 400; font-size: var(--fs-xs); }
input:user-invalid,
textarea:user-invalid { border-color: var(--danger); }
input:user-invalid:focus,
textarea:user-invalid:focus { outline-color: var(--danger); }
.field-error { color: var(--danger-fg); font-size: var(--fs-xs); margin-top: var(--sp-1); }

/* ---------- 27. Sectioned forms (employees & similar) ---------------- */
.form-stacked { max-width: 720px; }
.form-section {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--sp-3) var(--sp-4) var(--sp-4);
  margin: 0 0 var(--sp-4);
  background: var(--surface);
}
/* A native <legend> gets special "rendered legend" treatment — it straddles the
   fieldset's top border, so the heading pokes ABOVE the box. display:block does
   NOT stop this in Chrome; only float (or absolute positioning) disqualifies a
   legend from that special rendering. So we float it full-width and clear the
   following fields, making it a normal heading INSIDE the box. Fixes
   "Identity / Contact / …" sitting outside the box on every .form-section form. */
.form-section > legend {
  float: left;
  width: 100%;
  box-sizing: border-box;
  margin: 0 0 var(--sp-3);
  padding: 0;
  font-weight: 600;
  font-size: var(--fs-sm);
  color: var(--fg);
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
.form-section > legend ~ * { clear: both; }
.form-section > legend .hint { text-transform: none; letter-spacing: 0; }
.grid-3 {
  display: grid; gap: var(--sp-3);
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.grid-3 > label { margin: 0; }
@media (max-width: 720px) { .grid-3 { grid-template-columns: 1fr; } }
.checks { display: flex; flex-wrap: wrap; gap: var(--sp-4); margin: var(--sp-3) 0 var(--sp-1); }
label.check { display: inline-flex; align-items: center; gap: var(--sp-2); margin: 0; cursor: pointer; }
label.check input { width: auto; margin: 0; }
.form-actions { display: flex; gap: var(--sp-2); margin-top: var(--sp-3); }
.file-current {
  display: flex; align-items: center; gap: var(--sp-3);
  font-size: var(--fs-xs); color: var(--muted);
  margin: var(--sp-2) 0;
}
.file-current .thumb {
  width: 48px; height: 48px; object-fit: cover;
  border: 1px solid var(--border); border-radius: var(--r-sm);
}

/* ---------- 28. Employee detail: photo + masked PII ----------------- */
.emp-photo {
  width: 96px; height: 96px; object-fit: cover;
  border: 1px solid var(--border); border-radius: var(--r-md);
}
.emp-photo-placeholder {
  width: 96px; height: 96px; border: 1px solid var(--border);
  border-radius: var(--r-md); display: inline-flex; align-items: center; justify-content: center;
  background: var(--surface-2); color: var(--muted);
  font-size: 28px; font-weight: 600;
}
.pii-row {
  display: flex; align-items: center; gap: var(--sp-2);
  font-variant-numeric: tabular-nums;
}
.pii-row .masked { font-family: var(--mono, ui-monospace, SFMono-Regular, Menlo, monospace); }
.btn-unmask { padding: 2px 8px; font-size: var(--fs-xs); }

/* List-page avatar thumb */
td.avatar { padding: 4px 8px; width: 48px; }
.avatar-thumb {
  width: 36px; height: 36px; object-fit: cover;
  border-radius: 50%;
  border: 1px solid var(--border);
  display: block;
}
.avatar-initials {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--surface-2); color: var(--muted);
  display: flex; align-items: center; justify-content: center;
  font-size: var(--fs-xs); font-weight: 600;
  border: 1px solid var(--border);
}

/* ---------- 29. Compact home dashboard (KPI tiles + activity) ------- */
.home-hero {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: var(--sp-3); margin: var(--sp-2) 0 var(--sp-4);
}
.home-hero h1 { margin: 0 0 4px; font-size: var(--fs-xl); }
.kpi-strip {
  display: grid; gap: var(--sp-3);
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  margin: 0 0 var(--sp-5);
}
.kpi-tile {
  display: flex; flex-direction: column; gap: 4px;
  padding: var(--sp-4) var(--sp-4) var(--sp-3);
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 4px solid var(--primary);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
  text-decoration: none; color: inherit;
  transition: border-color 120ms, box-shadow 120ms, transform 120ms;
}
.kpi-tile:hover {
  border-left-color: var(--primary-hover, var(--primary));
  box-shadow: 0 1px 3px rgba(0,0,0,0.06), 0 2px 8px rgba(0,0,0,0.04);
  transform: translateY(-1px);
}
.kpi-tile[data-tone="inventory"]   { border-left-color: #2e7d32; }
.kpi-tile[data-tone="procurement"] { border-left-color: #ed6c02; }
.kpi-tile[data-tone="admin"]       { border-left-color: #6a1b9a; }
.kpi-tile .kpi-label {
  font-size: var(--fs-xs); text-transform: uppercase;
  letter-spacing: 0.04em; color: var(--muted); font-weight: 600;
}
.kpi-tile .kpi-num {
  font-size: 28px; font-weight: 700; line-height: 1.1;
  font-variant-numeric: tabular-nums; color: var(--fg);
}
.kpi-tile .kpi-num-suffix { font-size: 16px; vertical-align: top; color: var(--muted); margin-left: 2px; }
.kpi-tile .kpi-sub { font-size: var(--fs-xs); color: var(--muted); }
.kpi-tile .kpi-cta {
  margin-top: 6px; font-size: var(--fs-xs); color: var(--primary); font-weight: 500;
}

/* ---------- 29.5 Searchable combobox (live option search) ---------- */
.combobox { position: relative; }
.combobox-input { width: 100%; }
.combobox-list {
  position: absolute; left: 0; right: 0; top: calc(100% + 4px); z-index: 60;
  margin: 0; padding: 4px; list-style: none;
  max-height: 260px; overflow-y: auto;
  background: var(--surface); border: 1px solid var(--border-strong);
  border-radius: var(--r-md); box-shadow: var(--shadow-md);
  display: none;
}
.combobox.open .combobox-list { display: block; }
.combobox-list li {
  padding: 6px 10px; border-radius: var(--r-sm); cursor: pointer;
  font-size: var(--fs-sm); white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.combobox-list li:hover { background: var(--surface-3); }
.combobox.no-match .combobox-list::after {
  content: 'No match'; display: block; padding: 6px 10px;
  color: var(--muted); font-size: var(--fs-xs);
}
.combobox-input.combobox-invalid { border-color: var(--danger); }

.activity-strip {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--sp-3) var(--sp-4);
  max-width: 720px;
}
.activity-strip h3 {
  margin: 0 0 var(--sp-2); font-size: var(--fs-sm);
  text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted);
}
.activity-list {
  list-style: none; padding: 0; margin: 0 0 var(--sp-3);
  font-size: var(--fs-sm); font-variant-numeric: tabular-nums;
}
.activity-list li {
  display: grid;
  grid-template-columns: 56px 90px 1fr;
  gap: var(--sp-2);
  align-items: baseline;
  padding: 4px 0;
  border-bottom: 1px solid var(--border-soft, var(--border));
}
.activity-list li:last-child { border-bottom: 0; }
.activity-list .actor { font-weight: 500; color: var(--fg); }
.activity-list .action { color: var(--fg-2); }

