/* ============================================
   RMMS — Routine Maintenance Management System
   Material Design 3 — Highway Department theme
   ============================================ */

:root {
  /* Brand — Highway Department blue + yellow */
  --brand-primary: #0B3D91;        /* deep highway blue */
  --brand-primary-container: #DCE6FA;
  --brand-on-primary: #FFFFFF;
  --brand-on-primary-container: #001A4D;

  --brand-secondary: #F5B800;      /* highway yellow */
  --brand-secondary-container: #FFF3CC;
  --brand-on-secondary: #1F1500;
  --brand-on-secondary-container: #3D2A00;

  --brand-tertiary: #00695C;
  --brand-tertiary-container: #B2DFDB;

  /* Surface tones — M3 elevation */
  --surface: #FBFBFE;
  --surface-dim: #F2F3F7;
  --surface-bright: #FFFFFF;
  --surface-container-lowest: #FFFFFF;
  --surface-container-low: #F6F7FB;
  --surface-container: #F0F1F6;
  --surface-container-high: #EAECF2;
  --surface-container-highest: #E4E6ED;

  --on-surface: #1A1B1F;
  --on-surface-variant: #44464E;
  --outline: #74777F;
  --outline-variant: #C5C6CF;

  --error: #BA1A1A;
  --error-container: #FFDAD6;
  --on-error: #FFFFFF;
  --on-error-container: #410002;

  --success: #146C2E;
  --success-container: #C6F6D5;
  --on-success-container: #002106;

  --warning: #B45309;
  --warning-container: #FEF3C7;
  --on-warning-container: #3A2200;

  --info: #1E4E8C;
  --info-container: #D6E4FF;

  --plan-annual: #0B3D91;
  --plan-annual-container: #DCE6FA;
  --plan-annual-text: #001A4D;
  --plan-supplemental: #0F766E;
  --plan-supplemental-container: #CCFBF1;
  --plan-supplemental-text: #134E4A;

  /* Typography */
  --font-sans: 'IBM Plex Sans Thai', 'Sarabun', system-ui, -apple-system, sans-serif;
  --font-display: 'IBM Plex Sans Thai', 'Sarabun', system-ui, sans-serif;
  --font-mono: 'IBM Plex Mono', 'Roboto Mono', ui-monospace, monospace;

  /* Shape */
  --radius-xs: 4px;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-full: 999px;

  /* Elevation (M3 shadows, subtle) */
  --elev-1: 0 1px 2px rgba(11, 61, 145, 0.06), 0 1px 3px rgba(11, 61, 145, 0.04);
  --elev-2: 0 1px 2px rgba(11, 61, 145, 0.08), 0 2px 6px rgba(11, 61, 145, 0.06);
  --elev-3: 0 4px 8px rgba(11, 61, 145, 0.08), 0 1px 3px rgba(11, 61, 145, 0.06);
  --elev-4: 0 6px 10px rgba(11, 61, 145, 0.10), 0 2px 3px rgba(11, 61, 145, 0.06);

  /* Motion */
  --motion-fast: 150ms cubic-bezier(0.2, 0, 0, 1);
  --motion-med: 250ms cubic-bezier(0.2, 0, 0, 1);
  --motion-slow: 400ms cubic-bezier(0.2, 0, 0, 1);

  /* Layout */
  --sidebar-width: 260px;
  --sidebar-collapsed: 72px;
  --topbar-height: 64px;
}

[data-theme="dark"] {
  --brand-primary: #ADC6FF;
  --brand-primary-container: #1E3A66;
  --brand-on-primary: #002B6E;
  --brand-on-primary-container: #DCE6FA;

  --brand-secondary: #F5B800;
  --brand-secondary-container: #5A3F00;
  --brand-on-secondary: #FFFFFF;
  --brand-on-secondary-container: #FFEBB0;

  --surface: #121316;
  --surface-dim: #0E0F12;
  --surface-bright: #38393E;
  --surface-container-lowest: #0B0C0F;
  --surface-container-low: #1A1B1F;
  --surface-container: #1E1F23;
  --surface-container-high: #292A2E;
  --surface-container-highest: #343539;

  --on-surface: #E4E6ED;
  --on-surface-variant: #C5C6CF;
  --outline: #8E9099;
  --outline-variant: #44464E;

  --error: #FFB4AB;
  --error-container: #93000A;
  --on-error-container: #FFDAD6;

  --success: #7BD698;
  --success-container: #00531A;
  --on-success-container: #C6F6D5;

  --warning: #FCC678;
  --warning-container: #5A3F00;
  --on-warning-container: #FEF3C7;

  --info: #ADC6FF;
  --info-container: #1E3A66;

  --plan-annual: #ADC6FF;
  --plan-annual-container: #1E3A66;
  --plan-annual-text: #DCE6FA;
  --plan-supplemental: #5EEAD4;
  --plan-supplemental-container: #134E4A;
  --plan-supplemental-text: #CCFBF1;

  --elev-1: 0 1px 2px rgba(0, 0, 0, 0.4), 0 1px 3px rgba(0, 0, 0, 0.3);
  --elev-2: 0 2px 4px rgba(0, 0, 0, 0.5), 0 2px 6px rgba(0, 0, 0, 0.3);
  --elev-3: 0 4px 8px rgba(0, 0, 0, 0.6), 0 1px 3px rgba(0, 0, 0, 0.4);
  --elev-4: 0 6px 12px rgba(0, 0, 0, 0.7);
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  font-family: var(--font-sans);
  background: var(--surface-dim);
  color: var(--on-surface);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: 0.01em;
}

#root { min-height: 100vh; }

button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
input, select, textarea { font-family: inherit; color: inherit; }

/* ===== App Shell ===== */
.app-shell {
  display: grid;
  grid-template-columns: var(--sidebar-width) minmax(0, 1fr);
  grid-template-rows: var(--topbar-height) 1fr;
  grid-template-areas:
    "sidebar topbar"
    "sidebar main";
  min-height: 100vh;
  transition: grid-template-columns var(--motion-med);
}

.app-shell[data-collapsed="true"][data-mobile="false"] {
  grid-template-columns: var(--sidebar-collapsed) minmax(0, 1fr);
}

.top-nav-shell {
  grid-template-columns: 1fr;
  grid-template-areas:
    "topbar"
    "main";
}

.top-nav-shell[data-mobile="false"] .sidebar {
  display: none;
}

/* ===== Sidebar ===== */
.sidebar {
  grid-area: sidebar;
  background: var(--surface-container-low);
  border-right: 1px solid var(--outline-variant);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  position: sticky;
  top: 0;
  height: 100vh;
}

.sidebar-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  height: var(--topbar-height);
  border-bottom: 1px solid var(--outline-variant);
}

.sidebar-brand-mark {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-sm);
  background: var(--brand-primary);
  color: var(--brand-on-primary);
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.05em;
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
}
.sidebar-brand-mark::after {
  content: '';
  position: absolute;
  inset: auto 0 4px 0;
  height: 2px;
  background: var(--brand-secondary);
}

.sidebar-brand-text {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.sidebar-brand-text .name { font-weight: 700; font-size: 14px; color: var(--on-surface); }
.sidebar-brand-text .sub { font-size: 11px; color: var(--on-surface-variant); }

.app-shell[data-collapsed="true"][data-mobile="false"] .sidebar-brand {
  justify-content: center;
  padding: 14px 8px;
}
.app-shell[data-collapsed="true"][data-mobile="false"] .sidebar-brand-text,
.app-shell[data-collapsed="true"][data-mobile="false"] .nav-section-label,
.app-shell[data-collapsed="true"][data-mobile="false"] .nav-item > span:not(.material-symbols-rounded),
.app-shell[data-collapsed="true"][data-mobile="false"] .nav-item .badge,
.app-shell[data-collapsed="true"][data-mobile="false"] .sidebar-footer .who,
.app-shell[data-collapsed="true"][data-mobile="false"] .sidebar-footer .icon-btn {
  display: none;
}
.app-shell[data-collapsed="true"][data-mobile="false"] .sidebar-nav {
  padding: 12px 8px;
  align-items: center;
}
.app-shell[data-collapsed="true"][data-mobile="false"] .sidebar-nav > div {
  width: 100%;
}
.app-shell[data-collapsed="true"][data-mobile="false"] .nav-item {
  width: 48px;
  height: 48px;
  justify-content: center;
  padding: 0;
  margin: 4px auto;
  border-radius: var(--radius-lg);
}
.app-shell[data-collapsed="true"][data-mobile="false"] .nav-item .icon {
  width: 24px;
  font-size: 21px;
}
.app-shell[data-collapsed="true"][data-mobile="false"] .sidebar-footer {
  justify-content: center;
  padding: 12px 8px;
}
.app-shell[data-collapsed="true"][data-mobile="false"] .sidebar-footer .avatar {
  width: 38px;
  height: 38px;
}

.sidebar-nav {
  flex: 1;
  padding: 12px 8px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.nav-section-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--on-surface-variant);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 16px 12px 6px;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 10px 12px;
  border-radius: var(--radius-full);
  color: var(--on-surface-variant);
  font-size: 13px;
  font-weight: 500;
  transition: background var(--motion-fast), color var(--motion-fast);
  text-align: left;
  width: 100%;
  position: relative;
}
.nav-item:hover { background: var(--surface-container); color: var(--on-surface); }
.nav-item.active {
  background: var(--brand-primary-container);
  color: var(--brand-on-primary-container);
  font-weight: 600;
}
.nav-item .icon { font-size: 18px; flex-shrink: 0; width: 20px; display: grid; place-items: center; }
.nav-item .badge {
  margin-left: auto;
  background: var(--brand-primary);
  color: var(--brand-on-primary);
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: var(--radius-full);
  min-width: 18px;
  text-align: center;
}

.sidebar-footer {
  border-top: 1px solid var(--outline-variant);
  padding: 12px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.sidebar-footer .avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--brand-secondary-container);
  color: var(--brand-on-secondary-container);
  display: grid; place-items: center;
  font-weight: 700;
  font-size: 12px;
}
.sidebar-footer .who { display: flex; flex-direction: column; min-width: 0; flex: 1; }
.sidebar-footer .who .name { font-size: 12px; font-weight: 600; color: var(--on-surface); }
.sidebar-footer .who .role { font-size: 11px; color: var(--on-surface-variant); }

/* ===== Topbar ===== */
.topbar {
  grid-area: topbar;
  background: var(--surface-container-lowest);
  border-bottom: 1px solid var(--outline-variant);
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 0 24px;
  position: sticky;
  top: 0;
  z-index: 10;
}

.topbar-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
}

.topbar-brand > div:last-child {
  display: grid;
  line-height: 1.1;
}

.topbar-brand b {
  font-size: 14px;
  letter-spacing: .03em;
}

.topbar-brand span {
  color: var(--on-surface-variant);
  font-size: 10px;
  white-space: nowrap;
}

.top-nav {
  display: flex;
  align-items: center;
  gap: 4px;
  min-width: 0;
  flex: 0 1 auto;
}

.top-nav-group {
  position: relative;
}

.top-nav-trigger {
  height: 38px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 0 10px 0 14px;
  border-radius: var(--radius-full);
  color: var(--on-surface-variant);
  font-size: 13px;
  font-weight: 650;
  white-space: nowrap;
}

.top-nav-trigger.direct {
  gap: 8px;
}

.top-nav-trigger.direct .material-symbols-rounded {
  font-size: 19px;
}

.top-nav-trigger .badge {
  background: var(--brand-primary);
  color: var(--brand-on-primary);
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: var(--radius-full);
}

.top-nav-trigger:hover,
.top-nav-trigger.active {
  background: var(--brand-primary-container);
  color: var(--brand-on-primary-container);
}

.top-nav-trigger .material-symbols-rounded {
  font-size: 18px;
}

.top-nav-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  width: 260px;
  padding: 8px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
  box-shadow: var(--elev-3);
  display: none;
  z-index: 30;
}

.top-nav-group:hover .top-nav-menu,
.top-nav-group:focus-within .top-nav-menu {
  display: grid;
  gap: 4px;
}

.top-nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 40px;
  padding: 8px 10px;
  border-radius: var(--radius-sm);
  color: var(--on-surface);
  font-size: 13px;
  text-align: left;
}

.top-nav-item:hover {
  background: var(--surface-container-low);
}

.top-nav-item.active {
  background: var(--brand-primary-container);
  color: var(--brand-on-primary-container);
  font-weight: 700;
}

.top-nav-item .material-symbols-rounded {
  font-size: 19px;
}

.top-nav-item .badge {
  margin-left: auto;
  background: var(--brand-primary);
  color: var(--brand-on-primary);
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: var(--radius-full);
}

@media (max-width: 1280px) {
  .top-nav-trigger {
    padding: 0 8px 0 10px;
    font-size: 12px;
  }
  .crumbs {
    display: none;
  }
  .topbar-search {
    width: 260px;
    max-width: 24vw;
  }
}

.crumbs {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--on-surface-variant);
  flex: 1;
  min-width: 0;
}
.crumbs .current { color: var(--on-surface); font-weight: 600; }
.crumbs .sep { color: var(--outline); }

.body-crumbs {
  width: fit-content;
  max-width: 100%;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  margin: 0 0 4px;
  padding: 3px 9px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-full);
  background: var(--surface-container-lowest);
  color: var(--on-surface-variant);
  font-size: 12px;
  font-weight: 650;
  box-shadow: var(--elev-1);
}

.body-crumbs .material-symbols-rounded {
  color: var(--brand-primary);
}

.body-crumbs .current {
  color: var(--on-surface);
  font-weight: 750;
}

.body-crumbs .sep {
  color: var(--outline);
}

.topbar-search {
  display: flex;
  align-items: center;
  background: var(--surface-container);
  border-radius: var(--radius-full);
  padding: 8px 16px;
  gap: 10px;
  width: 320px;
  max-width: 30vw;
  border: 1px solid transparent;
  transition: border-color var(--motion-fast), background var(--motion-fast);
}
.topbar > .topbar-search {
  margin-left: auto;
}
.topbar-search:focus-within {
  border-color: var(--brand-primary);
  background: var(--surface-container-lowest);
}
.topbar-search input {
  border: none;
  outline: none;
  background: transparent;
  font-size: 13px;
  flex: 1;
  width: 100%;
}
.topbar-search .material-symbols-rounded { color: var(--on-surface-variant); font-size: 20px; }

.icon-btn {
  width: 40px; height: 40px;
  border-radius: 50%;
  display: grid; place-items: center;
  color: var(--on-surface-variant);
  transition: background var(--motion-fast);
  position: relative;
}
.icon-btn:hover { background: var(--surface-container); color: var(--on-surface); }
.icon-btn .dot {
  position: absolute;
  top: 8px; right: 9px;
  width: 8px; height: 8px;
  background: var(--brand-secondary);
  border-radius: 50%;
  border: 2px solid var(--surface-container-lowest);
}
.icon-btn .material-symbols-rounded { font-size: 20px; }
.nav-toggle {
  flex: 0 0 auto;
  pointer-events: auto;
  display: none;
}
.icon-btn.tiny {
  width: 28px;
  height: 28px;
}
.icon-btn.tiny .material-symbols-rounded {
  font-size: 17px;
}

/* ===== Main / Pages ===== */
.main {
  grid-area: main;
  padding: 18px 24px 48px;
  overflow-x: hidden;
  max-width: 100%;
}

.page-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 12px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}
.page-title {
  font-size: 24px;
  font-weight: 600;
  color: var(--on-surface);
  margin: 0 0 4px;
  letter-spacing: -0.01em;
}
.page-subtitle {
  font-size: 13px;
  color: var(--on-surface-variant);
  margin: 0;
}
.page-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

.plan-view-toolbar {
  display: flex;
  align-items: flex-end;
  gap: 10px;
  padding: 10px;
  margin: -2px 0 14px;
  background: var(--surface-container-lowest);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  box-shadow: var(--elev-1);
  overflow-x: auto;
}
.toolbar-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 0 0 auto;
}
.toolbar-group.compact { width: 118px; }
.toolbar-group.type { width: 152px; }
.toolbar-group.wide { width: 220px; }
.toolbar-group.grow {
  flex: 1 1 280px;
  min-width: 240px;
}
.toolbar-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--on-surface-variant);
}
.toolbar-divider {
  width: 1px;
  align-self: stretch;
  background: var(--outline-variant);
  flex: 0 0 auto;
}
.plan-toolbar-search {
  width: 100%;
  max-width: none;
  border-radius: var(--radius-sm);
  padding: 7px 10px;
  background: var(--surface-container-low);
}
.plan-section-tabs {
  display: inline-flex;
  width: fit-content;
  gap: 4px;
  padding: 4px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-full);
  background: var(--surface-container-lowest);
  box-shadow: var(--elev-1);
}
.plan-section-tabs button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 36px;
  padding: 7px 14px;
  border-radius: var(--radius-full);
  color: var(--on-surface-variant);
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}
.plan-section-tabs button.active {
  background: var(--brand-primary);
  color: var(--brand-on-primary);
}
.plan-section-tabs .material-symbols-rounded {
  font-size: 17px;
}
.plan-section {
  display: grid;
  gap: 12px;
  min-width: 0;
}
.plan-section-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}
.plan-section-head h2 {
  margin: 0;
  color: var(--on-surface);
  font-size: 18px;
  line-height: 1.25;
}
.plan-section-head p {
  margin: 3px 0 0;
  color: var(--on-surface-variant);
  font-size: 12px;
}
.plan-bulk-bar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 160px auto auto;
  gap: 8px;
  align-items: center;
  padding: 10px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
  box-shadow: var(--elev-1);
}
.plan-bulk-bar > div:first-child {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.plan-bulk-bar b {
  color: var(--on-surface);
  font-size: 13px;
}
.plan-bulk-bar span {
  color: var(--on-surface-variant);
  font-size: 11px;
}
.plan-management-table .data-table tr[data-selected="true"] {
  background: var(--brand-primary-container);
}
.plan-summary-band {
  display: grid;
  grid-template-columns: minmax(260px, 0.9fr) 2.1fr;
  gap: 10px;
  margin-top: -2px;
}
.plan-summary-main,
.plan-status-tile {
  background: var(--surface-container-lowest);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  box-shadow: var(--elev-1);
  color: inherit;
  text-align: left;
  cursor: pointer;
}
.plan-summary-main.active,
.plan-status-tile.active {
  border-color: var(--brand-primary);
  box-shadow: inset 0 0 0 1px var(--brand-primary), var(--elev-1);
}
.plan-summary-main {
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.plan-summary-label,
.plan-status-meta {
  font-size: 11px;
  font-weight: 600;
  color: var(--on-surface-variant);
}
.plan-summary-value {
  font-size: 24px;
  font-weight: 700;
  font-family: var(--font-mono);
  line-height: 1.15;
  color: var(--brand-primary);
}
.plan-summary-sub {
  font-size: 12px;
  color: var(--on-surface-variant);
}
.plan-type-split {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  font-size: 11px;
  color: var(--on-surface-variant);
}
.plan-type-split span {
  padding: 3px 7px;
  border-radius: var(--radius-full);
  border: 1px solid transparent;
  background: var(--surface-container-low);
}
.plan-type-split span:first-child {
  background: var(--plan-annual-container);
  color: var(--plan-annual-text);
}
.plan-type-split span:last-child {
  background: var(--plan-supplemental-container);
  color: var(--plan-supplemental-text);
}
.plan-type-split b {
  color: currentColor;
  font-family: var(--font-mono);
}
.plan-summary-bars {
  height: 6px;
  display: flex;
  border-radius: var(--radius-full);
  overflow: hidden;
  background: var(--surface-container-high);
  margin-top: 5px;
}
.plan-summary-bars .approved { background: var(--success); }
.plan-summary-bars .submitted { background: var(--info); }
.plan-summary-bars .draft { background: var(--outline); }
.plan-summary-statuses {
  display: grid;
  grid-template-columns: repeat(4, minmax(140px, 1fr));
  gap: 10px;
}
.plan-status-tile {
  padding: 11px 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  position: relative;
  overflow: hidden;
}
.plan-status-tile::before {
  content: '';
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: var(--outline-variant);
}
.plan-status-tile[data-tone="info"]::before { background: var(--info); }
.plan-status-tile[data-tone="success"]::before { background: var(--success); }
.plan-status-tile[data-tone="error"]::before { background: var(--error); }
.plan-status-head {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  color: var(--on-surface-variant);
}
.plan-status-head .material-symbols-rounded { font-size: 18px; }
.plan-status-amount {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 16px;
}

@media (max-width: 900px) {
  .app-shell {
    grid-template-columns: 1fr;
    grid-template-rows: var(--topbar-height) 1fr;
    grid-template-areas: "topbar" "main";
  }
  .sidebar {
    position: fixed;
    z-index: 40;
    inset: var(--topbar-height) auto 0 0;
    width: min(var(--sidebar-width), 86vw);
    height: calc(100dvh - var(--topbar-height));
    display: flex;
    box-shadow: var(--elev-4);
    transform: translateX(-104%);
    transition: transform var(--motion-med);
  }
  .app-shell[data-menu-open="true"] .sidebar {
    transform: translateX(0);
  }
  .mobile-sidebar-scrim {
    position: fixed;
    inset: var(--topbar-height) 0 0 0;
    z-index: 35;
    background: rgba(0,0,0,0.42);
    backdrop-filter: blur(1px);
  }
  .topbar {
    gap: 10px;
    padding: 0 12px;
    z-index: 50;
  }
  .top-nav {
    display: none;
  }
  .topbar-brand span {
    display: none;
  }
  .nav-toggle {
    position: relative;
    z-index: 60;
    pointer-events: auto;
    display: grid;
  }
  .crumbs {
    flex: 0 1 auto;
    min-width: 80px;
  }
  .topbar-search {
    flex: 1 1 220px;
    width: auto;
    max-width: none;
    min-width: 160px;
    padding: 7px 10px;
  }
  .topbar > .field-select {
    max-width: 130px;
  }
  .main { padding: 16px 14px 40px; }
  .page-header { align-items: flex-start; }
  .page-title { font-size: 22px; }
  .plan-view-toolbar {
    align-items: stretch;
    flex-direction: column;
    overflow-x: visible;
  }
  .plan-section-tabs {
    width: 100%;
    border-radius: var(--radius-md);
  }
  .plan-section-tabs button {
    flex: 1 1 0;
    justify-content: center;
    border-radius: var(--radius-sm);
  }
  .toolbar-group,
  .toolbar-group.compact,
  .toolbar-group.type,
  .toolbar-group.wide,
  .toolbar-group.grow {
    width: 100%;
    min-width: 0;
  }
  .toolbar-divider { display: none; }
  .plan-section-head,
  .plan-bulk-bar,
  .workcode-drawer-summary,
  .plan-summary-band,
  .plan-summary-statuses {
    grid-template-columns: 1fr;
  }
  .plan-section-head {
    align-items: stretch;
    flex-direction: column;
  }
  .executive-strip,
  .executive-watch-grid {
    grid-template-columns: 1fr;
  }
  .executive-actions,
  .decision-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  :root { --topbar-height: 58px; }
  .topbar {
    gap: 6px;
    padding: 0 8px;
  }
  .icon-btn {
    width: 38px;
    height: 38px;
  }
  .crumbs {
    display: none;
  }
  .topbar-brand {
    gap: 6px;
  }
  .topbar-brand b {
    display: none;
  }
  .topbar-search {
    min-width: 0;
    padding: 7px 9px;
  }
  .topbar-search input {
    font-size: 12px;
  }
  .topbar-search .chip {
    display: none;
  }
  .topbar > .field-select {
    width: 92px !important;
    max-width: 92px;
    padding: 7px 8px !important;
  }
  .page-title { font-size: 20px; }
  .page-subtitle { font-size: 12px; }
  .page-actions {
    width: 100%;
  }
  .page-actions .btn {
    flex: 1 1 auto;
    justify-content: center;
  }
  .kpi-grid {
    grid-template-columns: 1fr;
  }
  .executive-actions,
  .decision-grid {
    grid-template-columns: 1fr;
  }
  .executive-strip-main h3 {
    font-size: 16px;
  }
  .card-header,
  .card-body,
  .modal-header,
  .modal-body,
  .modal-footer {
    padding-left: 12px;
    padding-right: 12px;
  }
}

/* ===== Buttons (M3) ===== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 16px;
  border-radius: var(--radius-full);
  font-size: 13px;
  font-weight: 600;
  transition: background var(--motion-fast), box-shadow var(--motion-fast), transform var(--motion-fast);
  white-space: nowrap;
  letter-spacing: 0.02em;
}
.btn .material-symbols-rounded { font-size: 18px; }
.btn:active { transform: scale(0.98); }

.btn-filled { background: var(--brand-primary); color: var(--brand-on-primary); box-shadow: var(--elev-1); }
.btn-filled:hover { box-shadow: var(--elev-2); background: color-mix(in oklab, var(--brand-primary), white 8%); }

.btn-tonal { background: var(--brand-primary-container); color: var(--brand-on-primary-container); }
.btn-tonal:hover { background: color-mix(in oklab, var(--brand-primary-container), var(--on-surface) 6%); }

.btn-outlined { background: transparent; color: var(--brand-primary); border: 1px solid var(--outline); }
.btn-outlined:hover { background: color-mix(in oklab, var(--brand-primary), transparent 92%); }

.btn-text { background: transparent; color: var(--brand-primary); padding: 8px 10px; }
.btn-text:hover { background: color-mix(in oklab, var(--brand-primary), transparent 92%); }

.btn-secondary { background: var(--brand-secondary); color: var(--brand-on-secondary); }
.btn-secondary:hover { background: color-mix(in oklab, var(--brand-secondary), white 6%); }

.btn-danger { background: var(--error); color: var(--on-error); }

.btn-sm { padding: 5px 11px; font-size: 12px; }
.btn-lg { padding: 12px 24px; font-size: 14px; }

/* ===== Card ===== */
.card {
  background: var(--surface-container-lowest);
  border-radius: var(--radius-lg);
  border: 1px solid var(--outline-variant);
  overflow: hidden;
  transition: box-shadow var(--motion-fast);
  min-width: 0;
}
.card-elevated { box-shadow: var(--elev-1); border-color: transparent; }
.card-header {
  padding: 14px 18px 8px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  flex-wrap: wrap;
  min-width: 0;
}
.card-header > div { min-width: 0; }
.card-title { font-size: 15px; font-weight: 600; margin: 0; color: var(--on-surface); }
.card-subtitle { font-size: 12px; color: var(--on-surface-variant); margin: 2px 0 0; }
.card-body { padding: 10px 18px 14px; min-width: 0; }
.card-body.no-padding { padding: 0; }

/* ===== Chip ===== */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 9px;
  border-radius: var(--radius-full);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
  border: 1px solid var(--outline-variant);
  background: transparent;
  color: var(--on-surface-variant);
}
.chip-filled { border-color: transparent; }
.chip-success { background: var(--success-container); color: var(--on-success-container); border-color: transparent; }
.chip-warning { background: var(--warning-container); color: var(--on-warning-container); border-color: transparent; }
.chip-error { background: var(--error-container); color: var(--on-error-container); border-color: transparent; }
.chip-info { background: var(--info-container); color: var(--info); border-color: transparent; }
.chip-primary { background: var(--brand-primary-container); color: var(--brand-on-primary-container); border-color: transparent; }
.chip-secondary { background: var(--brand-secondary-container); color: var(--brand-on-secondary-container); border-color: transparent; }
.chip .dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }

.budget-signal-chip {
  gap: 4px;
  border-color: transparent;
}
.budget-signal-chip[data-tone="normal"] {
  background: var(--info-container);
  color: var(--info);
}
.budget-signal-chip[data-tone="success"] {
  background: var(--success-container);
  color: var(--on-success-container);
}
.budget-signal-chip[data-tone="warning"] {
  background: var(--warning-container);
  color: var(--on-warning-container);
}
.budget-signal-chip[data-tone="danger"] {
  background: var(--error-container);
  color: var(--on-error-container);
}
.budget-signal-chip[data-tone="neutral"] {
  background: var(--surface-container-high);
  color: var(--on-surface-variant);
}

/* ===== Tables ===== */
.table-wrap {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  border-radius: var(--radius-md);
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable;
}
.data-table {
  width: max-content;
  min-width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  table-layout: auto;
}
.data-table th {
  text-align: left;
  vertical-align: middle;
  font-weight: 600;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--on-surface-variant);
  padding: 9px 12px;
  background: var(--surface-container-low);
  border-bottom: 1px solid var(--outline-variant);
  white-space: nowrap;
}
.data-table td {
  padding: 9px 12px;
  border-bottom: 1px solid var(--outline-variant);
  color: var(--on-surface);
  vertical-align: middle;
  line-height: 1.35;
}
.data-table tr:last-child td { border-bottom: none; }
.data-table tbody tr { transition: background var(--motion-fast); }
.data-table tbody tr:hover { background: var(--surface-container-low); }
.data-table .num { font-variant-numeric: tabular-nums; text-align: right; white-space: nowrap; }
.data-table .code { font-family: var(--font-mono); font-size: 12px; white-space: nowrap; }
.data-table td > .btn,
.data-table td > button,
.data-table th > button {
  vertical-align: middle;
}
.data-table td .btn,
.data-table td .chip {
  white-space: nowrap;
}
.sort-th {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 5px;
  width: 100%;
  min-height: 24px;
  border-radius: var(--radius-xs);
  color: inherit;
  font: inherit;
  text-align: inherit;
  text-transform: inherit;
  letter-spacing: inherit;
  white-space: nowrap;
}
.num .sort-th {
  justify-content: flex-end;
}
.sort-th:hover,
.sort-th[data-active="true"] {
  color: var(--brand-primary);
}
.sort-th .material-symbols-rounded {
  font-size: 14px;
  opacity: 0.42;
}
.sort-th[data-active="true"] .material-symbols-rounded {
  opacity: 1;
}
.data-table .sticky-col {
  position: sticky;
  z-index: 2;
  background: var(--surface-container-lowest);
  box-shadow: 1px 0 0 var(--outline-variant);
}
.data-table th.sticky-col {
  z-index: 4;
  background: var(--surface-container-low);
}
.data-table .sticky-code {
  left: 0;
  min-width: 96px;
  width: 96px;
}
.data-table .sticky-name {
  left: 96px;
  min-width: 240px;
  width: 240px;
  max-width: 240px;
}
.data-table .sticky-name > div {
  white-space: normal;
}
.data-table .sticky-total {
  left: 0;
  min-width: 336px;
  width: 336px;
  z-index: 3;
  background: var(--surface-container);
}
.data-table tbody tr:hover .sticky-col {
  background: var(--surface-container-low);
}
.table-drill-link {
  display: inline-flex;
  justify-content: flex-end;
  width: 100%;
  color: inherit;
  font: inherit;
  text-align: right;
  text-decoration: underline;
  text-decoration-style: dotted;
  text-underline-offset: 3px;
  cursor: pointer;
}
.table-drill-link:hover {
  color: var(--brand-primary);
}
.table-drill-link:disabled {
  color: inherit;
  cursor: default;
  opacity: 0.55;
  text-decoration: none;
}
.workcode-drawer-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 12px;
}
.workcode-drawer-summary > div {
  display: grid;
  gap: 2px;
  padding: 10px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-low);
  min-width: 0;
}
.workcode-drawer-summary span {
  color: var(--on-surface-variant);
  font-size: 10px;
  font-weight: 700;
}
.workcode-drawer-summary b {
  color: var(--on-surface);
  font-family: var(--font-mono);
  font-size: 15px;
}
.compact-table th,
.compact-table td {
  padding: 8px 10px;
}

/* ===== Form fields (M3 outlined) ===== */
.field { display: flex; flex-direction: column; gap: 6px; }
.field-label {
  font-size: 12px;
  font-weight: 500;
  color: var(--on-surface-variant);
  letter-spacing: 0.02em;
}
.field-input,
.field-select,
.field-textarea {
  background: var(--surface-container-lowest);
  border: 1px solid var(--outline);
  border-radius: var(--radius-sm);
  padding: 8px 11px;
  font-size: 13px;
  outline: none;
  transition: border-color var(--motion-fast), box-shadow var(--motion-fast);
  width: 100%;
}
.field-input:focus,
.field-select:focus,
.field-textarea:focus {
  border-color: var(--brand-primary);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand-primary), transparent 85%);
}
.field-help { font-size: 11px; color: var(--on-surface-variant); }
.field-error { font-size: 11px; color: var(--error); }

.segmented {
  display: inline-flex;
  background: var(--surface-container);
  border-radius: var(--radius-full);
  padding: 3px;
  gap: 2px;
}
.segmented button {
  padding: 5px 11px;
  font-size: 12px;
  font-weight: 600;
  color: var(--on-surface-variant);
  border-radius: var(--radius-full);
  transition: background var(--motion-fast), color var(--motion-fast);
}
.segmented button.active {
  background: var(--surface-container-lowest);
  color: var(--brand-primary);
  box-shadow: var(--elev-1);
}

/* ===== KPI Cards ===== */
.dashboard-overview {
  display: grid;
  grid-template-columns: minmax(420px, 1.1fr) minmax(360px, 0.9fr);
  gap: 12px;
  align-items: stretch;
  min-width: 0;
}
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  min-width: 0;
}
.kpi {
  background: var(--surface-container-lowest);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  position: relative;
  overflow: hidden;
  transition: box-shadow var(--motion-fast), transform var(--motion-fast);
  min-width: 0;
}
.kpi:hover { box-shadow: var(--elev-2); }
.kpi-label {
  font-size: 11px;
  color: var(--on-surface-variant);
  font-weight: 600;
  letter-spacing: 0;
  padding-right: 30px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.kpi-value {
  font-size: 20px;
  font-weight: 700;
  color: var(--on-surface);
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}
.kpi-sub {
  font-size: 10px;
  color: var(--on-surface-variant);
  display: flex;
  align-items: center;
  gap: 6px;
  min-height: 24px;
  line-height: 1.3;
  flex-wrap: wrap;
}
.kpi-trend.up { color: var(--success); }
.kpi-trend.down { color: var(--error); }
.kpi-trend.flat { color: var(--on-surface-variant); }
.kpi-icon {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 26px; height: 26px;
  border-radius: var(--radius-sm);
  background: var(--brand-primary-container);
  color: var(--brand-on-primary-container);
  display: grid; place-items: center;
}
.kpi-icon .material-symbols-rounded { font-size: 18px; }
.kpi svg {
  width: 100%;
  max-width: 112px;
  height: 24px;
}

.kpi-progress {
  height: 5px;
  background: var(--surface-container);
  border-radius: var(--radius-full);
  overflow: hidden;
  margin-top: auto;
}
.kpi-progress-fill {
  height: 100%;
  background: var(--brand-primary);
  border-radius: var(--radius-full);
  transition: width var(--motion-slow);
}
.dashboard-kpi-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-content: stretch;
}
.dashboard-kpi {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 9px;
  align-items: center;
  min-height: 78px;
  padding: 10px;
}
.dashboard-kpi .kpi-label {
  padding-right: 0;
  white-space: normal;
}
.dashboard-kpi .kpi-value {
  display: flex;
  align-items: baseline;
  gap: 3px;
  font-size: 22px;
}
.dashboard-kpi .kpi-value span {
  color: var(--on-surface-variant);
  font-size: 13px;
  font-weight: 600;
}
.dashboard-kpi .kpi-sub {
  min-height: 0;
  font-size: 10px;
}
.dashboard-kpi-icon {
  width: 34px;
  height: 34px;
  border-radius: var(--radius-sm);
  background: var(--brand-primary-container);
  color: var(--brand-on-primary-container);
  display: grid;
  place-items: center;
}
.dashboard-kpi-icon .material-symbols-rounded {
  font-size: 20px;
}

/* ===== Universal role-scoped dashboard ===== */
.universal-dashboard {
  gap: 6px !important;
}

.dashboard-page-header {
  align-items: center;
  padding: 6px 8px;
  margin-bottom: 0;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
}

.dashboard-page-header .page-title {
  font-size: 18px;
}

.dashboard-page-header .page-subtitle {
  font-size: 11px;
  line-height: 1.25;
}

.dashboard-page-header .page-actions {
  gap: 6px;
}

.dashboard-page-header .field-select,
.dashboard-page-header .btn {
  min-height: 26px;
  padding-block: 5px;
}

.universal-dashboard .card-header {
  padding: 8px 10px 4px;
  gap: 6px;
}

.universal-dashboard .card-body {
  padding: 6px 10px 8px;
}

.universal-dashboard .card-body.no-padding {
  padding: 0;
}

.universal-dashboard .card-title {
  font-size: 13px;
}

.universal-dashboard .card-subtitle {
  font-size: 10px;
  line-height: 1.25;
}

.dashboard-fiscal-overview {
  display: grid;
  grid-template-columns: minmax(240px, 1.1fr) repeat(3, minmax(170px, .9fr));
  gap: 4px;
}

.dashboard-decision-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4px;
  align-items: start;
}

.dashboard-command-center {
  display: grid;
  grid-template-columns: minmax(210px, .28fr) minmax(0, 1fr);
  gap: 6px;
  padding: 8px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
  box-shadow: var(--elev-1);
}

.dashboard-command-copy {
  display: grid;
  align-content: start;
  gap: 4px;
  min-width: 0;
}

.dashboard-command-copy span {
  color: var(--brand-primary);
  font-size: 11px;
  font-weight: 800;
}

.dashboard-command-copy h2 {
  margin: 0;
  color: var(--on-surface);
  font-size: 16px;
  line-height: 1.25;
}

.dashboard-command-copy p {
  margin: 0;
  color: var(--on-surface-variant);
  font-size: 11px;
  line-height: 1.4;
}

.dashboard-action-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 4px;
  min-width: 0;
}

.dashboard-action-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 4px 8px;
  align-items: center;
  min-width: 0;
  padding: 7px 8px;
  border: 1px solid var(--outline-variant);
  border-left: 4px solid var(--info);
  border-radius: var(--radius-sm);
  background: var(--surface-container-low);
  color: inherit;
  text-align: left;
  cursor: pointer;
}

.dashboard-action-item[data-tone="success"] { border-left-color: var(--success); }
.dashboard-action-item[data-tone="warning"] { border-left-color: var(--warning); }
.dashboard-action-item[data-tone="error"] { border-left-color: var(--error); }

.dashboard-action-item .material-symbols-rounded {
  color: var(--brand-primary);
  font-size: 19px;
}

.dashboard-action-item b {
  display: block;
  color: var(--on-surface);
  font-size: 12px;
  line-height: 1.25;
}

.dashboard-action-item span {
  display: block;
  margin-top: 2px;
  color: var(--on-surface-variant);
  font-size: 10px;
  line-height: 1.3;
}

.dashboard-action-item strong {
  grid-column: 2;
  font-family: var(--font-mono);
  color: var(--on-surface);
  font-size: 13px;
  line-height: 1;
}

.dashboard-action-empty {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px;
  border-radius: var(--radius-sm);
  background: var(--success-container);
  color: var(--on-success-container);
  font-size: 13px;
  font-weight: 700;
}

.universal-kpi-grid,
.dashboard-status-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.universal-kpi-card,
.dashboard-status-card {
  min-width: 0;
  padding: 7px 8px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
  box-shadow: var(--elev-1);
}

.universal-kpi-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 3px 8px;
  align-items: end;
}

.universal-kpi-card.primary {
  border-color: color-mix(in oklab, var(--brand-primary), transparent 58%);
  background: var(--brand-primary-container);
}

.universal-kpi-card span,
.dashboard-status-card span {
  color: var(--on-surface-variant);
  font-size: 10px;
  font-weight: 700;
}

.universal-kpi-card.primary span {
  color: var(--brand-on-primary-container);
}

.universal-kpi-card b {
  grid-column: 1;
  color: var(--on-surface);
  font-family: var(--font-mono);
  font-size: 19px;
  line-height: 1.05;
}

.universal-kpi-card.primary b {
  color: var(--brand-primary);
}

.universal-kpi-card small {
  grid-column: 1 / -1;
  color: var(--on-surface-variant);
  font-size: 10px;
  line-height: 1.35;
}

.mini-progress {
  grid-column: 1 / -1;
  height: 5px;
  overflow: hidden;
  border-radius: var(--radius-full);
  background: var(--surface-container-high);
}

.mini-progress i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--brand-primary);
}

.mini-progress.success i {
  background: var(--success);
}

.dashboard-plan-status-panel {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  min-width: 0;
  padding: 6px 8px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-low);
  box-shadow: none;
}

.dashboard-plan-status-panel .panel-kicker {
  margin: 0;
  white-space: nowrap;
}

.dashboard-status-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 2px 7px;
  align-items: center;
  color: inherit;
  text-align: left;
  cursor: pointer;
  box-shadow: none;
  background: var(--surface-container-low);
}

.dashboard-status-card .material-symbols-rounded {
  grid-row: span 2;
  color: var(--brand-primary);
  font-size: 18px;
}

.dashboard-status-card b {
  color: var(--on-surface);
  font-size: 13px;
  white-space: nowrap;
}

.dashboard-status-card small {
  grid-column: 2 / -1;
  color: var(--on-surface-variant);
  font-family: var(--font-mono);
  font-size: 10px;
  white-space: nowrap;
}

.dashboard-status-card[data-tone="success"] .material-symbols-rounded { color: var(--success); }
.dashboard-status-card[data-tone="error"] .material-symbols-rounded { color: var(--error); }
.dashboard-status-card[data-tone="info"] .material-symbols-rounded { color: var(--info); }

.dashboard-status-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 4px;
}

.dashboard-main-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(280px, .45fr);
  gap: 4px;
  align-items: start;
}

.dashboard-secondary-grid {
  display: grid;
  grid-template-columns: minmax(360px, .86fr) minmax(0, 1.14fr);
  gap: 4px;
}

.dashboard-budget-grid {
  display: grid;
  grid-template-columns: minmax(360px, .92fr) minmax(0, 1.08fr);
  gap: 4px;
  align-items: stretch;
}

.unit-performance-list {
  display: grid;
  gap: 4px;
}

.unit-performance-row {
  display: grid;
  grid-template-columns: minmax(170px, 1.1fr) repeat(3, minmax(90px, .55fr)) minmax(130px, .75fr);
  gap: 6px;
  align-items: center;
  padding: 6px 7px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-low);
  min-width: 0;
}

.unit-performance-name,
.unit-performance-metric {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.unit-performance-name b {
  color: var(--on-surface);
  font-size: 12px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.unit-performance-name span,
.unit-performance-metric span,
.unit-performance-metric small {
  color: var(--on-surface-variant);
  font-size: 10px;
  line-height: 1.25;
}

.unit-performance-metric b {
  color: var(--on-surface);
  font-family: var(--font-mono);
  font-size: 15px;
}

.unit-performance-bar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 6px;
  align-items: center;
}

.unit-performance-bar i {
  height: 8px;
  border-radius: var(--radius-full);
  background: var(--brand-primary);
}

.unit-performance-bar span {
  color: var(--on-surface-variant);
  font-family: var(--font-mono);
  font-size: 11px;
  white-space: nowrap;
}

.dashboard-cost-panel {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 8px;
  align-items: center;
}

.dashboard-cost-list {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.dashboard-cost-list > div {
  display: grid;
  grid-template-columns: 10px minmax(0, 1fr) auto;
  gap: 6px 8px;
  align-items: center;
  min-width: 0;
  padding: 3px 0;
  border-bottom: 1px solid var(--outline-variant);
  font-size: 12px;
}

.dashboard-cost-list > div:last-child {
  border-bottom: 0;
}

.dashboard-cost-list i {
  grid-row: span 2;
  width: 10px;
  height: 10px;
  border-radius: 3px;
}

.dashboard-cost-list span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dashboard-cost-list b {
  font-family: var(--font-mono);
}

.dashboard-cost-list small {
  grid-column: 2 / -1;
  color: var(--on-surface-variant);
  font-family: var(--font-mono);
  font-size: 10px;
  line-height: 1.1;
}

.dashboard-cost-card {
  align-self: start;
}

.dashboard-cost-card .card-body {
  display: grid;
  gap: 6px;
}

.dashboard-cost-insight {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 2px 8px;
  align-items: end;
  padding: 7px 8px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-low);
}

.dashboard-cost-insight span {
  grid-column: 1 / -1;
  color: var(--on-surface-variant);
  font-size: 10px;
  font-weight: 750;
}

.dashboard-cost-insight b {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--on-surface);
  font-size: 12px;
}

.dashboard-cost-insight strong {
  color: var(--brand-primary);
  font-family: var(--font-mono);
  font-size: 14px;
  white-space: nowrap;
}

.dashboard-empty {
  padding: 18px;
  color: var(--on-surface-variant);
  text-align: center;
}

.district-budget-chart {
  display: grid;
  gap: 2px;
}

.district-budget-row {
  display: grid;
  grid-template-columns: minmax(160px, .9fr) minmax(150px, 1.2fr) minmax(120px, .65fr);
  gap: 8px;
  align-items: center;
  min-width: 0;
  padding: 5px 0;
  border-bottom: 1px solid var(--outline-variant);
}

.district-budget-row:last-child {
  border-bottom: 0;
}

.district-budget-name {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.district-budget-name b {
  color: var(--on-surface);
  font-size: 12px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.district-budget-name span,
.district-budget-value span {
  color: var(--on-surface-variant);
  font-size: 10px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.district-budget-track {
  position: relative;
  height: 12px;
  border-radius: var(--radius-full);
  background: var(--surface-container-high);
  overflow: hidden;
}

.district-budget-track i {
  position: absolute;
  inset-block: 0;
  left: 0;
  border-radius: var(--radius-full);
}

.district-budget-track .total {
  background: var(--brand-primary-container);
}

.district-budget-track .used {
  background: var(--brand-primary);
}

.district-budget-value {
  display: grid;
  gap: 2px;
  text-align: right;
  min-width: 0;
}

.district-budget-value b {
  color: var(--on-surface);
  font-family: var(--font-mono);
  font-size: 12px;
}

.dashboard-legend {
  display: flex;
  justify-content: center;
  gap: 14px;
  margin-top: 6px;
  color: var(--on-surface-variant);
  font-size: 11px;
}

.dashboard-legend span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.dashboard-legend i {
  width: 10px;
  height: 10px;
  border-radius: 3px;
}

.dashboard-legend .plan { background: var(--brand-primary-container); }
.dashboard-legend .paid { background: var(--brand-primary); }

.bureau-summary-wrap {
  max-height: 390px;
  overflow: auto;
}

.bureau-summary-table {
  min-width: 760px;
}

.bureau-summary-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--surface-container-low);
}

.bureau-progress {
  display: grid;
  grid-template-columns: minmax(78px, 1fr) 34px;
  gap: 6px;
  align-items: center;
}

.bureau-progress::before {
  content: "";
  grid-column: 1;
  grid-row: 1;
  height: 6px;
  border-radius: var(--radius-full);
  background: var(--surface-container-high);
}

.bureau-progress i {
  grid-column: 1;
  grid-row: 1;
  display: block;
  height: 6px;
  border-radius: var(--radius-full);
  background: var(--success);
  z-index: 1;
}

.bureau-progress span {
  color: var(--on-surface-variant);
  font-family: var(--font-mono);
  font-size: 11px;
}

@media (max-width: 1180px) {
  .dashboard-fiscal-overview,
  .dashboard-decision-grid,
  .dashboard-command-center,
  .dashboard-main-grid,
  .dashboard-budget-grid,
  .dashboard-secondary-grid {
    grid-template-columns: 1fr;
  }
  .dashboard-action-list {
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  }
  .dashboard-status-strip {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .unit-performance-row {
    grid-template-columns: minmax(180px, 1fr) repeat(3, minmax(80px, .5fr));
  }
  .unit-performance-bar {
    grid-column: 1 / -1;
  }
}

@media (max-width: 820px) {
  .dashboard-fiscal-overview,
  .universal-kpi-grid,
  .dashboard-status-grid,
  .dashboard-action-list,
  .dashboard-status-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .dashboard-plan-status-panel {
    grid-template-columns: 1fr;
  }
  .unit-performance-row {
    grid-template-columns: 1fr 1fr;
  }
  .district-budget-row {
    grid-template-columns: minmax(0, 1fr);
    gap: 6px;
  }
  .district-budget-value {
    text-align: left;
  }
  .unit-performance-name,
  .unit-performance-bar {
    grid-column: 1 / -1;
  }
}

@media (max-width: 560px) {
  .dashboard-fiscal-overview,
  .universal-kpi-grid,
  .dashboard-status-grid,
  .dashboard-action-list,
  .dashboard-status-strip,
  .dashboard-cost-panel,
  .unit-performance-row,
  .dashboard-command-center {
    grid-template-columns: 1fr;
  }
  .dashboard-action-item strong {
    grid-column: 1 / -1;
  }
  .dashboard-page-header .page-actions {
    width: 100%;
  }
}

/* ===== Executive dashboard ===== */
.executive-strip {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  align-items: stretch;
  background: var(--surface-container-lowest);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  padding: 12px;
  box-shadow: var(--elev-1);
  min-width: 0;
}
.executive-strip-main {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
}
.executive-eyebrow,
.mini-section-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--brand-primary);
  text-transform: uppercase;
  letter-spacing: 0;
  margin: 0;
}
.executive-strip-main h3 {
  margin: 0;
  font-size: 16px;
  color: var(--on-surface);
}
.executive-strip-main p {
  margin: 0;
  font-size: 12px;
  color: var(--on-surface-variant);
}
.executive-actions,
.decision-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.executive-action-card,
.decision-card {
  border: 1px solid var(--outline-variant);
  border-left: 4px solid var(--brand-primary);
  border-radius: var(--radius-sm);
  background: var(--surface-container-low);
  padding: 9px;
  display: grid;
  gap: 3px;
  min-width: 0;
}
.executive-action-card .material-symbols-rounded,
.decision-card .material-symbols-rounded {
  font-size: 20px;
  color: var(--brand-primary);
}
.executive-action-card span,
.decision-card span,
.decision-card em {
  font-size: 11px;
  color: var(--on-surface-variant);
  font-style: normal;
}
.executive-action-card b,
.decision-card b {
  font-family: var(--font-mono);
  font-size: 14px;
  color: var(--on-surface);
  white-space: nowrap;
}
.executive-action-card[data-tone="warning"],
.decision-card[data-tone="warning"] { border-left-color: var(--warning); }
.executive-action-card[data-tone="error"],
.decision-card[data-tone="error"] { border-left-color: var(--error); }
.executive-action-card[data-tone="info"],
.decision-card[data-tone="info"] { border-left-color: var(--info); }
.executive-action-card[data-tone="supplemental"],
.decision-card[data-tone="supplemental"] { border-left-color: var(--plan-supplemental); }

.executive-grid { align-items: stretch; }
.executive-list,
.mini-stack {
  display: grid;
  gap: 8px;
}
.executive-list-item {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 10px;
  align-items: start;
  padding: 10px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-low);
}
.executive-list-item .rank {
  width: 28px;
  height: 28px;
  border-radius: var(--radius-full);
  display: grid;
  place-items: center;
  background: var(--brand-primary);
  color: var(--brand-on-primary);
  font-weight: 700;
  font-size: 12px;
}
.district-monitor-list {
  display: grid;
  gap: 8px;
}
.district-monitor-item {
  display: grid;
  grid-template-columns: 28px minmax(130px, 0.7fr) minmax(220px, 1.1fr);
  gap: 8px;
  align-items: start;
  padding: 9px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-low);
  min-width: 0;
}
.district-monitor-rank {
  width: 26px;
  height: 26px;
  border-radius: var(--radius-full);
  display: grid;
  place-items: center;
  background: var(--brand-primary);
  color: var(--brand-on-primary);
  font-weight: 700;
  font-size: 12px;
}
.district-monitor-name {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.district-monitor-name b {
  font-size: 12px;
  color: var(--on-surface);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.district-monitor-name span {
  font-size: 11px;
  color: var(--on-surface-variant);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.district-monitor-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  min-width: 0;
}
.district-monitor-metrics > div {
  display: grid;
  gap: 2px;
  padding: 7px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-lowest);
  min-width: 0;
}
.district-monitor-metrics span {
  font-size: 10px;
  font-weight: 700;
  color: var(--on-surface-variant);
}
.district-monitor-metrics b {
  font-family: var(--font-mono);
  font-size: 14px;
  color: var(--on-surface);
  overflow-wrap: anywhere;
}
.district-monitor-metrics em {
  font-size: 10px;
  font-style: normal;
  color: var(--on-surface-variant);
  line-height: 1.25;
}
.district-monitor-action {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  justify-items: start;
  align-items: center;
  gap: 4px 8px;
  grid-column: 2 / -1;
  min-width: 0;
  text-align: left;
}
.district-monitor-action b {
  font-size: 11px;
  line-height: 1.35;
  color: var(--on-surface);
  min-width: 0;
}
.district-monitor-action span {
  font-size: 11px;
  color: var(--on-surface-variant);
  overflow-wrap: anywhere;
  min-width: 0;
}
.district-monitor-action .btn { justify-self: end; }
.grow-min { min-width: 0; }
.dual-progress {
  height: 7px;
  background: var(--surface-container-high);
  border-radius: var(--radius-full);
  overflow: hidden;
  margin: 8px 0 5px;
}
.dual-progress span {
  display: block;
  height: 100%;
  border-radius: var(--radius-full);
  background: var(--success);
}
.executive-watch-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.watch-item {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 2px 8px;
  align-items: center;
  text-align: left;
  padding: 8px 10px;
  border: 1px solid var(--outline-variant);
  border-left: 3px solid var(--info);
  border-radius: var(--radius-sm);
  background: var(--surface-container-low);
  min-width: 0;
}
.watch-item b {
  justify-self: end;
  font-family: var(--font-mono);
  color: var(--on-surface);
}
.watch-item em {
  grid-column: 1 / -1;
  font-style: normal;
  font-size: 11px;
  color: var(--on-surface-variant);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.watch-item[data-tone="warning"] { border-left-color: var(--warning); }
.watch-item[data-tone="error"] { border-left-color: var(--error); }
.watch-item[data-tone="success"] { border-left-color: var(--success); }
.decision-card {
  min-height: 104px;
}
.next-metric-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.next-metric-card {
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  padding: 12px;
  background: var(--surface-container-low);
  display: grid;
  gap: 5px;
  min-width: 0;
}
.next-metric-card .material-symbols-rounded {
  color: var(--brand-primary);
  font-size: 22px;
}
.next-metric-card b {
  font-size: 13px;
  color: var(--on-surface);
}
.next-metric-card span {
  font-size: 12px;
  color: var(--on-surface-variant);
  line-height: 1.45;
}

@media (max-width: 900px) {
  .dashboard-overview {
    grid-template-columns: 1fr;
  }
  .kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .executive-strip,
  .executive-watch-grid {
    grid-template-columns: 1fr;
  }
  .executive-actions,
  .decision-grid,
  .next-metric-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 640px) {
  .kpi-grid {
    grid-template-columns: 1fr;
  }
  .executive-actions,
  .decision-grid,
  .next-metric-grid {
    grid-template-columns: 1fr;
  }
  .executive-strip-main h3 {
    font-size: 16px;
  }
}
@media (max-width: 1100px) {
  .district-monitor-item {
    grid-template-columns: 28px 1fr;
    align-items: start;
  }
  .district-monitor-name,
  .district-monitor-metrics,
  .district-monitor-action {
    grid-column: 2;
  }
  .district-monitor-action {
    justify-items: start;
    min-width: 0;
    text-align: left;
  }
}
@media (max-width: 760px) {
  .district-monitor-item {
    grid-template-columns: 1fr;
  }
  .district-monitor-rank,
  .district-monitor-name,
  .district-monitor-metrics,
  .district-monitor-action {
    grid-column: auto;
  }
  .district-monitor-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 520px) {
  .district-monitor-metrics,
  .district-monitor-action {
    grid-template-columns: 1fr;
  }
  .district-monitor-action .btn {
    justify-self: start;
  }
}

/* ===== Snackbar ===== */
.snackbar-host {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1000;
  display: flex;
  flex-direction: column;
  gap: 8px;
  pointer-events: none;
}
.snackbar {
  background: #1A1B1F;
  color: #E4E6ED;
  padding: 12px 20px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  gap: 16px;
  box-shadow: var(--elev-3);
  pointer-events: auto;
  animation: snackbar-in 200ms cubic-bezier(0.2, 0, 0, 1);
  min-width: 280px;
}
.snackbar.success { border-left: 4px solid var(--success); }
.snackbar.error { border-left: 4px solid var(--error); }
.snackbar.info { border-left: 4px solid var(--brand-secondary); }
.snackbar button { color: var(--brand-secondary); font-weight: 700; font-size: 12px; padding: 4px 8px; }

@keyframes snackbar-in {
  from { opacity: 0; transform: translate(-50%, 20px); }
  to { opacity: 1; transform: translate(-50%, 0); }
}

/* ===== Modal ===== */
.modal-scrim {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.5);
  backdrop-filter: blur(2px);
  display: grid; place-items: center;
  z-index: 100;
  animation: fade-in 200ms;
  padding: 24px;
}
@keyframes fade-in { from { opacity: 0; } to { opacity: 1; } }
.modal {
  background: var(--surface-container-lowest);
  border-radius: var(--radius-xl);
  max-width: 720px;
  width: 100%;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: var(--elev-4);
  animation: modal-in 250ms cubic-bezier(0.2, 0, 0, 1);
}
.modal.large { max-width: 1100px; }
.modal.small { max-width: 480px; }
@keyframes modal-in {
  from { opacity: 0; transform: scale(0.95) translateY(10px); }
  to { opacity: 1; transform: scale(1) translateY(0); }
}
.modal-header {
  padding: 16px 20px 10px;
  border-bottom: 1px solid var(--outline-variant);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}
.modal-title { font-size: 18px; font-weight: 600; margin: 0; }
.modal-body { padding: 14px 20px; overflow-y: auto; flex: 1; }
.modal-footer { padding: 10px 20px 14px; display: flex; gap: 8px; justify-content: flex-end; border-top: 1px solid var(--outline-variant); }

/* ===== Kanban ===== */
.kanban {
  display: grid;
  grid-template-columns: repeat(4, minmax(230px, 1fr));
  gap: 10px;
  align-items: start;
}
@media (max-width: 1100px) {
  .kanban { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 1400px) {
  .kanban { grid-template-columns: repeat(4, minmax(250px, 1fr)); }
  .main { padding-left: 28px; padding-right: 28px; }
}
@media (max-width: 700px) {
  .kanban { grid-template-columns: 1fr; }
}
.kanban-col {
  background: var(--surface-container-low);
  border-radius: var(--radius-md);
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 7px;
  min-height: 200px;
  transition: background var(--motion-fast), outline var(--motion-fast);
  outline: 2px dashed transparent;
  outline-offset: -4px;
}
.kanban-col[data-drop-active="true"] {
  background: var(--brand-primary-container);
  outline-color: var(--brand-primary);
}
.kanban-col-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 6px 2px;
}
.kanban-col-title { font-size: 13px; font-weight: 700; color: var(--on-surface); }
.kanban-col-count {
  background: var(--surface-container-high);
  color: var(--on-surface-variant);
  padding: 2px 10px;
  border-radius: var(--radius-full);
  font-size: 11px;
  font-weight: 600;
}
.kanban-col[data-status="draft"] .kanban-col-count { background: var(--surface-container-high); }
.kanban-col[data-status="submitted"] .kanban-col-count { background: var(--info-container); color: var(--info); }
.kanban-col[data-status="approved"] .kanban-col-count { background: var(--success-container); color: var(--on-success-container); }
.kanban-col[data-status="rejected"] .kanban-col-count { background: var(--error-container); color: var(--on-error-container); }

.kanban-type-summary {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
}
.kanban-type-summary > div {
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  padding: 7px 8px;
  background: var(--surface-container-lowest);
  display: grid;
  gap: 2px;
  min-width: 0;
}
.kanban-type-summary span {
  font-size: 10px;
  font-weight: 600;
  color: var(--on-surface-variant);
}
.kanban-type-summary b {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--on-surface);
  overflow: hidden;
  text-overflow: ellipsis;
}
.kanban-type-summary em {
  font-style: normal;
  font-size: 10px;
  color: var(--on-surface-variant);
}
.kanban-type-summary [data-tone="annual"],
.kanban-type-section[data-tone="annual"] {
  border-left: 3px solid var(--plan-annual);
  background: color-mix(in oklab, var(--plan-annual-container), var(--surface-container-lowest) 72%);
}
.kanban-type-summary [data-tone="supplemental"],
.kanban-type-section[data-tone="supplemental"] {
  border-left: 3px solid var(--plan-supplemental);
  background: color-mix(in oklab, var(--plan-supplemental-container), var(--surface-container-lowest) 68%);
}
.kanban-type-summary [data-tone="annual"] span,
.kanban-type-section[data-tone="annual"] .kanban-type-heading { color: var(--plan-annual-text); }
.kanban-type-summary [data-tone="supplemental"] span,
.kanban-type-section[data-tone="supplemental"] .kanban-type-heading { color: var(--plan-supplemental-text); }

.kanban-type-section {
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  padding: 7px;
  background: color-mix(in oklab, var(--surface-container-lowest), var(--surface-container-low) 35%);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.kanban-type-heading {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  padding: 0 2px;
  font-size: 11px;
  font-weight: 700;
  color: var(--on-surface-variant);
}

.kanban-card {
  background: var(--surface-container-lowest);
  border-radius: var(--radius-md);
  padding: 9px;
  border: 1px solid var(--outline-variant);
  cursor: grab;
  transition: box-shadow var(--motion-fast), transform var(--motion-fast);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.kanban-card[data-plan-type="annual"] {
  border-left: 4px solid var(--plan-annual);
  box-shadow: inset 0 0 0 9999px color-mix(in oklab, var(--plan-annual-container), transparent 88%);
}
.kanban-card[data-plan-type="supplemental"] {
  border-left: 4px solid var(--plan-supplemental);
  box-shadow: inset 0 0 0 9999px color-mix(in oklab, var(--plan-supplemental-container), transparent 86%);
}
.kanban-card:hover { box-shadow: var(--elev-2); transform: translateY(-1px); }
.kanban-card[data-plan-type="annual"]:hover {
  box-shadow: var(--elev-2), inset 0 0 0 9999px color-mix(in oklab, var(--plan-annual-container), transparent 88%);
}
.kanban-card[data-plan-type="supplemental"]:hover {
  box-shadow: var(--elev-2), inset 0 0 0 9999px color-mix(in oklab, var(--plan-supplemental-container), transparent 86%);
}
.kanban-card.dragging { opacity: 0.4; }
.kanban-card-title { font-size: 13px; font-weight: 600; line-height: 1.4; }
.budget-signal-note {
  border-radius: var(--radius-xs);
  padding: 5px 7px;
  font-size: 10px;
  font-weight: 600;
  line-height: 1.35;
  background: var(--surface-container-low);
  color: var(--on-surface-variant);
}
.budget-signal-note[data-tone="normal"] {
  background: var(--info-container);
  color: var(--info);
}
.budget-signal-note[data-tone="success"] {
  background: var(--success-container);
  color: var(--on-success-container);
}
.budget-signal-note[data-tone="warning"] {
  background: var(--warning-container);
  color: var(--on-warning-container);
}
.budget-signal-note[data-tone="danger"] {
  background: var(--error-container);
  color: var(--on-error-container);
}
.kanban-card-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11px;
  color: var(--on-surface-variant);
}
.kanban-card-budget {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
  color: var(--on-surface);
}
.kanban-card-tags { display: flex; gap: 4px; flex-wrap: wrap; }

.plan-type-chip[data-plan-type="annual"] {
  background: var(--plan-annual-container);
  color: var(--plan-annual-text);
}
.plan-type-chip[data-plan-type="supplemental"] {
  background: var(--plan-supplemental-container);
  color: var(--plan-supplemental-text);
}

.plan-item-button[data-plan-type="annual"] {
  border-left: 3px solid var(--plan-annual);
  background: color-mix(in oklab, var(--plan-annual-container), transparent 72%);
  color: var(--plan-annual-text);
}
.plan-item-button[data-plan-type="supplemental"] {
  border-left: 3px solid var(--plan-supplemental);
  background: color-mix(in oklab, var(--plan-supplemental-container), transparent 68%);
  color: var(--plan-supplemental-text);
}

.budget-signal-panel {
  border: 1px solid var(--outline-variant);
  border-left: 4px solid var(--outline);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
  padding: 12px;
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(260px, auto);
  gap: 12px;
  align-items: center;
}
.budget-signal-panel[data-tone="normal"] { border-left-color: var(--info); background: color-mix(in oklab, var(--info-container), var(--surface-container-lowest) 70%); }
.budget-signal-panel[data-tone="success"] { border-left-color: var(--success); background: color-mix(in oklab, var(--success-container), var(--surface-container-lowest) 72%); }
.budget-signal-panel[data-tone="warning"] { border-left-color: var(--warning); background: color-mix(in oklab, var(--warning-container), var(--surface-container-lowest) 70%); }
.budget-signal-panel[data-tone="danger"] { border-left-color: var(--error); background: color-mix(in oklab, var(--error-container), var(--surface-container-lowest) 72%); }
.budget-signal-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--on-surface);
}
.budget-signal-desc {
  font-size: 12px;
  color: var(--on-surface-variant);
  margin-top: 2px;
}
.budget-signal-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.budget-signal-metrics span {
  display: grid;
  gap: 2px;
  padding: 8px;
  border-radius: var(--radius-sm);
  background: color-mix(in oklab, var(--surface-container-lowest), transparent 8%);
  font-size: 10px;
  color: var(--on-surface-variant);
}
.budget-signal-metrics b {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--on-surface);
  white-space: nowrap;
}
@media (max-width: 760px) {
  .budget-signal-panel { grid-template-columns: 1fr; }
  .budget-signal-metrics { grid-template-columns: 1fr; }
}

/* ===== Spreadsheet grid ===== */
.sheet {
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  overflow: auto;
  max-height: 68vh;
  background: var(--surface-container-lowest);
}
.sheet table { border-collapse: collapse; width: 100%; font-size: 12px; }
.sheet th, .sheet td {
  border: 1px solid var(--outline-variant);
  padding: 0;
  vertical-align: middle;
}
.sheet th {
  background: var(--surface-container-low);
  padding: 6px 8px;
  font-weight: 600;
  font-size: 11px;
  text-align: left;
  position: sticky;
  top: 0;
  z-index: 2;
  white-space: nowrap;
}
.sheet th.num, .sheet td.num { text-align: right; }
.sheet td input, .sheet td select {
  width: 100%;
  border: none;
  outline: none;
  background: transparent;
  padding: 6px 8px;
  font-size: 12px;
  font-variant-numeric: tabular-nums;
}
.sheet td input.num { text-align: right; font-family: var(--font-mono); }
.sheet td.editing { background: color-mix(in oklab, var(--brand-primary), transparent 92%); }
.sheet td:focus-within { background: color-mix(in oklab, var(--brand-primary), transparent 90%); box-shadow: inset 0 0 0 2px var(--brand-primary); }
.sheet tfoot td {
  background: var(--surface-container);
  font-weight: 700;
  font-family: var(--font-mono);
  padding: 8px;
}
.sheet tbody tr:hover { background: var(--surface-container-low); }
.sheet td.code { font-family: var(--font-mono); padding: 8px 10px; color: var(--on-surface-variant); white-space: nowrap; }

.import-helper {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) minmax(260px, 0.75fr) auto;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-low);
  min-width: 0;
}
.import-helper-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--on-surface);
}
.import-helper-title .material-symbols-rounded {
  font-size: 18px;
  color: var(--brand-primary);
}
.import-helper-sub {
  font-size: 11px;
  color: var(--on-surface-variant);
  margin-top: 2px;
}
.import-actions {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.activity-detail-cell {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) 106px;
  gap: 4px;
  min-width: 320px;
  padding: 3px 4px;
  align-items: center;
}
.activity-select {
  min-width: 0;
}
.activity-detail-cell select {
  min-height: 26px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-xs);
  background: var(--surface-container-lowest);
}
.activity-month-trigger {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 4px;
  align-items: baseline;
  min-height: 26px;
  padding: 3px 7px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-full);
  background: color-mix(in oklab, var(--brand-primary-container), var(--surface-container-lowest) 45%);
  color: var(--brand-on-primary-container);
  cursor: pointer;
  text-align: left;
  width: 100%;
}
.activity-month-trigger:hover {
  border-color: var(--brand-primary);
  background: var(--brand-primary-container);
}
.activity-month-trigger span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 11px;
  font-weight: 700;
}
.activity-month-trigger small {
  color: var(--brand-on-primary-container);
  font-size: 9px;
  font-weight: 700;
  white-space: nowrap;
  opacity: 0.78;
}
.month-picker-modal .modal-header p {
  margin: 2px 0 0;
  font-size: 12px;
  color: var(--on-surface-variant);
}
.month-picker-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-low);
}
.month-picker-summary b {
  color: var(--on-surface);
}
.month-picker-summary span {
  color: var(--on-surface-variant);
  font-size: 12px;
  white-space: nowrap;
}
.month-picker-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 10px 0 12px;
}
.month-chip-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}
.month-chip {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 38px;
  padding: 7px 8px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-lowest);
  color: var(--on-surface-variant);
  font-weight: 700;
  cursor: pointer;
}
.month-chip:hover {
  border-color: var(--brand-primary);
  color: var(--on-surface);
}
.month-chip.selected {
  border-color: transparent;
  background: var(--brand-primary);
  color: var(--brand-on-primary);
}
.month-chip .material-symbols-rounded {
  font-size: 16px;
}
.unitcost-lock-note {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 10px 12px;
  margin-bottom: 10px;
  border: 1px solid var(--info-container);
  border-radius: var(--radius-sm);
  background: color-mix(in oklab, var(--info-container), var(--surface-container-lowest) 42%);
}
.unitcost-lock-note .material-symbols-rounded {
  color: var(--info);
}
.unitcost-lock-note div {
  display: grid;
  gap: 2px;
}
.unitcost-lock-note b {
  color: var(--on-surface);
}
.unitcost-lock-note span {
  font-size: 12px;
  color: var(--on-surface-variant);
}
.unitcost-hero {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.unitcost-kpi {
  display: grid;
  gap: 4px;
  padding: 12px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
}
.unitcost-kpi span {
  font-size: 11px;
  color: var(--on-surface-variant);
}
.unitcost-kpi b {
  font-size: 18px;
  color: var(--on-surface);
}
.unitcost-sheet .sheet,
.unitcost-sheet {
  max-height: 58vh;
}
.unitcost-toolbar {
  display: grid;
  grid-template-columns: repeat(3, minmax(140px, 1fr)) auto;
  gap: 8px;
  align-items: end;
  min-width: min(100%, 720px);
}
.unitcost-toolbar label {
  display: grid;
  gap: 4px;
  min-width: 0;
}
.unitcost-toolbar label span {
  font-size: 10px;
  font-weight: 700;
  color: var(--on-surface-variant);
}
.unitcost-toolbar .field-select {
  width: 100%;
}
.unitcost-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.unitcost-revision-panel {
  padding-top: 0;
}
.revision-summary-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-low);
}
.revision-summary-row > div:first-child {
  display: grid;
  gap: 3px;
  min-width: 0;
}
.revision-summary-row .chip {
  justify-self: start;
}
.revision-summary-row b,
.revision-history-item b {
  color: var(--on-surface);
}
.revision-summary-row small,
.revision-summary-row p,
.revision-history-item small,
.revision-history-item p {
  margin: 0;
  color: var(--on-surface-variant);
  font-size: 11px;
}
.revision-summary-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
}
.revision-history-modal .modal-header p {
  margin: 2px 0 0;
  color: var(--on-surface-variant);
  font-size: 12px;
}
.revision-history-list {
  display: grid;
  gap: 8px;
}
.revision-history-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  padding: 9px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-lowest);
}
.revision-history-item.active {
  border-color: var(--brand-primary);
  background: color-mix(in oklab, var(--brand-primary-container), var(--surface-container-lowest) 60%);
}
.revision-history-item > button:first-child {
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: 0;
  border: 0;
  background: transparent;
  text-align: left;
  cursor: pointer;
}
.revision-history-item .chip {
  justify-self: start;
}
.revision-empty {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px;
  border: 1px dashed var(--outline-variant);
  border-radius: var(--radius-sm);
  color: var(--on-surface-variant);
  background: var(--surface-container-low);
  font-size: 12px;
}
.revision-empty .material-symbols-rounded {
  font-size: 18px;
}
.lock-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 10px;
}
.lock-status-board {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 10px;
}
.lock-status-card {
  display: grid;
  gap: 8px;
  min-width: 0;
  padding: 10px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
}
.lock-status-card[data-state="locked"] {
  background: color-mix(in oklab, var(--error-container), var(--surface-container-lowest) 76%);
}
.lock-status-card[data-state="open"] {
  background: color-mix(in oklab, var(--success-container), var(--surface-container-lowest) 74%);
}
.lock-compact-panel {
  display: grid;
  gap: 8px;
  margin-bottom: 10px;
  padding: 10px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
}
.period-type-tabs {
  display: inline-flex;
  gap: 4px;
  padding: 4px;
  margin-bottom: 10px;
  border-radius: var(--radius-full);
  background: var(--surface-container);
}
.period-type-tabs button {
  padding: 7px 14px;
  border-radius: var(--radius-full);
  color: var(--on-surface-variant);
  font-size: 12px;
  font-weight: 700;
}
.period-type-tabs button.active {
  background: var(--brand-primary);
  color: var(--brand-on-primary);
}
.lock-primary-action {
  display: grid;
  gap: 8px;
  margin-bottom: 10px;
  padding: 10px;
  border: 1px solid color-mix(in oklab, var(--brand-primary), transparent 76%);
  border-radius: var(--radius-md);
  background: color-mix(in oklab, var(--brand-primary-container), var(--surface-container-lowest) 76%);
}
.lock-action-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}
.lock-action-head > div:first-child {
  display: grid;
  gap: 2px;
}
.lock-action-head b {
  color: var(--on-surface);
  font-size: 14px;
}
.lock-action-head span {
  color: var(--on-surface-variant);
  font-size: 11px;
}
.nation-lock-action {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 140px auto;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
}
.nation-lock-action[data-state="locked"] {
  border-color: color-mix(in oklab, var(--error), transparent 58%);
  background: color-mix(in oklab, var(--error-container), var(--surface-container-lowest) 74%);
}
.nation-lock-action[data-state="open"] {
  border-color: color-mix(in oklab, var(--success), transparent 62%);
  background: color-mix(in oklab, var(--success-container), var(--surface-container-lowest) 76%);
}
.nation-lock-action > div {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 4px 8px;
  align-items: center;
  min-width: 0;
}
.nation-lock-action b {
  min-width: 0;
  color: var(--on-surface);
  font-size: 14px;
}
.nation-lock-action small {
  grid-column: 2;
  color: var(--on-surface-variant);
  font-size: 11px;
}
.nation-lock-action label {
  display: grid;
  gap: 4px;
}
.nation-lock-action label span {
  font-size: 10px;
  font-weight: 700;
  color: var(--on-surface-variant);
}
.lock-matrix {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}
.lock-matrix-cell {
  display: grid;
  gap: 2px;
  padding: 8px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-low);
  text-align: left;
  cursor: pointer;
}
.lock-matrix-cell.active {
  border-color: var(--brand-primary);
  background: var(--brand-primary-container);
}
.lock-matrix-cell span {
  color: var(--on-surface-variant);
  font-size: 10px;
  font-weight: 700;
}
.lock-matrix-cell b {
  color: var(--on-surface);
  font-size: 18px;
  line-height: 1;
}
.lock-matrix-cell small {
  color: var(--on-surface-variant);
  font-size: 10px;
}
.lock-list-tools {
  display: grid;
  grid-template-columns: auto minmax(180px, 1fr);
  gap: 8px;
  align-items: center;
}
.period-hierarchy-filters {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.period-hierarchy-filters label {
  display: grid;
  gap: 4px;
  min-width: 0;
}
.period-hierarchy-filters label span {
  font-size: 10px;
  font-weight: 700;
  color: var(--on-surface-variant);
}
.period-hierarchy-filters .field-select {
  width: 100%;
}
.segmented.mini button {
  padding: 4px 9px;
  font-size: 11px;
}
.lock-search {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  padding: 5px 9px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-full);
  background: var(--surface-container-low);
}
.lock-search .material-symbols-rounded {
  font-size: 16px;
  color: var(--on-surface-variant);
}
.lock-search input {
  width: 100%;
  min-width: 0;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--on-surface);
  font-size: 12px;
}
.lock-compact-list {
  display: grid;
  gap: 4px;
  max-height: 286px;
  overflow: auto;
}
.lock-compact-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  padding: 7px 8px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-low);
}
.lock-compact-row[data-state="locked"] {
  border-left: 3px solid var(--error);
}
.lock-compact-row[data-state="open"] {
  border-left: 3px solid var(--success);
}
.lock-compact-row > div {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 4px 7px;
  align-items: center;
  min-width: 0;
}
.lock-compact-row b {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--on-surface);
}
.lock-compact-row small {
  grid-column: 2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--on-surface-variant);
  font-size: 10px;
}
.lock-list-footer {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 10px;
  color: var(--on-surface-variant);
  font-size: 11px;
}
.lock-list-footer > div {
  display: flex;
  align-items: center;
  gap: 4px;
}
.rows-per-page {
  display: flex;
  align-items: center;
  gap: 6px;
}
.rows-per-page .field-select {
  width: 92px;
  min-height: 32px;
  padding-block: 4px;
  font-size: 12px;
}

/* ===== Allocation workflow ===== */
.allocation-summary-table {
  width: 100%;
  min-width: 980px;
  table-layout: fixed;
}

.allocation-summary-table th,
.allocation-summary-table td {
  overflow: hidden;
  text-overflow: ellipsis;
}

.allocation-summary-table td:nth-child(2) div:first-child {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.planet-change-table {
  width: 100%;
  min-width: 1040px;
  table-layout: fixed;
}

.planet-change-table th:nth-child(7),
.planet-change-table td:nth-child(7) {
  white-space: normal;
}

.link-num {
  padding: 0;
  color: var(--brand-primary);
  font: inherit;
  font-family: var(--font-mono);
  font-weight: 750;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.link-num.positive {
  color: var(--success);
}

.link-num.negative {
  color: var(--error);
}

.allocation-balance-kpi.remaining {
  border-color: color-mix(in oklab, var(--info), transparent 62%);
}

.allocation-balance-kpi.remaining .kpi-icon {
  background: var(--info-container);
  color: var(--info);
}

.allocation-balance-kpi.remaining .kpi-value,
.allocation-balance-kpi.remaining .kpi-sub {
  color: var(--info);
}

.allocation-balance-kpi.over {
  border-color: color-mix(in oklab, var(--error), transparent 58%);
}

.allocation-balance-kpi.over .kpi-icon {
  background: var(--error-container);
  color: var(--error);
}

.allocation-balance-kpi.over .kpi-value,
.allocation-balance-kpi.over .kpi-sub {
  color: var(--error);
}

.allocation-balance-kpi.complete {
  border-color: color-mix(in oklab, var(--success), transparent 58%);
}

.allocation-balance-kpi.complete .kpi-icon {
  background: var(--success-container);
  color: var(--success);
}

.allocation-balance-kpi.complete .kpi-value,
.allocation-balance-kpi.complete .kpi-sub {
  color: var(--success);
}

.allocation-editor {
  display: grid;
  gap: 10px;
}

.allocation-editor-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.allocation-editor-summary > div {
  display: grid;
  gap: 3px;
  padding: 10px 12px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-low);
}

.allocation-editor-summary span {
  color: var(--on-surface-variant);
  font-size: 11px;
  font-weight: 750;
}

.allocation-editor-summary b {
  color: var(--on-surface);
  font-family: var(--font-mono);
  font-size: 18px;
}

.allocation-editor-summary [data-state="over"] {
  background: var(--error-container);
  border-color: color-mix(in oklab, var(--error), transparent 56%);
}

.allocation-editor-summary [data-state="over"] b,
.allocation-editor-summary [data-state="over"] span {
  color: var(--on-error-container);
}

.allocation-editor-table .data-table {
  width: 100%;
  min-width: 760px;
  table-layout: fixed;
}

.allocation-editor-table th,
.allocation-editor-table td {
  overflow: hidden;
}

.allocation-money-input {
  width: min(150px, 100%);
  text-align: right;
  font-family: var(--font-mono);
}

/* ===== Unit cost table refresh ===== */
.unitcost-table-wrap {
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  max-height: 520px;
}

.unitcost-table {
  width: 100%;
  min-width: 1180px;
  table-layout: fixed;
}

.unitcost-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--surface-container);
}

.unitcost-table tbody tr:nth-child(even) td {
  background: color-mix(in oklab, var(--surface-container-lowest), var(--surface-container-low) 42%);
}

.unitcost-activity-cell {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.unitcost-activity-cell b {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--on-surface);
}

.unitcost-activity-cell span {
  color: var(--on-surface-variant);
  font-size: 10px;
}

.unitcost-number-input {
  width: min(104px, 100%);
  text-align: right;
  font-family: var(--font-mono);
}
.lock-status-head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 7px;
}
.lock-status-head .material-symbols-rounded {
  font-size: 18px;
}
.lock-status-head b {
  color: var(--on-surface);
}
.lock-status-head span {
  min-width: 24px;
  padding: 2px 7px;
  border-radius: var(--radius-full);
  background: var(--surface-container-high);
  color: var(--on-surface);
  text-align: center;
  font-size: 11px;
  font-weight: 700;
}
.lock-unit-list {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  padding-bottom: 2px;
}
.lock-unit-chip {
  display: grid;
  gap: 1px;
  min-width: 138px;
  max-width: 180px;
  padding: 7px 9px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-full);
  background: color-mix(in oklab, var(--surface-container-lowest), transparent 8%);
  text-align: left;
  cursor: pointer;
}
.lock-unit-chip span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--on-surface);
  font-size: 11px;
  font-weight: 700;
}
.lock-unit-chip small,
.lock-unit-empty {
  color: var(--on-surface-variant);
  font-size: 10px;
}
.lock-create-panel {
  display: grid;
  grid-template-columns: 150px minmax(180px, 0.8fr) minmax(220px, 1.2fr) minmax(220px, 1.2fr) auto;
  gap: 8px;
  align-items: end;
  padding: 10px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
}
.lock-create-panel-top {
  padding: 0;
  border: 0;
  background: transparent;
}
.lock-create-panel label {
  display: grid;
  gap: 4px;
  min-width: 0;
}
.lock-create-panel label span {
  font-size: 10px;
  font-weight: 700;
  color: var(--on-surface-variant);
}
.lock-create-panel .field-select,
.lock-create-panel .field-input {
  width: 100%;
}
.intake-control-card {
  border-color: color-mix(in oklab, var(--brand-primary), transparent 78%);
}
.intake-control-card .card-header {
  background: color-mix(in oklab, var(--brand-primary-container), var(--surface-container-lowest) 70%);
}
.lock-card {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  padding: 12px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-low);
}
.lock-card[data-locked="true"] {
  border-color: color-mix(in oklab, var(--error), transparent 60%);
  background: color-mix(in oklab, var(--error-container), var(--surface-container-lowest) 70%);
}
.lock-card div {
  display: grid;
  gap: 4px;
  min-width: 0;
}
.lock-card .chip {
  justify-self: start;
}
.lock-card b {
  color: var(--on-surface);
}
.lock-card span,
.lock-card p {
  margin: 0;
  font-size: 12px;
  color: var(--on-surface-variant);
}
.review-activity-list {
  display: grid;
  gap: 8px;
  margin-top: 8px;
}
.review-activity-item {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(180px, 0.8fr);
  gap: 10px;
  align-items: center;
  padding: 10px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-low);
}
.review-activity-item > div {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.review-activity-item b {
  color: var(--on-surface);
}
.review-activity-item span {
  font-size: 11px;
  color: var(--on-surface-variant);
}
@media (max-width: 900px) {
  .import-helper,
  .review-activity-item,
  .lock-grid,
  .lock-status-board,
  .lock-action-head,
  .nation-lock-action,
  .lock-matrix,
  .lock-list-tools,
  .period-hierarchy-filters,
  .lock-create-panel,
  .lock-list-footer,
  .unitcost-hero,
  .unitcost-toolbar {
    grid-template-columns: 1fr;
  }
  .unitcost-actions {
    justify-content: flex-start;
  }
  .revision-summary-row,
  .revision-history-item {
    align-items: stretch;
    grid-template-columns: 1fr;
    flex-direction: column;
  }
  .revision-summary-actions {
    justify-content: flex-start;
  }
  .lock-action-head {
    align-items: stretch;
    flex-direction: column;
  }
  .import-actions {
    justify-content: flex-start;
  }
  .import-helper .btn {
    justify-self: start;
  }
}
@media (max-width: 640px) {
  .activity-detail-cell {
    grid-template-columns: 1fr;
    min-width: 300px;
  }
  .activity-month-trigger {
    max-width: 128px;
  }
  .month-chip-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* ===== Stepper ===== */
.stepper {
  display: flex;
  align-items: center;
  gap: 0;
  margin: 0 0 14px;
  flex-wrap: wrap;
}
.stepper-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  font-size: 12px;
  color: var(--on-surface-variant);
}
.stepper-num {
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--surface-container-high);
  color: var(--on-surface-variant);
  display: grid; place-items: center;
  font-size: 12px;
  font-weight: 700;
  border: 2px solid transparent;
}
.stepper-item.active .stepper-num {
  background: var(--brand-primary);
  color: var(--brand-on-primary);
}
.stepper-item.done .stepper-num {
  background: var(--success);
  color: white;
}
.stepper-item.active .stepper-label { color: var(--on-surface); font-weight: 600; }
.stepper-line { flex: 0 0 32px; height: 2px; background: var(--outline-variant); }
.stepper-item.done + .stepper-line { background: var(--success); }

/* ===== Tabs ===== */
.tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--outline-variant);
  margin-bottom: 16px;
  overflow-x: auto;
}
.tab {
  padding: 12px 20px;
  font-size: 13px;
  font-weight: 600;
  color: var(--on-surface-variant);
  border-bottom: 2px solid transparent;
  transition: color var(--motion-fast), border-color var(--motion-fast);
  white-space: nowrap;
}
.tab:hover { color: var(--on-surface); }
.tab.active {
  color: var(--brand-primary);
  border-bottom-color: var(--brand-primary);
}

/* ===== Bar / Donut placeholders ===== */
.chart-bar {
  display: flex;
  align-items: flex-end;
  gap: 12px;
  height: 240px;
  padding: 20px 0;
}
.chart-bar-col {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  height: 100%;
  justify-content: flex-end;
}
.chart-bar-col .bar-stack {
  width: 100%;
  display: flex;
  flex-direction: column;
  border-radius: var(--radius-xs);
  overflow: hidden;
  transition: transform var(--motion-fast);
}
.chart-bar-col:hover .bar-stack { transform: translateY(-2px); }
.chart-bar-col .bar-label {
  font-size: 11px;
  color: var(--on-surface-variant);
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
}
.chart-bar-col .bar-value {
  font-size: 11px;
  font-family: var(--font-mono);
  font-weight: 700;
  color: var(--on-surface);
}

/* ===== Map placeholder ===== */
.map-card {
  background: var(--surface-container-low);
  border-radius: var(--radius-lg);
  border: 1px solid var(--outline-variant);
  overflow: hidden;
  position: relative;
  height: 360px;
}
.map-svg { display: block; width: 100%; height: 100%; }

/* ===== Drawer (right panel for plan detail) ===== */
.drawer-scrim { position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 90; animation: fade-in 200ms; }
.drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: 720px; max-width: 100vw;
  background: var(--surface-container-lowest);
  z-index: 91;
  display: flex; flex-direction: column;
  box-shadow: var(--elev-4);
  animation: drawer-in 280ms cubic-bezier(0.2, 0, 0, 1);
}
@keyframes drawer-in { from { transform: translateX(100%); } to { transform: translateX(0); } }
.drawer-header {
  padding: 12px 18px;
  border-bottom: 1px solid var(--outline-variant);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}
.drawer-body { flex: 1; overflow-y: auto; padding: 14px 18px; }
.drawer-footer { padding: 10px 18px; border-top: 1px solid var(--outline-variant); display: flex; gap: 8px; justify-content: flex-end; }

/* ===== Stock pill / bars ===== */
.stock-bar {
  height: 6px;
  background: var(--surface-container-high);
  border-radius: var(--radius-full);
  overflow: hidden;
  position: relative;
  width: 120px;
}
.stock-bar-fill {
  height: 100%;
  background: var(--success);
  border-radius: var(--radius-full);
  transition: width var(--motion-med);
}
.stock-bar-fill.low { background: var(--warning); }
.stock-bar-fill.critical { background: var(--error); }

/* ===== Work result and settings workflows ===== */
.work-result-tabs {
  position: sticky;
  top: 72px;
  z-index: 20;
  background: color-mix(in oklab, var(--surface-container-lowest), transparent 8%);
  backdrop-filter: blur(12px);
}

.work-result-tabs.compact-tabs {
  position: static;
  top: auto;
  z-index: auto;
}

.report-control-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.report-control-row > .btn {
  flex: 0 0 auto;
}

.report-management-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-width: 0;
}

.report-management-head h3 {
  margin: 0;
  color: var(--on-surface);
  font-size: 17px;
  line-height: 1.25;
}

.report-management-head p {
  margin: 2px 0 0;
  color: var(--on-surface-variant);
  font-size: 12px;
}

.report-head-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.report-filter-toolbar {
  margin-top: -4px;
  align-items: end;
  padding: 10px 14px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
  box-shadow: var(--elev-1);
}

.plan-subview-toggle {
  display: inline-flex;
  width: fit-content;
  gap: 4px;
  padding: 4px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-full);
  background: var(--surface-container-lowest);
  box-shadow: var(--elev-1);
}

.plan-subview-toggle button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 32px;
  padding: 6px 12px;
  border-radius: var(--radius-full);
  color: var(--on-surface-variant);
  font-size: 12px;
  font-weight: 700;
}

.plan-subview-toggle button.active {
  background: var(--brand-primary-container);
  color: var(--brand-primary);
}

.report-summary-band .plan-summary-statuses.two-status {
  grid-template-columns: repeat(2, minmax(170px, 1fr));
}

.report-status-board {
  grid-template-columns: repeat(2, minmax(280px, 1fr));
}

.report-status-board .kanban-type-summary {
  grid-template-columns: 1fr;
}

.report-status-board .kanban-type-summary > div {
  min-height: 64px;
  border-color: color-mix(in oklab, var(--brand-primary), transparent 72%);
}

.report-status-board .kanban-col[data-status="submitted"] .kanban-type-summary > div {
  background: color-mix(in oklab, var(--info-container), var(--surface-container-lowest) 48%);
  border-color: color-mix(in oklab, var(--info), transparent 62%);
}

.report-status-board .kanban-type-summary b {
  font-size: 18px;
}

.report-col-corner {
  display: grid;
  gap: 1px;
  text-align: right;
}

.report-col-corner b {
  color: var(--brand-primary);
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1.15;
}

.report-col-corner span {
  color: var(--on-surface-variant);
  font-size: 10px;
  font-weight: 700;
}

.report-kanban-card {
  cursor: pointer;
}

.report-kanban-card[draggable="true"] {
  cursor: grab;
}

.report-kanban-card[draggable="true"]:active {
  cursor: grabbing;
}

.report-step1-body {
  display: grid;
  gap: 10px;
}

.report-step1-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(340px, 0.75fr);
  gap: 10px;
  align-items: stretch;
}

.report-entry-panel {
  display: grid;
  gap: 10px;
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
}

.report-entry-panel-head {
  display: flex;
  align-items: center;
  gap: 9px;
  min-width: 0;
}

.report-entry-panel-head > .material-symbols-rounded {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: var(--radius-sm);
  background: var(--brand-primary-container);
  color: var(--brand-primary);
  flex: 0 0 auto;
}

.report-entry-panel-head div {
  display: grid;
  gap: 1px;
  min-width: 0;
}

.report-entry-panel-head b {
  color: var(--on-surface);
  font-size: 13px;
}

.report-entry-panel-head span {
  color: var(--on-surface-variant);
  font-size: 11px;
  font-weight: 650;
}

.report-primary-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.report-date-panel .work-range-picker {
  padding: 0;
  border: 0;
  background: transparent;
}

.report-date-panel .work-range-topline {
  grid-template-columns: 1fr;
}

.report-date-panel .work-range-inputs {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.report-date-panel .work-range-add {
  grid-column: 1 / -1;
  width: 100%;
}

.work-date-picker {
  display: grid;
  gap: 8px;
}

.work-date-picker > div {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.work-date-chip {
  cursor: pointer;
}

.work-date-chip .material-symbols-rounded {
  font-size: 14px;
}

.work-range-field {
  display: grid;
  gap: 7px;
}

.field-label {
  color: var(--on-surface-variant);
  font-size: 12px;
  font-weight: 800;
}

.work-range-picker {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-lowest);
}

.work-range-topline {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(190px, 260px);
  gap: 10px;
  align-items: stretch;
}

.work-range-inputs {
  display: grid;
  grid-template-columns: minmax(140px, 1fr) minmax(140px, 1fr) auto;
  gap: 8px;
  align-items: end;
}

.work-range-inputs label {
  min-width: 0;
}

.work-range-add {
  height: 40px;
  white-space: nowrap;
}

.work-range-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 38px;
  padding: 8px 10px;
  border-radius: var(--radius-xs);
  background: var(--brand-primary-container);
  color: var(--brand-on-primary-container);
}

.work-range-summary b,
.work-range-summary span {
  min-width: 0;
}

.work-range-summary span {
  color: var(--on-surface-variant);
  font-size: 12px;
  font-weight: 700;
  text-align: right;
}

.work-range-presets {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.work-range-presets button {
  min-height: 28px;
  padding: 4px 10px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-full);
  background: var(--surface-container-low);
  color: var(--on-surface-variant);
  cursor: pointer;
  font-size: 12px;
  font-weight: 800;
}

.work-range-presets button:hover {
  border-color: var(--brand-primary);
  color: var(--brand-primary);
}

.work-range-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 6px;
  max-height: 132px;
  overflow: auto;
  padding-right: 2px;
}

.work-range-list.compact {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  max-height: 104px;
}

.work-range-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 8px;
  min-height: 36px;
  padding: 7px 9px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-xs);
  background: var(--surface-container-low);
  color: var(--on-surface);
  cursor: pointer;
  text-align: left;
}

.work-range-list.compact .work-range-card {
  min-height: 32px;
  padding: 5px 8px;
}

.work-range-card:hover {
  border-color: var(--brand-primary);
  background: var(--surface-container);
}

.work-range-card span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 750;
}

.work-range-card small {
  color: var(--on-surface-variant);
  font-size: 11px;
  font-weight: 750;
  white-space: nowrap;
}

.work-range-card .material-symbols-rounded {
  font-size: 18px;
  color: var(--brand-primary);
}

.work-range-card .material-symbols-rounded:last-child {
  color: var(--on-surface-variant);
  font-size: 16px;
}

.work-range-empty {
  min-height: 36px;
  display: flex;
  align-items: center;
  padding: 0 10px;
  border: 1px dashed var(--outline-variant);
  border-radius: var(--radius-xs);
  color: var(--on-surface-variant);
  font-size: 12px;
  font-weight: 700;
}

.work-day-picker-card {
  display: grid;
  gap: 9px;
}

.work-day-trigger {
  width: 100%;
  min-height: 58px;
  grid-template-columns: minmax(0, 1fr) auto;
}

.work-day-summary {
  display: grid;
  gap: 2px;
  padding: 9px 10px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-low);
}

.work-day-summary b {
  color: var(--on-surface);
  font-size: 12px;
}

.work-day-summary span {
  color: var(--on-surface-variant);
  font-size: 12px;
  font-weight: 650;
  line-height: 1.35;
}

.work-day-chip-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 7px;
}

.work-day-chip {
  min-width: 0;
  padding-inline: 6px;
}

.work-day-chip span {
  font-family: var(--font-mono);
}

@media (max-width: 720px) {
  .work-range-topline {
    grid-template-columns: 1fr;
  }

  .work-range-inputs {
    grid-template-columns: 1fr;
  }

  .work-range-add {
    width: 100%;
  }

  .work-range-summary {
    align-items: flex-start;
    flex-direction: column;
  }

  .work-range-summary span {
    text-align: left;
  }

  .work-day-chip-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.labor-cost-table {
  min-width: 1180px;
}

.material-cost-table {
  min-width: 1060px;
}

.resource-entry-table {
  table-layout: fixed;
}

.resource-entry-table .col-person { width: 260px; }
.resource-entry-table .col-labor-type { width: 150px; }
.resource-entry-table .col-pay-mode { width: 130px; }
.resource-entry-table .col-money { width: 120px; }
.resource-entry-table .col-qty { width: 100px; }
.resource-entry-table .col-action { width: 52px; }
.resource-entry-table .col-fy { width: 140px; }
.resource-entry-table .col-material { width: 320px; }
.resource-entry-table .col-stock { width: 110px; }
.resource-entry-table .col-unit { width: 90px; }

.resource-entry-table th,
.resource-entry-table td {
  vertical-align: middle;
}

.resource-entry-table .field-select,
.resource-entry-table .field-input {
  width: 100%;
}

.resource-entry-table .num {
  text-align: right;
}

.monthly-w402-table {
  min-width: 980px;
}

.monthly-w402-card .card-header {
  padding-bottom: 10px;
}

.monthly-w402-table th {
  background: var(--surface-container);
}

.monthly-w402-table tbody tr:nth-child(even) td {
  background: color-mix(in oklab, var(--surface-container-lowest), var(--surface-container-low) 36%);
}

.monthly-w402-table td:nth-child(5) {
  background: color-mix(in oklab, var(--brand-primary-container), transparent 64%);
  color: var(--brand-primary);
}

.month-drill {
  font-weight: 750;
}

.justify-end {
  justify-content: flex-end;
}

.gap-6 {
  gap: 6px;
}

.drawer-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.drawer-list-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 10px 12px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
  color: var(--on-surface);
  text-align: left;
}

.drawer-list-item:hover {
  background: var(--brand-primary-container);
}

.drawer-list-item > div {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.drawer-list-item b,
.drawer-list-item span,
.drawer-list-item small {
  overflow: hidden;
  text-overflow: ellipsis;
}

.drawer-list-item span,
.drawer-list-item small {
  color: var(--on-surface-variant);
  font-size: 12px;
}

.report-step-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 10px;
  align-items: stretch;
}

.report-command-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.report-command-step {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  padding: 11px 12px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
  box-shadow: var(--elev-1);
}

.report-command-step.active {
  border-color: color-mix(in oklab, var(--brand-primary), transparent 45%);
  background: var(--brand-primary-container);
  color: var(--brand-on-primary-container);
}

.report-command-step > .material-symbols-rounded {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  border-radius: var(--radius-sm);
  background: var(--surface-container);
  color: var(--brand-primary);
}

.report-command-step.active > .material-symbols-rounded {
  background: var(--brand-primary);
  color: var(--brand-on-primary);
}

.report-command-step div {
  display: grid;
  min-width: 0;
}

.report-command-step b {
  font-size: 12px;
}

.report-command-step span {
  color: var(--on-surface-variant);
  font-size: 11px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.report-command-step.active span {
  color: var(--brand-on-primary-container);
}

.compact-form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
  align-items: end;
}

.compact-form-grid label {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.compact-form-grid label span {
  color: var(--on-surface-variant);
  font-size: 11px;
  font-weight: 650;
}

.compact-form-grid .wide-field {
  grid-column: span 2;
}

.compact-form-grid.one-col {
  grid-template-columns: 1fr;
}

.compact-inline {
  gap: 8px;
}

.crew-pick-panel {
  display: grid;
  grid-template-columns: minmax(180px, .45fr) minmax(0, 1fr);
  gap: 12px;
  margin-top: 14px;
  padding: 12px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-low);
}

.crew-pick-panel h4 {
  margin: 0 0 2px;
  font-size: 13px;
}

.crew-pick-panel p {
  margin: 0;
  color: var(--on-surface-variant);
  font-size: 11px;
}

.crew-pick-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 8px;
}

.crew-pick-list button {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 8px 10px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-lowest);
  color: var(--on-surface);
  text-align: left;
}

.crew-pick-list button.active {
  background: var(--brand-primary-container);
  color: var(--brand-on-primary-container);
  border-color: transparent;
  font-weight: 700;
}

.crew-pick-list small {
  color: var(--on-surface-variant);
  font-size: 10px;
  white-space: nowrap;
}

.crew-select-stack {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.crew-selected-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  max-height: 74px;
  overflow: auto;
  padding: 8px;
  border-radius: var(--radius-sm);
  background: var(--surface-container-lowest);
  border: 1px solid var(--outline-variant);
}

.report-cost-summary .card-body {
  display: grid;
  gap: 8px;
}

.mini-total-row,
.report-grand-total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 10px;
  border-radius: var(--radius-sm);
  background: var(--surface-container-low);
  min-width: 0;
}

.mini-total-row span,
.report-grand-total span {
  color: var(--on-surface-variant);
  font-size: 12px;
}

.mini-total-row b,
.report-grand-total strong {
  font-family: var(--font-mono);
  white-space: nowrap;
}

.report-grand-total {
  background: var(--brand-primary-container);
  color: var(--brand-on-primary-container);
  margin-top: 4px;
}

.report-grand-total span {
  color: var(--brand-on-primary-container);
}

.report-grand-total strong {
  font-size: 22px;
}

.readiness-meter {
  display: grid;
  gap: 7px;
  padding: 10px;
  border-radius: var(--radius-md);
  background: var(--surface-container-low);
  border: 1px solid var(--outline-variant);
}

.readiness-meter > div {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: baseline;
}

.readiness-meter b {
  color: var(--brand-primary);
  font-family: var(--font-mono);
  font-size: 18px;
}

.readiness-meter span {
  color: var(--on-surface-variant);
  font-size: 11px;
}

.readiness-meter progress {
  width: 100%;
  height: 7px;
  border: 0;
  border-radius: var(--radius-full);
  overflow: hidden;
  background: var(--surface-container-high);
}

.readiness-meter progress::-webkit-progress-bar {
  background: var(--surface-container-high);
}

.readiness-meter progress::-webkit-progress-value {
  background: var(--brand-primary);
  border-radius: var(--radius-full);
}

.readiness-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 5px;
}

.readiness-list > div {
  display: flex;
  align-items: center;
  gap: 7px;
  color: var(--on-surface-variant);
  font-size: 12px;
}

.readiness-list > div[data-ok="true"] {
  color: var(--success);
  font-weight: 650;
}

.readiness-list .material-symbols-rounded {
  font-size: 17px;
}

.compact-submit-panel {
  display: grid;
  grid-template-columns: minmax(150px, .7fr) minmax(260px, 1.4fr) minmax(170px, .7fr) auto;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
  box-shadow: var(--elev-1);
}

.compact-submit-status {
  display: grid;
  min-width: 0;
}

.submit-status-pill {
  display: flex;
  align-items: center;
  gap: 9px;
  min-width: 0;
  padding: 7px 9px;
  border-radius: var(--radius-sm);
  background: var(--warning-container);
  color: var(--on-warning-container);
  border: 1px solid color-mix(in oklab, var(--warning), transparent 70%);
}

.submit-status-pill[data-ready="true"] {
  background: var(--success-container);
  color: var(--on-success-container);
  border-color: transparent;
}

.submit-status-pill .material-symbols-rounded {
  font-size: 20px;
  flex: 0 0 auto;
}

.submit-status-pill > div {
  display: grid;
  min-width: 0;
}

.submit-status-pill b {
  font-size: 12px;
  line-height: 1.15;
}

.submit-status-pill span {
  font-size: 10px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  opacity: .86;
}

.compact-cost-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  min-width: 0;
}

.compact-cost-grid span {
  display: grid;
  gap: 8px;
  padding: 6px 8px;
  border-radius: var(--radius-sm);
  background: var(--surface-container-low);
  color: var(--on-surface-variant);
  font-size: 11px;
  min-width: 0;
}

.compact-cost-grid b {
  color: var(--on-surface);
  font-family: var(--font-mono);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.compact-total-line {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  padding: 7px 9px;
  border-radius: var(--radius-sm);
  background: var(--brand-primary-container);
  color: var(--brand-on-primary-container);
  min-width: 0;
}

.compact-total-line span {
  font-size: 11px;
  font-weight: 700;
}

.compact-total-line strong {
  font-family: var(--font-mono);
  font-size: 17px;
  white-space: nowrap;
}

.compact-submit-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(110px, 1fr));
  gap: 6px;
}

.form-action-footer {
  display: grid;
  grid-template-columns: minmax(180px, .55fr) minmax(260px, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
  box-shadow: var(--elev-1);
}

.form-action-total {
  display: grid;
  gap: 1px;
  min-width: 0;
}

.form-action-total span {
  color: var(--on-surface-variant);
  font-size: 11px;
  font-weight: 700;
}

.form-action-total strong {
  color: var(--brand-primary);
  font-family: var(--font-mono);
  font-size: 20px;
  white-space: nowrap;
}

.form-action-note {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  min-width: 0;
}

.form-action-note span {
  padding: 4px 8px;
  border-radius: var(--radius-full);
  background: var(--surface-container-low);
  color: var(--on-surface-variant);
  font-size: 11px;
  white-space: nowrap;
}

.form-action-buttons {
  display: flex;
  gap: 7px;
  justify-content: flex-end;
}

.report-form-stepper {
  margin-bottom: 2px;
  padding: 6px 8px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
}

.report-review-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.review-info-box {
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-low);
}

.review-info-box span {
  color: var(--on-surface-variant);
  font-size: 11px;
  font-weight: 700;
}

.review-info-box strong {
  color: var(--on-surface);
  font-size: 15px;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.review-info-box small {
  color: var(--on-surface-variant);
  font-size: 11px;
}

.review-info-box.accent {
  background: var(--brand-primary-container);
  border-color: color-mix(in oklab, var(--brand-primary), transparent 62%);
}

.review-info-box.accent strong {
  color: var(--brand-primary);
  font-family: var(--font-mono);
  font-size: 18px;
}

.report-management-table .data-table {
  min-width: 0;
}

.report-management-table .card-header {
  padding-top: 12px;
  padding-bottom: 10px;
}

.report-management-table .card-body {
  background: var(--surface-container-lowest);
}

.report-table-summary {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  padding: 10px 12px;
  border-top: 1px solid var(--outline-variant);
  border-bottom: 1px solid var(--outline-variant);
  background: var(--surface-container-low);
}

.report-table-summary span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  padding: 5px 10px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-full);
  background: var(--surface-container-lowest);
  color: var(--on-surface-variant);
  font-size: 12px;
  font-weight: 650;
  white-space: nowrap;
}

.report-table-summary .material-symbols-rounded {
  font-size: 16px;
  color: var(--brand-primary);
}

.report-table-wrap {
  border-radius: 0 0 var(--radius-md) var(--radius-md);
}

.report-list-table {
  width: 100%;
  min-width: 980px;
  table-layout: fixed;
}

.contract-report-table {
  min-width: 1060px;
}

.report-list-table th {
  height: 40px;
  background: var(--surface-container);
}

.report-list-table td {
  height: 60px;
  min-width: 0;
}

.report-list-table th,
.report-list-table td {
  overflow: hidden;
}

.report-list-table tbody tr:nth-child(even) td {
  background: color-mix(in oklab, var(--surface-container-lowest), var(--surface-container-low) 42%);
}

.report-list-table tbody tr:hover td {
  background: var(--brand-primary-container);
}

.report-main-cell,
.report-work-cell,
.report-route-cell {
  display: grid;
  gap: 3px;
  min-width: 0;
  line-height: 1.25;
}

.report-main-cell .code,
.report-work-cell .code {
  display: inline-flex;
  width: fit-content;
  max-width: 100%;
  padding: 2px 7px;
  border-radius: var(--radius-full);
  background: var(--surface-container-high);
  color: var(--brand-primary);
  overflow: hidden;
  text-overflow: ellipsis;
}

.report-main-cell strong,
.report-work-cell strong,
.report-route-cell strong {
  color: var(--on-surface);
  font-size: 12px;
  font-weight: 750;
  overflow: hidden;
  text-overflow: ellipsis;
}

.report-work-cell strong {
  display: -webkit-box;
  max-width: 100%;
  min-height: 30px;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  white-space: normal;
  line-height: 1.25;
}

.report-main-cell strong,
.report-route-cell strong {
  white-space: nowrap;
}

.report-main-cell small,
.report-route-cell small {
  color: var(--on-surface-variant);
  font-size: 11px;
  white-space: nowrap;
}

.report-route-cell span {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  width: fit-content;
  color: var(--on-surface-variant);
  font-size: 11px;
  white-space: nowrap;
}

.report-route-cell .material-symbols-rounded {
  font-size: 14px;
}

.report-detail-btn {
  min-width: 92px;
  justify-content: center;
}

.report-empty-state {
  display: grid;
  place-items: center;
  min-height: 96px;
  color: var(--on-surface-variant);
  font-size: 13px;
  font-weight: 650;
}

.report-workspace-header,
.report-create-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
  box-shadow: var(--elev-1);
}

.report-workspace-header h2,
.report-create-header h2 {
  margin: 0;
  color: var(--on-surface);
  font-size: 16px;
  line-height: 1.25;
}

.report-workspace-header p,
.report-create-header p {
  margin: 2px 0 0;
  color: var(--on-surface-variant);
  font-size: 12px;
}

.report-create-header {
  justify-content: flex-start;
}

.report-create-page-header {
  margin-bottom: 0;
}

.plan-form-footer {
  padding: 12px 24px 20px;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.plan-form-footer.between {
  justify-content: space-between;
}

.report-cost-tiles {
  flex-wrap: wrap;
}

.report-cost-tiles > div {
  flex: 1 1 150px;
  min-width: 0;
  padding: 12px;
  border-radius: var(--radius-md);
  background: var(--surface-container-low);
  display: grid;
  gap: 4px;
}

.report-cost-tiles span {
  color: var(--on-surface-variant);
  font-size: 12px;
  font-weight: 650;
}

.report-cost-tiles b {
  color: var(--on-surface);
  font-family: var(--font-mono);
  font-size: 15px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.report-cost-tiles .total {
  background: var(--brand-primary-container);
  color: var(--brand-on-primary-container);
}

.report-cost-tiles .total b {
  color: var(--brand-primary);
  font-size: 18px;
}

.report-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.report-actions.right {
  justify-content: flex-end;
}

.danger-text {
  color: var(--error) !important;
}

.report-resource-section {
  display: grid;
  gap: 8px;
  padding: 10px 0;
  border-top: 1px solid var(--outline-variant);
}

.report-resource-section:first-child {
  padding-top: 0;
  border-top: 0;
}

.resource-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.resource-section-head h4 {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  font-size: 14px;
}

.resource-section-head h4 .material-symbols-rounded {
  color: var(--brand-primary);
}

.compact-resource-table {
  width: 100%;
  max-width: 100%;
  max-height: 280px;
  overflow: auto;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
}

.compact-resource-table .data-table th,
.compact-resource-table .data-table td {
  padding: 7px 9px;
}

.table-input {
  min-height: 30px;
  height: 30px;
  width: 82px;
  padding: 4px 8px;
}

.table-input.wide {
  width: 120px;
}

@media (max-width: 1180px) {
  .report-step1-layout {
    grid-template-columns: 1fr;
  }

  .report-date-panel .work-range-topline {
    grid-template-columns: minmax(0, 1fr) minmax(190px, 260px);
  }
}

@media (max-width: 760px) {
  .report-primary-grid {
    grid-template-columns: 1fr;
  }

  .report-date-panel .work-range-topline {
    grid-template-columns: 1fr;
  }

  .resource-section-head {
    align-items: flex-start;
    flex-direction: column;
  }
}

.field-input:disabled {
  opacity: .52;
  background: var(--surface-container);
  cursor: not-allowed;
}

.report-extra-grid {
  margin-top: 8px;
  padding-top: 12px;
  border-top: 1px solid var(--outline-variant);
}

.detail-total-band {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  background: var(--brand-primary-container);
  color: var(--brand-on-primary-container);
}

.detail-total-band span {
  font-size: 12px;
  font-weight: 650;
}

.detail-total-band b {
  font-family: var(--font-mono);
  font-size: 22px;
}

.drawer-section-title {
  margin: 4px 0 -4px;
  font-size: 13px;
  color: var(--on-surface-variant);
}

.drawer-edit-row {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(92px, .5fr) auto;
  gap: 8px;
  align-items: center;
}

.drawer-edit-row.detail-4 {
  grid-template-columns: minmax(0, 1.4fr) 96px 86px auto;
}

.drawer-edit-row.detail-5 {
  grid-template-columns: minmax(0, 1.3fr) 110px 82px 82px 82px;
}

.settings-grid,
.crew-builder,
.crew-list {
  display: grid;
  gap: 12px;
}

.personnel-settings-page {
  gap: 14px;
}

.personnel-scope-card .card-body {
  padding-top: 0;
}

.personnel-scope-grid {
  display: grid;
  grid-template-columns: minmax(160px, .75fr) minmax(190px, .9fr) minmax(240px, 1.25fr);
  gap: 10px;
  align-items: end;
}

.personnel-scope-grid label {
  display: grid;
  gap: 4px;
}

.personnel-scope-grid label span {
  color: var(--on-surface-variant);
  font-size: 11px;
  font-weight: 650;
}

.settings-search {
  width: 100%;
  max-width: none;
  border-radius: var(--radius-md);
  padding: 7px 10px;
}

.personnel-command-card {
  display: grid;
  grid-template-columns: minmax(260px, .9fr) minmax(0, 1.35fr);
  gap: 12px;
  align-items: stretch;
  padding: 12px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, var(--surface-container-lowest), var(--surface-container-low));
  box-shadow: var(--elev-1);
}

.personnel-command-copy {
  display: grid;
  align-content: center;
  justify-items: start;
  gap: 5px;
  min-width: 0;
}

.personnel-command-copy h2 {
  margin: 0;
  color: var(--on-surface);
  font-size: 19px;
  line-height: 1.25;
}

.personnel-command-copy p {
  margin: 0;
  max-width: 560px;
  color: var(--on-surface-variant);
  font-size: 12px;
  line-height: 1.5;
}

.personnel-overview-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.personnel-stat {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  grid-template-areas:
    "icon label"
    "icon value";
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-lowest);
}

.personnel-stat .material-symbols-rounded {
  grid-area: icon;
  align-self: center;
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-full);
  background: var(--brand-primary-container);
  color: var(--brand-primary);
  font-size: 19px;
}

.personnel-stat span {
  grid-area: label;
  color: var(--on-surface-variant);
  font-size: 12px;
  font-weight: 650;
  white-space: nowrap;
}

.personnel-stat b {
  grid-area: value;
  font-family: var(--font-mono);
  font-size: 21px;
  line-height: 1;
  color: var(--brand-primary);
}

.personnel-table-wrap {
  max-height: 430px;
  overflow: auto;
}

.personnel-editor-layout {
  display: grid;
  grid-template-columns: minmax(320px, 400px) minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.personnel-form-panel,
.personnel-list-panel {
  min-width: 0;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-low);
  padding: 12px;
}

.personnel-list-panel {
  background: var(--surface-container-lowest);
}

.personnel-form-panel,
.crew-form-panel {
  position: sticky;
  top: 76px;
}

.panel-kicker {
  font-size: 12px;
  font-weight: 750;
  color: var(--brand-primary);
  margin-bottom: 10px;
}

.panel-title-row,
.list-panel-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 10px;
}

.panel-title-row .panel-kicker,
.list-panel-head .panel-kicker {
  margin-bottom: 2px;
}

.panel-title-row p,
.list-panel-head p {
  margin: 0;
  color: var(--on-surface-variant);
  font-size: 11px;
  line-height: 1.45;
}

.personnel-list-search {
  width: min(260px, 100%);
  flex: 0 1 260px;
  padding-block: 5px;
}

.panel-title-row > .material-symbols-rounded {
  flex: 0 0 auto;
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-full);
  background: var(--brand-secondary-container);
  color: var(--brand-on-secondary-container);
  font-size: 19px;
}

.settings-form-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
  padding-top: 2px;
}

.personnel-table {
  min-width: 980px;
}

.personnel-table th {
  background: var(--surface-container);
}

.person-cell {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  gap: 9px;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  text-align: left;
  cursor: pointer;
}

.person-cell > span {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-full);
  background: var(--surface-container-high);
  color: var(--brand-primary);
  font-size: 12px;
  font-weight: 800;
}

.person-cell div {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.person-cell b,
.person-cell small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.person-cell small {
  color: var(--on-surface-variant);
  font-size: 10px;
}

.table-action-cluster {
  display: inline-flex;
  justify-content: flex-end;
  align-items: center;
  gap: 2px;
  padding: 2px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-full);
  background: var(--surface-container-low);
}

.table-action-cluster .icon-btn {
  width: 30px;
  height: 30px;
}

.table-action-cluster .icon-btn .material-symbols-rounded {
  font-size: 17px;
}

.settings-empty-state {
  display: grid;
  place-items: center;
  min-height: 86px;
  color: var(--on-surface-variant);
  font-size: 12px;
  font-weight: 650;
}

.crew-builder {
  grid-template-columns: minmax(220px, 300px) minmax(0, 1fr) auto;
  align-items: start;
}

.crew-editor-layout {
  display: grid;
  grid-template-columns: minmax(320px, 400px) minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.crew-form-panel,
.crew-list-panel {
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-low);
}

.crew-list-panel {
  background: var(--surface-container-lowest);
}

.stack-label {
  display: grid;
  gap: 4px;
}

.stack-label span {
  color: var(--on-surface-variant);
  font-size: 11px;
  font-weight: 650;
}

.crew-member-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin: 10px 0 8px;
}

.crew-member-toolbar span {
  color: var(--on-surface-variant);
  font-size: 12px;
  font-weight: 700;
  margin-right: auto;
}

.crew-search {
  margin-bottom: 8px;
}

.selected-member-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  max-height: 76px;
  overflow: auto;
  padding: 8px;
  margin-bottom: 8px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-sm);
  background: var(--surface-container-lowest);
}

.selected-member-strip .chip {
  cursor: pointer;
}

.crew-member-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 6px;
  max-height: 230px;
  overflow: auto;
  padding: 2px;
}

.crew-member-list button {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  grid-template-areas:
    "icon name"
    "icon role";
  border: 1px solid var(--outline-variant);
  background: var(--surface-container-lowest);
  border-radius: var(--radius-sm);
  padding: 7px 9px;
  gap: 7px;
  color: var(--on-surface);
  font-size: 12px;
  text-align: left;
  cursor: pointer;
}

.crew-member-list button.active {
  background: var(--brand-primary-container);
  color: var(--brand-on-primary-container);
  border-color: transparent;
}

.crew-member-list .material-symbols-rounded {
  grid-area: icon;
  align-self: center;
  font-size: 18px;
}

.crew-member-list span {
  grid-area: name;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 700;
}

.crew-member-list small {
  grid-area: role;
  color: var(--on-surface-variant);
  font-size: 10px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.crew-card {
  display: grid;
  grid-template-columns: minmax(180px, .7fr) minmax(240px, 1fr) auto;
  align-items: start;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-md);
  background: var(--surface-container-low);
}

.crew-card {
  min-width: 0;
}

.crew-card > div:first-child {
  display: grid;
  gap: 2px;
}

.crew-card > div:first-child span {
  color: var(--on-surface-variant);
  font-size: 11px;
}

.crew-card-members {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-width: min(100%, 280px);
}

.crew-card-members .chip {
  cursor: pointer;
}

.crew-card-actions {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
}

.summary-tight-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width: 1100px) {
  .report-step-grid {
    grid-template-columns: 1fr;
  }
  .compact-submit-panel {
    grid-template-columns: 1fr 1fr;
  }
  .report-review-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .compact-submit-actions {
    grid-column: span 2;
  }
  .form-action-footer {
    grid-template-columns: 1fr;
  }
  .form-action-buttons {
    justify-content: stretch;
  }
  .form-action-buttons .btn {
    flex: 1;
  }
  .crew-builder {
    grid-template-columns: 1fr;
  }
  .personnel-command-card {
    grid-template-columns: 1fr;
  }
  .personnel-overview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .report-command-strip,
  .crew-pick-panel,
  .personnel-editor-layout,
  .crew-editor-layout {
    grid-template-columns: 1fr;
  }
  .personnel-form-panel,
  .crew-form-panel {
    position: static;
  }
  .personnel-scope-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .crew-card {
    grid-template-columns: minmax(0, 1fr);
  }
  .crew-card-actions {
    justify-content: flex-start;
  }
}

@media (max-width: 720px) {
  .report-table-summary {
    gap: 6px;
    padding: 8px;
  }
  .report-table-summary span {
    min-height: 26px;
    padding: 4px 8px;
    font-size: 11px;
  }
  .report-list-table {
    min-width: 860px;
  }
  .contract-report-table {
    min-width: 920px;
  }
  .report-list-table th,
  .report-list-table td {
    padding: 6px 7px;
  }
  .report-main-cell .code,
  .report-work-cell .code {
    padding-inline: 5px;
  }
  .report-detail-btn {
    width: 34px;
    min-width: 34px;
    padding-inline: 0;
    font-size: 0;
    gap: 0;
  }
  .report-detail-btn .material-symbols-rounded {
    font-size: 18px;
  }
  .compact-form-grid {
    grid-template-columns: 1fr;
  }
  .compact-form-grid .wide-field {
    grid-column: auto;
  }
  .resource-section-head,
  .crew-card {
    align-items: stretch;
    flex-direction: column;
  }
  .report-actions,
  .report-actions.right {
    justify-content: stretch;
  }
  .report-actions .btn {
    flex: 1 1 180px;
  }
  .report-workspace-header,
  .report-create-header {
    align-items: stretch;
    flex-direction: column;
  }
  .report-workspace-header .btn,
  .report-create-header .btn,
  .plan-form-footer .btn {
    width: 100%;
  }
  .report-control-row {
    align-items: stretch;
    flex-direction: column;
  }
  .report-management-head,
  .report-head-actions {
    align-items: stretch;
    flex-direction: column;
  }
  .report-control-row > .btn,
  .report-head-actions > .btn,
  .report-control-row .plan-section-tabs,
  .report-control-row .plan-subview-toggle,
  .report-head-actions .plan-subview-toggle {
    width: 100%;
  }
  .report-control-row .plan-section-tabs,
  .report-control-row .plan-subview-toggle,
  .report-head-actions .plan-subview-toggle {
    overflow-x: auto;
  }
  .plan-form-footer,
  .plan-form-footer.between {
    padding: 10px 12px 14px;
    justify-content: stretch;
    flex-direction: column;
  }
  .work-result-tabs {
    top: 60px;
  }
  .drawer-edit-row,
  .drawer-edit-row.detail-4,
  .drawer-edit-row.detail-5,
  .personnel-scope-grid,
  .personnel-overview-grid {
    grid-template-columns: 1fr;
  }
  .personnel-command-card {
    padding: 10px;
  }
  .personnel-command-copy h2 {
    font-size: 17px;
  }
  .personnel-stat {
    grid-template-columns: auto minmax(0, 1fr) auto;
    grid-template-areas: "icon label value";
  }
  .personnel-stat b {
    align-self: center;
  }
  .crew-member-toolbar {
    align-items: stretch;
  }
  .crew-member-toolbar .btn {
    flex: 1;
  }
  .selected-member-strip {
    max-height: 92px;
  }
  .report-command-strip {
    gap: 8px;
  }
  .report-review-grid {
    grid-template-columns: 1fr;
  }
  .compact-submit-panel,
  .compact-cost-grid,
  .compact-submit-actions,
  .form-action-buttons {
    grid-template-columns: 1fr;
  }
  .compact-submit-actions {
    grid-column: auto;
  }
}

/* ===== Misc ===== */
.row { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.col { display: flex; flex-direction: column; gap: 12px; min-width: 0; }
.gap-8 { gap: 8px; }
.gap-12 { gap: 12px; }
.gap-16 { gap: 12px; }
.gap-24 { gap: 16px; }
.grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; min-width: 0; }
.grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; min-width: 0; }
@media (max-width: 900px) {
  .grid-2, .grid-3 { grid-template-columns: 1fr; }
}
.muted { color: var(--on-surface-variant); }
.bold { font-weight: 600; }
.mono { font-family: var(--font-mono); }
.tnum { font-variant-numeric: tabular-nums; }
.tag-money { font-family: var(--font-mono); font-weight: 600; color: var(--on-surface); }

.dl { display: grid; grid-template-columns: 140px 1fr; gap: 8px 16px; font-size: 13px; }
.dl dt { color: var(--on-surface-variant); }
.dl dd { margin: 0; color: var(--on-surface); font-weight: 500; }

/* Scrollbar */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--outline-variant); border-radius: var(--radius-full); }
::-webkit-scrollbar-thumb:hover { background: var(--outline); }

/* Material Symbols sizing helpers */
.material-symbols-rounded {
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  user-select: none;
}
.material-symbols-rounded.filled { font-variation-settings: 'FILL' 1; }

/* ===== Density pass: operational screens should prioritize working area ===== */
:root {
  --topbar-height: 56px;
}

.topbar {
  gap: 10px;
  padding: 0 16px;
}

.topbar-brand .sidebar-brand-mark {
  width: 32px;
  height: 32px;
}

.topbar-search {
  padding: 6px 12px;
  width: 280px;
}

.top-nav-trigger {
  height: 34px;
  padding: 0 9px 0 11px;
}

.main {
  padding: 12px 16px 32px;
}

.page-header {
  align-items: center;
  margin-bottom: 8px;
  gap: 8px;
}

.page-title {
  font-size: 20px;
  margin-bottom: 0;
}

.page-subtitle {
  font-size: 12px;
}

.plan-section-tabs {
  border-radius: var(--radius-md);
  padding: 3px;
  margin-bottom: -4px;
}

.plan-section-tabs button {
  min-height: 30px;
  padding: 5px 10px;
  border-radius: var(--radius-sm);
}

.card {
  border-radius: var(--radius-md);
  min-width: 0;
}

.card-header {
  padding: 10px 12px 6px;
  gap: 8px;
}

.card-title {
  font-size: 14px;
}

.card-subtitle {
  font-size: 11px;
  margin-top: 0;
}

.card-body {
  padding: 8px 12px 10px;
  min-width: 0;
}

.compact-form-grid {
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
  gap: 7px;
}

.compact-form-grid label {
  gap: 3px;
}

.compact-form-grid label span,
.personnel-scope-grid label span,
.stack-label span {
  font-size: 10px;
}

.field-input,
.field-select,
.field-textarea {
  padding: 6px 9px;
  font-size: 12px;
}

.btn {
  min-height: 34px;
  padding: 7px 12px;
  font-size: 12px;
}

.btn-sm {
  min-height: 28px;
  padding: 4px 9px;
}

.report-step-grid {
  grid-template-columns: minmax(0, 1fr);
  gap: 10px;
  align-items: start;
}

.report-cost-summary .card-body {
  gap: 6px;
}

.mini-total-row,
.report-grand-total,
.readiness-meter {
  padding: 7px 9px;
}

.report-grand-total strong {
  font-size: 18px;
}

.readiness-list {
  gap: 3px;
}

.crew-pick-panel {
  grid-template-columns: minmax(150px, .35fr) minmax(0, 1fr);
  padding: 9px;
  margin-top: 10px;
  gap: 9px;
}

.crew-selected-summary,
.selected-member-strip {
  padding: 6px;
  max-height: 58px;
}

.report-resource-section {
  padding: 7px 0;
}

.resource-section-head h4 {
  font-size: 13px;
}

.compact-resource-table {
  max-height: 220px;
}

.compact-resource-table .data-table th,
.compact-resource-table .data-table td,
.data-table th,
.data-table td {
  padding: 6px 8px;
}

.data-table {
  font-size: 11px;
}

.data-table td {
  vertical-align: middle;
}

.table-input {
  min-height: 28px;
  height: 28px;
}

.settings-grid {
  gap: 10px;
}

.personnel-overview-grid {
  gap: 8px;
}

.personnel-stat {
  padding: 8px 10px;
}

.personnel-stat b {
  font-size: 18px;
}

.personnel-editor-layout,
.crew-editor-layout {
  gap: 10px;
}

.personnel-form-panel,
.personnel-list-panel,
.crew-form-panel,
.crew-list-panel {
  padding: 10px;
}

.panel-kicker {
  margin-bottom: 7px;
}

.crew-member-list {
  max-height: 200px;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

.crew-member-list button,
.crew-card {
  padding: 6px 8px;
}

.personnel-table-wrap {
  max-height: 380px;
}

@media (max-width: 900px) {
  .main {
    padding: 10px 10px 28px;
  }
  .report-cost-summary,
  .compact-submit-panel {
    position: static;
  }
  .personnel-command-card,
  .personnel-editor-layout,
  .crew-editor-layout,
  .crew-card {
    grid-template-columns: 1fr;
  }
  .personnel-form-panel,
  .crew-form-panel {
    position: static;
  }
  .personnel-overview-grid,
  .personnel-scope-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .crew-card-actions {
    justify-content: flex-start;
  }
}

@media (max-width: 640px) {
  .personnel-overview-grid,
  .personnel-scope-grid {
    grid-template-columns: 1fr;
  }
  .personnel-command-card {
    padding: 10px;
  }
  .personnel-command-copy h2 {
    font-size: 17px;
  }
  .personnel-stat {
    grid-template-columns: auto minmax(0, 1fr) auto;
    grid-template-areas: "icon label value";
  }
  .list-panel-head,
  .panel-title-row {
    flex-direction: column;
  }
  .personnel-list-search,
  .settings-form-actions .btn,
  .crew-member-toolbar .btn {
    width: 100%;
  }
  .settings-form-actions {
    justify-content: stretch;
  }
}
