:root {
  color-scheme: light;
  --bg: #d2d7d4;
  --panel: #fffefa;
  --ink: #20251f;
  --muted: #657069;
  --line: #ccd5ce;
  --soft: #f6f8f4;
  --accent: #1e5f4d;
  --accent-dark: #17483c;
  --accent-soft: #edf6ef;
  --sky: #dbeafe;
  --sun: #f9d36b;
  --danger: #a53617;
  --hm-red: #c83232;
  --hm-red-dark: #982426;
  --hm-red-soft: #fff0f0;
  --graphite: #1f2329;
  --graphite-2: #2a2f37;
  --graphite-3: #3b424d;
  --shadow: 0 14px 36px rgba(41, 38, 32, 0.12);
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

body {
  margin: 0;
  background:
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.18) 0 1px, transparent 1px 7px),
    linear-gradient(180deg, #eef1ee 0, #d1d8d3 330px),
    var(--bg);
  color: var(--ink);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 14px;
}

body.bossModeActive {
  background:
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.035) 0 1px, transparent 1px 8px),
    radial-gradient(circle at 82% -10%, rgba(200, 50, 50, 0.24), transparent 30%),
    linear-gradient(180deg, #2a2d32 0, #17191d 340px, #101114 100%);
  color: #f5f7fb;
}

body.bossModeActive .brand h1 {
  color: #f7f9fc;
}

body.bossModeActive #statusText {
  color: #aeb5c0;
}

body.bossModeActive .brandIcon {
  box-shadow: 0 10px 24px rgba(200, 50, 50, 0.2);
}

body.bossModeActive .pageTabs,
body.bossModeActive .officeAccessButton {
  background: rgba(34, 37, 42, 0.92);
  border-color: #3a3f48;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.24);
}

body.bossModeActive .pageTabs button,
body.bossModeActive .officeAccessButton {
  color: #e6eaf0;
}

body.bossModeActive .pageTabs button:not(.active) {
  background: #2a2e36;
  border-color: #424853;
  color: #dce2eb;
}

body.bossModeActive .pageTabs button:not(.active):hover,
body.bossModeActive .pageTabs button:not(.active):focus-visible {
  background: #343944;
  border-color: #555d6a;
}

body.bossModeActive .tabButton.active,
body.bossModeActive .officeAccessButton.active {
  background: #c83232;
  border-color: #e05252;
  color: #fff;
}

body.bossModeActive #poTab {
  display: none;
}

body.bossModeActive .pageTabs {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

button,
input,
select {
  font: inherit;
}

button,
.photoButton {
  -webkit-tap-highlight-color: transparent;
}

.shell {
  margin: 0 auto;
  max-width: 1480px;
  min-height: 100vh;
  padding: 10px;
}

body.appLocked {
  overflow: hidden;
}

body.appLocked .shell {
  display: none;
}

.appLoginScreen {
  align-items: center;
  background:
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.035) 0 1px, transparent 1px 8px),
    radial-gradient(circle at 50% -6%, rgba(200, 50, 50, 0.28), transparent 34%),
    linear-gradient(180deg, #30343b 0%, #1b1e23 54%, #111316 100%);
  display: grid;
  min-height: 100vh;
  padding: 24px;
}

body:not(.appLocked) .appLoginScreen {
  display: none;
}

.appLoginCard {
  background:
    linear-gradient(180deg, rgba(45, 50, 58, 0.98) 0%, rgba(28, 31, 36, 0.98) 100%);
  border: 1px solid #454c57;
  border-radius: 14px;
  box-shadow:
    inset 0 4px 0 var(--hm-red),
    0 32px 90px rgba(0, 0, 0, 0.38);
  display: grid;
  gap: 12px;
  justify-self: center;
  max-width: 430px;
  padding: 30px;
  width: min(100%, 430px);
}

.appLoginLogo {
  background: #f7f9fc;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: 10px;
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.22);
  display: block;
  justify-self: center;
  max-height: 132px;
  max-width: 230px;
  object-fit: contain;
  padding: 8px;
  width: 70%;
}

.appLoginCard h1 {
  color: #f7f9fc;
  font-size: 34px;
  font-weight: 950;
  line-height: 1;
  text-align: center;
}

.appLoginCard p {
  color: #b8c0ca;
  font-weight: 700;
  line-height: 1.45;
  text-align: center;
}

.appLoginCard label {
  color: #d7dde5;
  font-size: 12px;
  font-weight: 900;
  margin-top: 4px;
  text-transform: uppercase;
}

.appLoginCard input {
  background:
    linear-gradient(180deg, #f8fafc 0, #eef2f4 100%);
  border: 1px solid #606a77;
  border-radius: 8px;
  color: #14171b;
  font-size: 17px;
  min-height: 48px;
  padding: 0 12px;
  width: 100%;
}

.passwordField {
  display: grid;
  position: relative;
}

.passwordField input {
  padding-right: 54px;
}

.passwordToggle {
  align-items: center;
  background: transparent;
  border: 0;
  border-radius: 8px;
  color: var(--hm-red-dark);
  display: inline-flex;
  font-size: 20px;
  height: 42px;
  justify-content: center;
  min-height: 0;
  min-width: 42px;
  padding: 0;
  position: absolute;
  right: 4px;
  top: 3px;
  width: 42px;
}

.appLoginCard button {
  background:
    linear-gradient(180deg, #dc4545 0%, #b62b1e 100%);
  border-color: #e05252;
  box-shadow: 0 12px 24px rgba(200, 50, 50, 0.24);
  color: #fff;
  font-size: 16px;
  font-weight: 900;
  min-height: 50px;
  width: 100%;
}

.appLoginCard .passwordToggle {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
  color: var(--hm-red-dark);
  font-size: 20px;
  font-weight: 900;
  height: 42px;
  min-height: 0;
  min-width: 42px;
  width: 42px;
}

.appLoginMessage {
  min-height: 20px;
}

.appHeader {
  align-items: center;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  margin-bottom: 10px;
}

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

.brandIcon {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.03)),
    #161a20;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 13px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 12px 26px rgba(0, 0, 0, 0.24);
  height: 48px;
  object-fit: contain;
  padding: 0;
  width: 48px;
}

.pageTabs {
  background: rgba(255, 253, 249, 0.82);
  border: 1px solid var(--line);
  border-radius: 10px;
  box-shadow: 0 8px 20px rgba(41, 38, 32, 0.08);
  display: flex;
  gap: 4px;
  padding: 4px;
}

.headerActions {
  align-items: center;
  display: flex;
  gap: 8px;
}

.installAppButton {
  background:
    linear-gradient(180deg, #f9fbff 0, #e8eef7 100%);
  border-color: #b8c4d5;
  border-radius: 8px;
  color: #26303d;
  font-size: 13px;
  font-weight: 900;
  min-height: 36px;
  min-width: 82px;
  padding: 0 12px;
  white-space: nowrap;
}

.pageTabs button {
  border-color: transparent;
  border-radius: 7px;
  min-width: 86px;
  white-space: nowrap;
}

.tabButton.active {
  background:
    linear-gradient(180deg, #2b3038 0%, var(--graphite) 100%);
  border-color: var(--graphite);
  box-shadow:
    inset 0 -3px 0 var(--hm-red),
    0 8px 18px rgba(31, 35, 41, 0.12);
  color: #fff;
}

.officeAccessButton {
  background: #f8fbf9;
  border-color: var(--line);
  color: var(--accent-dark);
  min-width: 72px;
}

.officeAccessButton.active {
  background:
    linear-gradient(180deg, #2b3038 0%, var(--graphite) 100%);
  border-color: var(--graphite);
  box-shadow: inset 0 -3px 0 var(--hm-red);
  color: #fff;
}

.quickAddButton {
  background: #fff4cc;
  border-color: var(--sun);
}

.weekNavButton,
.weekPickerButton {
  border-radius: 8px;
  font-size: 15px;
  height: 36px;
  min-width: 34px;
  padding: 0 10px;
}

.weekNavButton {
  font-weight: 900;
}

.weekPickerButton {
  background: #f6f8f7;
  min-width: 58px;
}

.sheetActions {
  align-items: center;
  display: flex;
  gap: 8px;
}

.pageView {
  display: none;
}

.pageView.active {
  display: block;
}

.hiddenUploadInputs {
  height: 0;
  overflow: hidden;
  position: absolute;
  width: 0;
}

.hiddenUploadInputs input {
  height: 0;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  width: 0;
}

h1,
h2,
p {
  margin: 0;
}

h1 {
  font-size: 23px;
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.1;
}

h2 {
  font-size: 18px;
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.2;
}

#statusText,
#weeklyRange {
  color: var(--muted);
  margin-top: 3px;
}

.photoButton {
  align-items: center;
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: 8px;
  cursor: pointer;
  display: inline-flex;
  font-weight: 800;
  justify-content: center;
  min-height: 52px;
  padding: 0 18px;
  text-align: center;
}

.primaryPhoto {
  background: var(--accent);
  border-color: var(--accent-dark);
  box-shadow: 0 16px 36px rgba(20, 35, 28, 0.24);
  color: #fff;
  flex-direction: column;
  font-size: 20px;
  gap: 8px;
  min-height: 126px;
  padding: 16px 22px;
  width: 220px;
}

.primaryPhoto::before {
  content: "📷";
  font-size: 52px;
  line-height: 1;
}

.primaryPhoto span {
  font-size: 0;
}

.primaryPhoto span::after {
  content: "Scan Sheet";
  font-size: 20px;
  line-height: 1.1;
}

.secondaryPhoto {
  background: rgba(255, 255, 255, 0.13);
  color: #fff;
}

.hiddenPhotoAction {
  display: none;
}

.photoButton input {
  display: none;
}

.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 8px 20px rgba(41, 38, 32, 0.045);
}

.workspace {
  align-items: stretch;
  display: grid;
  gap: 8px;
  grid-template-columns: 218px minmax(0, 1fr);
  margin-bottom: 8px;
}

.side {
  align-self: start;
  padding: 10px;
}

.field {
  display: grid;
  gap: 6px;
  margin-bottom: 10px;
  position: relative;
}

.hint {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

label {
  color: var(--muted);
  font-size: 12px;
  font-weight: 750;
  text-transform: uppercase;
}

input,
select {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 250, 249, 0.98));
  border: 1px solid #c5cfca;
  border-radius: 6px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.78),
    0 1px 0 rgba(31, 35, 41, 0.02);
  color: var(--ink);
  height: 36px;
  min-width: 0;
  padding: 0 10px;
  transition:
    background-color 140ms ease,
    border-color 140ms ease,
    box-shadow 140ms ease;
}

select {
  appearance: none;
  background:
    linear-gradient(45deg, transparent 50%, var(--graphite-2) 50%) calc(100% - 18px) 15px / 6px 6px no-repeat,
    linear-gradient(135deg, var(--graphite-2) 50%, transparent 50%) calc(100% - 13px) 15px / 6px 6px no-repeat,
    linear-gradient(180deg, #ffffff 0%, #f8faf9 100%);
  cursor: pointer;
  padding-right: 34px;
}

select option {
  background: #fffefa;
  color: var(--ink);
  font-weight: 750;
}

input:focus,
select:focus,
button:focus-visible,
.photoButton:focus-within {
  border-color: var(--hm-red);
  outline: 3px solid rgba(200, 50, 50, 0.16);
  outline-offset: 1px;
}

input:hover,
select:hover {
  border-color: #aeb9b3;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.86),
    0 0 0 3px rgba(31, 35, 41, 0.035);
}

input:focus,
select:focus {
  background:
    linear-gradient(180deg, #ffffff 0%, #fbfcfb 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.9),
    0 0 0 4px rgba(200, 50, 50, 0.08);
}

button {
  align-items: center;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 7px;
  color: var(--ink);
  cursor: pointer;
  display: inline-flex;
  font-weight: 700;
  height: 36px;
  justify-content: center;
  min-width: 88px;
  padding: 0 12px;
  transition:
    background-color 140ms ease,
    border-color 140ms ease,
    box-shadow 140ms ease,
    color 140ms ease,
    transform 100ms ease;
}

button:disabled {
  color: #9aa39d;
  cursor: default;
}

button:not(:disabled):hover {
  background: #fbfcfb;
  border-color: #adb9b3;
  box-shadow: 0 5px 14px rgba(31, 35, 41, 0.08);
}

button:not(:disabled):active {
  transform: translateY(1px);
}

.jobList {
  display: grid;
  gap: 6px;
}

.jobSetupItem {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.78), rgba(246, 248, 244, 0.95));
  border: 1px solid var(--line);
  border-radius: 7px;
  display: grid;
  gap: 2px;
  height: auto;
  justify-content: stretch;
  min-height: 44px;
  padding: 6px 8px;
  text-align: left;
  width: 100%;
}

.jobSetupItem span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.jobSetupItem input {
  background: transparent;
  border: 0;
  font-size: 14px;
  font-weight: 800;
  height: 22px;
  padding: 0;
}

.jobSetupItem input:focus {
  outline: none;
}

.draftJobItem {
  background:
    repeating-linear-gradient(135deg, rgba(30, 95, 77, 0.045) 0 1px, transparent 1px 8px),
    #fbfcfb;
  border-style: dashed;
}

.draftJobItem input::placeholder {
  color: #6f7e76;
  font-weight: 850;
}

.jobSetupItem:hover,
.jobSetupItem:focus-within {
  background: #eef5f1;
}

.addJobButton {
  width: 100%;
}

.smallEmpty {
  background: var(--soft);
  border: 1px dashed var(--line);
  border-radius: 6px;
  padding: 10px;
  text-align: center;
}

.emptyJobList {
  background: #fbfcfb;
  border: 1px dashed var(--line);
  border-radius: 8px;
  color: var(--muted);
  display: grid;
  gap: 4px;
  padding: 14px 12px;
}

.emptyJobList strong {
  color: var(--accent-dark);
}

.emptyJobList span {
  font-size: 12px;
  font-weight: 700;
  line-height: 1.35;
}

.totals {
  border-top: 1px solid var(--line);
  display: grid;
  gap: 6px;
  padding-top: 10px;
}

.totals div {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

.totals span,
.empty {
  color: var(--muted);
}

.recentScansPanel {
  background:
    radial-gradient(circle at 18% 0, rgba(96, 150, 205, 0.16), transparent 36%),
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.026) 0 1px, transparent 1px 9px),
    linear-gradient(180deg, rgba(38, 48, 60, 0.62), rgba(25, 31, 39, 0.42));
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 14px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 14px 28px rgba(0, 0, 0, 0.12);
  display: grid;
  gap: 9px;
  grid-template-rows: auto minmax(0, 1fr);
  margin-top: 10px;
  min-height: 248px;
  padding: 10px;
}

.recentScansHeader {
  align-items: start;
  display: flex;
  gap: 8px;
  flex-direction: column;
  justify-content: start;
}

.recentScansHeader strong {
  color: #f5f8fc;
  font-size: 22px;
  font-weight: 950;
  letter-spacing: 0;
  line-height: 1;
}

.recentScansHeader .moduleEyebrow {
  color: rgba(218, 228, 240, 0.68);
  font-size: 10px;
  letter-spacing: 0.08em;
}

.recentScansList {
  align-content: start;
  display: grid;
  gap: 8px;
  grid-template-rows: minmax(0, 1fr);
  min-height: 0;
}

.recentScanCard {
  --recent-scan-accent: #c83232;
  --recent-scan-top: #343a44;
  --recent-scan-bottom: #1f252d;
  background:
    radial-gradient(circle at 88% 10%, color-mix(in srgb, var(--recent-scan-accent) 24%, transparent), transparent 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.025)),
    linear-gradient(145deg, var(--recent-scan-top), var(--recent-scan-bottom));
  border: 1px solid color-mix(in srgb, var(--recent-scan-accent) 34%, rgba(255, 255, 255, 0.12));
  border-radius: 12px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    inset 3px 0 0 color-mix(in srgb, var(--recent-scan-accent) 70%, transparent);
  display: grid;
  gap: 7px;
  overflow: hidden;
  padding: 8px;
}

.recentScanCard.company-alfa {
  --recent-scan-accent: #168a46;
  --recent-scan-top: #293c33;
  --recent-scan-bottom: #17241e;
}

.recentScanCard.company-sec {
  --recent-scan-accent: #2369d1;
  --recent-scan-top: #27374f;
  --recent-scan-bottom: #172235;
}

.recentScanOpen {
  align-items: center;
  background: transparent;
  border: 0;
  color: inherit;
  cursor: pointer;
  display: grid;
  gap: 8px;
  grid-template-columns: 36px minmax(0, 1fr);
  min-width: 0;
  padding: 0;
  text-align: left;
}

.recentScanThumb {
  background:
    radial-gradient(circle at 72% 14%, rgba(255, 255, 255, 0.24), transparent 34%),
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.055) 0 1px, rgba(0, 0, 0, 0.05) 1px 3px),
    linear-gradient(145deg, color-mix(in srgb, var(--recent-scan-accent) 82%, #ffffff 8%), color-mix(in srgb, var(--recent-scan-accent) 66%, #101114));
  border: 1px solid color-mix(in srgb, var(--recent-scan-accent) 54%, rgba(255, 255, 255, 0.18));
  border-radius: 9px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    0 8px 16px color-mix(in srgb, var(--recent-scan-accent) 20%, transparent);
  height: 42px;
  width: 36px;
}

.recentScanText {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.recentScanText strong {
  color: #f6f9fd;
  font-size: 13px;
  font-weight: 950;
  line-height: 1.1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.recentScanText em,
.recentScanCard small,
.recentScansEmpty em {
  color: rgba(226, 234, 244, 0.68);
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
  line-height: 1.25;
}

.recentScanActions {
  display: grid;
  gap: 5px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.recentScanActions button {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  color: rgba(240, 246, 252, 0.78);
  cursor: pointer;
  font-size: 10px;
  font-weight: 900;
  min-height: 25px;
  padding: 0 6px;
}

.recentScanOpen:hover .recentScanText strong,
.recentScanOpen:focus-visible .recentScanText strong,
.recentScanActions button:hover,
.recentScanActions button:focus-visible {
  color: #fff;
}

.recentScanActions button:hover,
.recentScanActions button:focus-visible {
  border-color: color-mix(in srgb, var(--recent-scan-accent) 46%, rgba(255, 255, 255, 0.18));
  outline: none;
}

.recentScansEmpty {
  align-content: center;
  align-self: stretch;
  border: 1px dashed rgba(180, 197, 216, 0.34);
  border-radius: 12px;
  color: rgba(235, 241, 248, 0.76);
  display: grid;
  gap: 5px;
  height: 100%;
  justify-items: center;
  min-height: 100%;
  padding: 16px 12px;
  text-align: center;
}

.recentScansEmpty span {
  color: rgba(134, 169, 206, 0.72);
  font-size: 24px;
}

.recentScansEmpty strong {
  color: #f4f8fc;
  font-size: 13px;
  font-weight: 950;
}

.review {
  --scan-border: #c9d8cf;
  --scan-check: #f7fbf8;
  --scan-grid: #d6e1da;
  --scan-head: #e8f2eb;
  --scan-hover: #edf7f1;
  --scan-row: #fff;
  --scan-row-alt: #f8fbf8;
  --scan-shell: #fbfdfb;
  display: flex;
  flex-direction: column;
  min-height: 494px;
  min-width: 0;
  position: relative;
}

#scanPage[data-company="alfa"] .review {
  --scan-border: #b9dac5;
  --scan-check: #f4fbf6;
  --scan-grid: #cfe5d6;
  --scan-head: #e0f2e6;
  --scan-hover: #e2f5e9;
}

#scanPage[data-company="hm"] .review {
  --scan-border: #decac6;
  --scan-check: #fbf8f6;
  --scan-grid: #e5d7d3;
  --scan-head: #f1e4e1;
  --scan-hover: #f6ece9;
}

#scanPage[data-company="sec"] .review {
  --scan-border: #c2d6ea;
  --scan-check: #f6f9fc;
  --scan-grid: #d2e0ee;
  --scan-head: #e6eef7;
  --scan-hover: #edf4fb;
}

#scanPage .review {
  border-color: var(--scan-border);
}

#scanPage .review .tableHeader,
#scanPage .review .scanDayBanner,
#scanPage .review .reviewActions {
  background: var(--scan-shell);
}

.tableHeader,
.sheetHeader {
  align-items: center;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 10px;
  justify-content: space-between;
  min-height: 38px;
  padding: 0 10px;
}

.tableHeader {
  font-weight: 800;
}

.scanStatusHeader {
  display: grid;
  gap: 6px;
  grid-template-columns: minmax(0, 1fr) auto;
  min-height: 28px;
  padding: 3px 9px;
}

.scanStatusHeader[hidden] {
  display: none;
}

#rowCount {
  background: #fff;
  border: 1px solid var(--scan-grid);
  border-radius: 999px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  padding: 3px 8px;
  white-space: nowrap;
}

.scanPager {
  align-items: center;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 999px;
  display: flex;
  gap: 4px;
  padding: 1px;
}

.scanPager button {
  border-radius: 999px;
  font-size: 17px;
  height: 23px;
  min-width: 26px;
  padding: 0;
}

.scanPager span {
  color: var(--accent-dark);
  font-size: 12px;
  font-weight: 850;
  min-width: 76px;
  text-align: center;
}

.scanTools {
  display: none;
}

.scanTools button,
.iconRefreshButton {
  border-radius: 7px;
  font-size: 16px;
  height: 30px;
  min-width: 34px;
  padding: 0;
}

.weeklyTopRefreshButton {
  align-items: center;
  display: inline-flex;
  justify-content: center;
  min-width: 34px;
  width: 34px;
}

.sheetHeader .weeklyTopRefreshButton {
  flex: 0 0 34px;
}

.tableHeader span:last-child {
  color: var(--muted);
  font-weight: 700;
}

.scanDayBanner {
  align-items: center;
  border-bottom: 1px solid var(--scan-grid);
  display: grid;
  gap: 2px 10px;
  grid-template-columns: minmax(74px, auto) minmax(0, 1fr) minmax(170px, auto) minmax(132px, 154px);
  min-height: 34px;
  padding: 4px 10px;
}

.scanDayBanner [data-scan-label] {
  background: #fff;
  border: 1px solid var(--scan-grid);
  border-radius: 999px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0;
  padding: 3px 7px;
  text-transform: uppercase;
}

.scanDayBanner [data-scan-title] {
  color: var(--accent-dark);
  font-size: 16px;
  font-weight: 950;
  line-height: 1.05;
  min-width: 0;
}

.scanBannerMeta {
  align-items: center;
  display: flex;
  gap: 6px;
  justify-content: flex-end;
  min-width: 0;
}

.scanDayBanner small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
  text-align: right;
  white-space: nowrap;
}

.scanDateOverride {
  align-items: end;
  display: grid;
  gap: 2px;
  justify-self: end;
  min-width: 0;
  opacity: 0.78;
  width: min(154px, 100%);
}

.scanDateOverride:focus-within {
  opacity: 1;
}

.scanDateOverride span {
  color: var(--muted);
  font-size: 9px;
  font-weight: 950;
  line-height: 1;
  overflow: hidden;
  text-align: right;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.scanDateControl {
  background: #f8faf9;
  border: 1px solid #dbe6df;
  border-radius: 7px;
  color: #5f756b;
  font-size: 12px;
  font-weight: 800;
  min-height: 28px;
  min-width: 0;
  padding: 4px 7px;
  width: 100%;
}

.scanDateControl:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(30, 95, 77, 0.12);
  outline: none;
}

.scanQualityBar {
  align-items: center;
  background: #f8faf9;
  border-bottom: 1px solid var(--scan-grid);
  display: grid;
  gap: 7px;
  grid-template-columns: minmax(0, 1fr) auto;
  min-height: 34px;
  padding: 4px 8px;
}

.scanWarningList {
  display: grid;
  gap: 4px;
  grid-column: 1 / -1;
}

.scanWarningItem {
  background: #fff5df;
  border: 1px solid #e7c97a;
  border-radius: 6px;
  color: #745002;
  font-size: 12px;
  font-weight: 850;
  line-height: 1.25;
  padding: 6px 8px;
}

.scanQualityBar[hidden] {
  display: none;
}

.scanQualityChips {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  min-width: 0;
}

.scanQualityActions {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  justify-content: flex-end;
  min-width: 0;
}

.scanQualityChip {
  align-items: center;
  background: #fff;
  border: 1px solid #d4e0da;
  border-radius: 999px;
  color: var(--muted);
  display: inline-flex;
  font-size: 10px;
  font-weight: 900;
  gap: 4px;
  min-height: 22px;
  min-width: 0;
  padding: 0 7px;
  text-transform: uppercase;
  white-space: nowrap;
}

.scanQualityChip strong {
  color: var(--accent-dark);
  font-size: 12px;
}

.scanQualityChip.ok {
  border-color: #bdd7ca;
  color: var(--accent-dark);
}

.scanQualityChip.rescued,
.scanQualityChip.review {
  background: #fff8df;
  border-color: #e2c979;
  color: #755600;
}

.scanQualityChip.missing {
  background: #f7eeee;
  border-color: #d7c2bd;
  color: #7b4e43;
}

.scanQualityChip.invalid {
  background: #fff0f0;
  border-color: #dca4a4;
  color: #8e2d2d;
}

.scanQualityChip.total {
  background: #eef3ef;
}

.scanQualityBar button {
  background: #fff;
  border-color: #b9d3c6;
  color: var(--accent-dark);
  font-size: 11px;
  font-weight: 950;
  min-height: 26px;
  min-width: 0;
  padding: 0 9px;
  white-space: nowrap;
}

.scanQualityBar button:not(:disabled):hover,
.scanQualityBar button:not(:disabled):focus-visible {
  background: var(--accent-soft);
  outline: none;
}

.tableWrap {
  background: var(--scan-row);
  flex: 1;
  max-height: min(70vh, 590px);
  min-height: 320px;
  overflow: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}

body:not(.appLocked) #scanPage .review .tableWrap {
  background:
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.028) 0 1px, transparent 1px 9px),
    linear-gradient(180deg, rgba(42, 49, 58, 0.94), rgba(27, 32, 39, 0.96)),
    radial-gradient(circle at 50% 0, rgba(255, 255, 255, 0.05), transparent 48%);
  max-height: none;
  min-height: min(56vh, 540px);
}

body:not(.appLocked) #scanPage[data-scan-stage="pre"] .review {
  min-height: calc(100vh - 82px);
}

body:not(.appLocked) #scanPage[data-scan-stage="pre"] .review .tableWrap,
body:not(.appLocked) #scanPage[data-scan-stage="pre"] #reviewTable,
body:not(.appLocked) #scanPage[data-scan-stage="pre"] #rowsBody,
body:not(.appLocked) #scanPage[data-scan-stage="pre"] .emptyScanRow,
body:not(.appLocked) #scanPage[data-scan-stage="pre"] .emptyScanRow td {
  height: 100%;
}

body:not(.appLocked) #scanPage[data-scan-stage="pre"] .emptyScanRow td {
  padding: clamp(26px, 4vh, 46px) 26px;
  vertical-align: middle;
}

table {
  border-collapse: collapse;
  min-width: 960px;
  table-layout: fixed;
  width: 100%;
}

th,
td {
  border-bottom: 1px solid var(--line);
  border-right: 1px solid var(--line);
  padding: 4px 5px;
  vertical-align: middle;
}

th {
  background: #e8f0eb;
  box-shadow: inset 0 -1px 0 #c2d0c8;
  color: #26352e;
  font-size: 12px;
  height: 34px;
  position: sticky;
  text-align: left;
  text-transform: uppercase;
  top: 0;
  z-index: 1;
}

.scanJobHeader {
  padding-bottom: 4px;
  padding-top: 4px;
}

.scanJobHeader span {
  color: var(--muted);
  display: block;
  font-size: 10px;
  font-weight: 900;
  line-height: 1;
}

.scanJobHeader strong {
  color: var(--ink);
  display: block;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.25;
  margin-top: 4px;
  text-transform: none;
}

#scanPage .review th,
#scanPage .review td {
  border-color: var(--scan-grid);
}

#scanPage .review th {
  background: var(--scan-head);
  box-shadow: inset 0 -1px 0 var(--scan-border);
}

tbody tr {
  background: #fff;
}

tbody tr:nth-child(even) {
  background: #f8fbf9;
}

tbody tr:hover {
  background: var(--accent-soft);
}

#scanPage .review tbody tr[data-review-row="true"] {
  background: var(--scan-row);
}

#scanPage .review tbody tr[data-review-row="true"]:nth-child(even) {
  background: var(--scan-row-alt);
}

#scanPage .review tbody tr[data-review-row="true"]:hover {
  background: var(--scan-hover);
}

.emptyScanRow td {
  border-right: 0;
  height: 340px;
}

.emptyScanPrompt {
  align-items: center;
  color: var(--muted);
  cursor: pointer;
  display: grid;
  gap: 10px;
  height: 100%;
  justify-items: center;
  left: 0;
  padding: 32px;
  position: sticky;
  text-align: center;
  width: min(100%, calc(100vw - 32px));
}

.emptyScanPrompt:hover {
  background: var(--scan-hover);
}

.emptyScanPrompt strong {
  color: var(--accent-dark);
  font-size: 28px;
  line-height: 1.1;
}

.emptyScanPrompt span {
  font-size: 15px;
  font-weight: 700;
}

.emptyScanPrompt ol {
  display: grid;
  gap: 6px;
  list-style-position: inside;
  margin: 0;
  max-width: 560px;
  padding: 0;
}

.emptyScanPrompt li {
  background: #fff;
  border: 1px solid #d6e3dc;
  border-radius: 7px;
  color: #506058;
  font-size: 15px;
  font-weight: 800;
  padding: 8px 10px;
  text-align: left;
}

td {
  height: 34px;
}

td input {
  background: transparent;
  border-color: transparent;
  border-radius: 3px;
  height: 27px;
  padding: 0 6px;
  width: 100%;
}

td input:hover {
  border-color: #c8d4ce;
}

td input:focus {
  background: #fff;
  border-color: var(--accent);
  outline: none;
}

td input[data-field="hours"] {
  color: var(--accent-dark);
  font-weight: 900;
}

td input[data-field="job_number"] {
  font-weight: 750;
}

.nameCol {
  width: 172px;
}

.nameCol:has(.scanProofChip),
.nameCol.needsReview {
  align-items: center;
  display: grid;
  gap: 3px;
  grid-template-columns: minmax(0, 1fr) auto;
}

.nameCol .scanProofChip {
  align-items: center;
  border: 1px solid #d3ded8;
  border-radius: 999px;
  display: inline-flex;
  font-size: 9px;
  font-weight: 950;
  height: 18px;
  justify-content: center;
  letter-spacing: 0;
  max-width: 58px;
  min-width: 38px;
  overflow: hidden;
  padding: 0 5px;
  text-transform: uppercase;
  white-space: nowrap;
}

.scanProofChip.ok {
  background: #edf7f2;
  border-color: #bed8cb;
  color: var(--accent-dark);
}

.scanProofChip.rescued,
.scanProofChip.review,
.scanProofChip.low {
  background: #fff7db;
  border-color: #e2c979;
  color: #755600;
}

.scanProofChip.missing {
  background: #f4eeee;
  border-color: #d7c2bd;
  color: #7b4e43;
}

#scanPage .review tbody tr.scanRowNeedsReview,
#scanPage .review tbody tr.scanReviewFocus {
  box-shadow: inset 3px 0 0 #d8a625;
}

#scanPage .review tbody tr.scanRowNeedsReview[data-review-flag="missing"] {
  box-shadow: inset 3px 0 0 #b56c60;
}

#scanPage .review tbody tr.scanReviewFocus {
  outline: 2px solid rgba(216, 166, 37, 0.42);
  outline-offset: -2px;
}

.jobCol {
  width: 96px;
}

.hoursCol {
  width: 92px;
}

.hoursCol input {
  font-size: 14px;
  font-weight: 900;
  text-align: center;
}

.checkCol {
  background: #fbfdfb;
  box-shadow: -1px 0 0 var(--line);
  position: sticky;
  right: 0;
  text-align: center;
  width: 78px;
  z-index: 1;
}

#scanPage .review .checkCol {
  background: var(--scan-check);
  box-shadow: -1px 0 0 var(--scan-grid);
}

.checkHeader {
  background: #dfeae4;
  position: sticky;
  right: 0;
  text-align: center;
  width: 78px;
  z-index: 3;
}

#scanPage .review .checkHeader {
  background: var(--scan-head);
}

.sheetCompanyLabel {
  color: var(--scan-muted);
  display: block;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1;
  margin-bottom: 4px;
}

.sheetCompanySelect {
  border: 1px solid var(--scan-border);
  border-radius: 999px;
  color: #fff;
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
  height: 28px;
  min-width: 70px;
  padding: 0 8px;
  text-align: center;
}

.sheetCompanySelect.company-alfa {
  background: #168a46;
}

.sheetCompanySelect.company-hm {
  background: #c83232;
}

.sheetCompanySelect.company-sec {
  background: #2369d1;
}

.approvalBox {
  align-items: center;
  display: inline-flex;
  height: 32px;
  justify-content: center;
  min-width: 40px;
  position: relative;
  width: 100%;
}

.approvalBox input {
  cursor: pointer;
  height: 100%;
  inset: 0;
  margin: 0;
  opacity: 0;
  position: absolute;
  width: 100%;
  z-index: 2;
}

.approvalBox span {
  align-items: center;
  background: #fff;
  border: 2px solid #8fa098;
  border-radius: 6px;
  color: #fff;
  display: inline-flex;
  height: 25px;
  justify-content: center;
  width: 25px;
}

.approvalBox input:checked + span {
  background: var(--accent);
  border-color: var(--accent);
  box-shadow: 0 2px 6px rgba(30, 95, 77, 0.24);
}

.approvalBox.company-alfa input:checked + span {
  background: #168a46;
  border-color: #168a46;
  box-shadow: 0 2px 7px rgba(22, 138, 70, 0.28);
}

.approvalBox.company-hm input:checked + span {
  background: #c83232;
  border-color: #c83232;
  box-shadow: 0 2px 7px rgba(200, 50, 50, 0.28);
}

.approvalBox.company-sec input:checked + span {
  background: #2369d1;
  border-color: #2369d1;
  box-shadow: 0 2px 7px rgba(35, 105, 209, 0.28);
}

.approvalBox input:checked + span::after {
  content: "✓";
  font-size: 17px;
  font-weight: 900;
  line-height: 1;
}

.approvalBox:focus-within span {
  outline: 3px solid rgba(30, 95, 77, 0.18);
  outline-offset: 1px;
}

.reviewActions {
  align-items: center;
  border-top: 1px solid var(--line);
  display: flex;
  gap: 7px;
  justify-content: flex-start;
  padding: 6px 9px;
}

.saveApprovedWrap {
  align-items: flex-end;
  background: #fbfcfb;
  border: 1px solid #d7e0db;
  border-radius: 6px;
  display: grid;
  gap: 4px;
  justify-items: end;
  margin-left: auto;
  min-width: 246px;
  padding: 4px;
}

.saveApprovedWrap span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  line-height: 1.2;
  max-width: 260px;
  min-height: 14px;
  text-align: right;
}

.saveApprovedWrap span.ready {
  color: var(--accent-dark);
}

.saveRequirements {
  display: grid;
  gap: 2px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  justify-content: stretch;
  list-style: none;
  margin: 0;
  max-width: 100%;
  padding: 0;
  width: 100%;
}

.saveRequirements li {
  align-items: center;
  background: #f3f5f4;
  border: 1px solid #d7dfda;
  border-radius: 5px;
  color: #61736a;
  display: inline-flex;
  font-size: 10px;
  font-weight: 900;
  gap: 4px;
  line-height: 1;
  min-height: 21px;
  min-width: 0;
  padding: 3px 5px;
  text-transform: uppercase;
  white-space: nowrap;
}

.saveRequirements li span {
  align-items: center;
  background: #fff;
  border: 1px solid #d5ded8;
  border-radius: 999px;
  display: inline-flex;
  flex: 0 0 auto;
  font-size: 9px;
  height: 14px;
  justify-content: center;
  width: 14px;
}

.saveRequirements li.needed {
  color: #6a756f;
}

.saveRequirements li.done {
  background: #edf6f1;
  border-color: #bed7ca;
  color: var(--accent-dark);
}

.saveRequirements li.done span {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.saveRequirements strong {
  font: inherit;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.scanReviewButton {
  align-items: center;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 7px;
  box-shadow: 0 8px 18px rgba(20, 35, 28, 0.07);
  color: var(--accent-dark);
  cursor: pointer;
  display: inline-flex;
  gap: 8px;
  min-height: 38px;
  min-width: 148px;
  padding: 0 11px;
  text-transform: none;
}

.secondaryScanButton {
  min-width: 138px;
}

.scanReviewButton span {
  font-size: 22px;
  line-height: 1;
}

.scanReviewButton.secondaryScanButton span {
  font-size: 21px;
}

.scanReviewButton strong {
  font-size: 14px;
  font-weight: 950;
}

.clearScanButton {
  align-items: center;
  background: #fff8f8;
  border: 1px solid #dcb6b6;
  border-radius: 7px;
  color: #9d3333;
  cursor: pointer;
  display: inline-flex;
  gap: 7px;
  min-height: 38px;
  min-width: 120px;
  padding: 0 10px;
}

.clearScanButton span {
  font-size: 18px;
  line-height: 1;
}

.clearScanButton strong {
  font-size: 13px;
  font-weight: 950;
}

.clearScanButton:not(:disabled):hover,
.clearScanButton:not(:disabled):focus-visible {
  background: #ffecec;
  border-color: #c86565;
  box-shadow: 0 0 0 3px rgba(200, 50, 50, 0.12);
  outline: none;
}

.clearScanButton:disabled {
  cursor: default;
  opacity: 0.48;
}

.scanOverlay {
  align-items: center;
  background: rgba(248, 251, 249, 0.92);
  display: grid;
  gap: 10px;
  inset: 35px 0 55px;
  justify-items: center;
  min-height: 250px;
  padding: 24px;
  position: absolute;
  text-align: center;
  z-index: 4;
}

.scanOverlay[hidden] {
  display: none;
}

.scanSpinner {
  animation: spin 0.8s linear infinite;
  border: 5px solid #d6e6de;
  border-radius: 50%;
  border-top-color: var(--accent);
  height: 58px;
  width: 58px;
}

.scanOverlay strong {
  color: var(--accent-dark);
  font-size: 20px;
}

.scanOverlay span {
  color: var(--muted);
  font-weight: 700;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

.saveScanButton,
.saveEntryButton {
  background: var(--hm-red);
  border-color: var(--hm-red);
  color: #fff;
}

.saveEntryButton:not(:disabled) {
  background:
    linear-gradient(180deg, #d94747 0%, #b62828 100%);
  border-color: #b62828;
  box-shadow:
    0 8px 18px rgba(200, 50, 50, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

.saveEntryButton:not(:disabled):hover,
.saveEntryButton:not(:disabled):focus-visible {
  background:
    linear-gradient(180deg, #e15151 0%, #bd2d2d 100%);
  border-color: #d94747;
  box-shadow:
    0 12px 24px rgba(200, 50, 50, 0.24),
    0 0 0 4px rgba(200, 50, 50, 0.1);
}

.saveEntryButton:disabled {
  background:
    linear-gradient(180deg, #edf1ef 0%, #dfe6e2 100%);
  border-color: #cbd6d0;
  box-shadow: none;
  color: #75817b;
}

.saveScanButton {
  background-image: linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(0, 0, 0, 0.06));
  border-width: 2px;
  box-shadow:
    0 10px 20px rgba(30, 95, 77, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.25);
  font-size: 15px;
  font-weight: 900;
  height: 42px;
  min-width: 148px;
  padding: 0 14px;
  transition:
    background-color 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease,
    filter 160ms ease,
    opacity 160ms ease,
    transform 120ms ease;
}

#scanPage[data-company="alfa"] .saveScanButton:not(:disabled) {
  background: #168a46;
  border-color: #168a46;
  box-shadow: 0 8px 18px rgba(22, 138, 70, 0.2);
}

#scanPage[data-company="hm"] .saveScanButton:not(:disabled) {
  background: #c83232;
  border-color: #c83232;
  box-shadow: 0 8px 18px rgba(200, 50, 50, 0.2);
}

#scanPage[data-company="sec"] .saveScanButton:not(:disabled) {
  background: #2369d1;
  border-color: #2369d1;
  box-shadow: 0 8px 18px rgba(35, 105, 209, 0.2);
}

.saveScanButton:not(:disabled) {
  background-image: linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(0, 0, 0, 0.08));
  cursor: pointer;
  opacity: 1;
}

.saveScanButton:not(:disabled):hover {
  box-shadow:
    0 14px 28px rgba(31, 41, 35, 0.24),
    0 0 0 4px rgba(30, 95, 77, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
  filter: brightness(1.08) saturate(1.08);
  transform: translateY(-3px);
}

#scanPage[data-company="alfa"] .saveScanButton:not(:disabled):hover {
  box-shadow:
    0 14px 28px rgba(22, 138, 70, 0.28),
    0 0 0 4px rgba(22, 138, 70, 0.15),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

#scanPage[data-company="hm"] .saveScanButton:not(:disabled):hover {
  box-shadow:
    0 14px 28px rgba(200, 50, 50, 0.28),
    0 0 0 4px rgba(200, 50, 50, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

#scanPage[data-company="sec"] .saveScanButton:not(:disabled):hover {
  box-shadow:
    0 14px 28px rgba(35, 105, 209, 0.28),
    0 0 0 4px rgba(35, 105, 209, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.saveScanButton:not(:disabled):active {
  box-shadow: 0 5px 12px rgba(31, 41, 35, 0.18);
  filter: brightness(0.96);
  transform: translateY(1px) scale(0.985);
}

.saveScanButton:focus-visible {
  border-color: #fff;
  outline: 3px solid rgba(30, 95, 77, 0.32);
  outline-offset: 3px;
}

.saveScanButton:disabled {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.26), rgba(30, 95, 77, 0.08)),
    #dce7e1;
  border-color: #9db9ad;
  box-shadow:
    0 8px 18px rgba(30, 95, 77, 0.11),
    inset 0 0 0 1px rgba(255, 255, 255, 0.45);
  color: #5f746b;
  cursor: default;
  opacity: 1;
  transform: none;
}

.saveScanButton:disabled:hover {
  box-shadow:
    0 8px 18px rgba(30, 95, 77, 0.11),
    inset 0 0 0 1px rgba(255, 255, 255, 0.55);
  filter: none;
  transform: none;
}

.weeklySheet,
.saved {
  margin-bottom: 8px;
}

.weeklySummaryStrip,
.weeklySummaryGrid,
.weeklySummaryRow {
  background: #f7f9f8;
  border-bottom: 1px solid var(--line);
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(auto-fit, minmax(124px, 1fr));
  padding: 7px 10px;
}

.weeklySummaryStrip > *,
.weeklySummaryGrid > *,
.weeklySummaryRow > *,
.weeklySummaryCard,
.weeklySummaryItem,
.weeklySummaryMetric,
.weeklyMetricCard {
  align-content: center;
  background: #fff;
  border: 1px solid #d7e0db;
  border-left: 3px solid #6f9385;
  border-radius: 6px;
  display: grid;
  gap: 1px;
  min-height: 36px;
  min-width: 0;
  padding: 5px 7px;
}

.weeklySummaryStrip :where(span, small, em),
.weeklySummaryGrid :where(span, small, em),
.weeklySummaryRow :where(span, small, em),
.weeklySummaryCard :where(span, small, em),
.weeklySummaryItem :where(span, small, em),
.weeklySummaryMetric :where(span, small, em),
.weeklyMetricCard :where(span, small, em) {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  font-weight: 850;
  line-height: 1.15;
  text-transform: uppercase;
}

.weeklySummaryStrip :where(strong, b),
.weeklySummaryGrid :where(strong, b),
.weeklySummaryRow :where(strong, b),
.weeklySummaryCard :where(strong, b),
.weeklySummaryItem :where(strong, b),
.weeklySummaryMetric :where(strong, b),
.weeklyMetricCard :where(strong, b) {
  color: var(--accent-dark);
  font-size: 15px;
  font-weight: 950;
  line-height: 1.1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.weeklySummaryStrip .company-hm,
.weeklySummaryGrid .company-hm,
.weeklySummaryRow .company-hm {
  border-left-color: #c83232;
}

.weeklySummaryStrip .company-alfa,
.weeklySummaryGrid .company-alfa,
.weeklySummaryRow .company-alfa {
  border-left-color: var(--accent);
}

.weeklySummaryStrip .company-sec,
.weeklySummaryGrid .company-sec,
.weeklySummaryRow .company-sec {
  border-left-color: #2369d1;
}

.weeklySummaryStrip {
  align-items: stretch;
  background: #f4f7f5;
  gap: 0;
  grid-template-columns: 1.15fr 1.35fr 1fr 1fr;
  padding: 6px 10px;
}

.weeklySummaryStrip .weeklySummaryBlock {
  align-content: center;
  background: transparent;
  border: 0;
  border-left: 1px solid #d6e0da;
  border-radius: 0;
  box-shadow: none;
  display: grid;
  gap: 3px;
  min-height: 44px;
  min-width: 0;
  padding: 3px 12px;
}

.weeklySummaryStrip .weeklySummaryBlock:first-child {
  border-left: 0;
  padding-left: 0;
}

.weeklySummaryStrip .weeklySummaryLabel {
  color: #6d7d75;
  font-size: 12px;
  font-weight: 950;
  line-height: 1.05;
  text-transform: uppercase;
}

.weeklySummaryStrip .weeklySummaryBlock strong {
  color: var(--accent-dark);
  font-size: 19px;
  font-weight: 950;
  line-height: 1.05;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.weeklySummaryStrip .weeklySummaryBlock em {
  color: #627168;
  font-size: 11px;
  font-style: normal;
  font-weight: 850;
  line-height: 1.15;
  overflow: hidden;
  text-overflow: ellipsis;
  text-transform: none;
  white-space: nowrap;
}

.weeklySummaryJobList {
  display: block;
  min-width: 0;
}

.weeklySummaryPills {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  min-width: 0;
}

.weeklySummaryPill {
  align-items: center;
  background: #fff;
  border: 1px solid #d4dfd9;
  border-radius: 999px;
  color: #4f6057;
  display: inline-flex;
  font-size: 11px;
  font-weight: 900;
  gap: 5px;
  min-height: 24px;
  padding: 0 8px;
  white-space: nowrap;
}

.weeklySummaryPill b {
  color: var(--accent-dark);
  font-size: 11px;
}

.weeklySummaryPill.company-hm b {
  color: #c83232;
}

.weeklySummaryPill.company-alfa b {
  color: #168a46;
}

.weeklySummaryPill.company-sec b {
  color: #2369d1;
}

.weeklySummaryEmpty {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.weeklyProgress {
  background: #dce5e0;
  border-radius: 999px;
  display: block;
  height: 5px;
  overflow: hidden;
  width: min(130px, 100%);
}

.weeklyProgress span {
  background: linear-gradient(90deg, var(--accent), #48a46f);
  display: block;
  height: 100%;
}

.weeklyScroller,
.savedGrid {
  overflow: auto;
}

.weeklyScroller {
  max-height: min(48vh, 460px);
}

.weeklyTable {
  min-width: calc(246px + (var(--week-columns) * 104px));
}

.weeklyHeaderRow,
.weeklyRowSheet {
  grid-template-columns: minmax(136px, 170px) repeat(var(--week-columns), minmax(104px, 1fr)) 78px !important;
}

.weeklySelectPrompt {
  align-items: center;
  color: var(--muted);
  display: grid;
  gap: 3px;
  min-height: 72px;
  place-content: center;
  text-align: center;
}

.weeklySelectPrompt strong {
  color: var(--ink);
  font-size: 15px;
}

.weeklyStartPanel {
  align-content: center;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.88), rgba(246, 249, 247, 0.9));
  border: 1px solid #d7e0db;
  border-left: 4px solid var(--hm-red);
  border-radius: 8px;
  color: var(--muted);
  display: grid;
  gap: 8px;
  margin: 10px;
  min-height: 150px;
  padding: 16px;
}

.weeklyStartPanel strong {
  color: var(--ink);
  font-size: 22px;
  line-height: 1.1;
}

.weeklyStartPanel p {
  font-weight: 800;
  line-height: 1.35;
  margin: 0;
  max-width: 620px;
}

.weeklyStartActions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.weeklyStartActions button {
  min-height: 40px;
}

.weeklyStartChecklist {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  max-width: 760px;
}

.weeklyStartChecklist div {
  align-items: center;
  background: rgba(255, 255, 255, 0.58);
  border: 1px solid #d7e0db;
  border-radius: 7px;
  display: grid;
  gap: 8px;
  grid-template-columns: 26px minmax(0, 1fr);
  min-height: 46px;
  padding: 8px 10px;
}

.weeklyStartChecklist b {
  align-items: center;
  background: rgba(185, 39, 42, 0.12);
  border: 1px solid rgba(185, 39, 42, 0.2);
  border-radius: 999px;
  color: var(--hm-red);
  display: inline-flex;
  font-size: 12px;
  height: 26px;
  justify-content: center;
  width: 26px;
}

.weeklyStartChecklist span {
  color: var(--ink);
  font-size: 12px;
  font-weight: 850;
  line-height: 1.25;
}

.weeklyHeaderRow,
.weeklyRowSheet,
.weeklyEmpty {
  align-items: stretch;
  border-bottom: 1px solid var(--line);
  display: grid;
}

.weeklyHeaderRow {
  background: #eef3ef;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  position: sticky;
  text-transform: uppercase;
  top: 0;
  z-index: 2;
}

.weeklyHeaderRow > span,
.weeklyRowSheet > .employeeName,
.weeklyRowSheet > .weekTotal,
.weeklyEmpty > strong,
.weeklyEmpty > span,
.dayHead {
  align-items: center;
  border-right: 1px solid var(--line);
  display: flex;
  min-height: 38px;
  padding: 6px 8px;
}

.dayHead {
  align-items: flex-start;
  flex-direction: column;
  justify-content: center;
}

.dayHead span {
  font-weight: 650;
  text-transform: none;
}

.employeeName,
.weekTotal,
.weeklyEmpty > strong {
  background: #fbfcfb;
}

.dayCell {
  align-items: flex-start;
  background: #fff;
  border: 0;
  border-radius: 0;
  border-right: 1px solid var(--line);
  color: var(--ink);
  cursor: pointer;
  display: grid;
  gap: 4px;
  height: auto;
  justify-content: stretch;
  min-height: 62px;
  min-width: 0;
  padding: 6px;
  position: relative;
  text-align: left;
}

.dayCell.filledCell {
  align-content: stretch;
  gap: 4px;
  grid-template-rows: minmax(0, 1fr) auto;
  min-height: 70px;
  padding: 4px;
}

.dayCell:has(.dayProofBadge),
.dayCell:has(.manualProofBadge) {
  padding-top: 28px;
}

.dayCell.filledCell:has(.dayCellAction) {
  padding-top: 6px;
}

.dayCell:hover,
.dayCell:focus-visible {
  background: #f2f7f4;
}

.dayCell.partialDay {
  background: #fff7d8;
}

.dayCell.partialDay:hover,
.dayCell.partialDay:focus-visible {
  background: #fff0b8;
}

.emptyCell {
  color: var(--muted);
}

.addText {
  align-self: center;
  color: var(--muted);
  font-weight: 800;
  justify-self: center;
}

.entryPill {
  background: #eef2f0;
  border: 1px solid #d4ddd8;
  border-radius: 6px;
  display: grid;
  gap: 0;
  padding: 5px 6px;
}

.entryPill[data-delete-entry] {
  cursor: context-menu;
}

.entryPill.vacation {
  background: #fff4cc;
  border-color: var(--sun);
}

.entryPill.partial {
  background: #fff1b8;
  border-color: #e8bd4d;
}

.entryPill strong,
.entryPill em {
  font-style: normal;
}

.entryPill span {
  color: var(--muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dayCellEntries {
  align-self: stretch;
  display: grid;
  gap: 4px;
  grid-auto-rows: minmax(42px, 1fr);
  height: 100%;
  min-height: 100%;
  min-width: 0;
  position: relative;
}

.dayCellEntry {
  align-content: center;
  gap: 2px;
  min-height: 44px;
  padding: 7px 30px 7px 8px;
}

.dayCellEntry strong {
  font-size: 12px;
  line-height: 1.05;
}

.dayCellEntryJob {
  font-size: 11px;
  font-weight: 850;
  line-height: 1.1;
}

.dayCellEntryHours {
  font-size: 13px;
  font-weight: 950;
  line-height: 1.05;
}

.dayCell small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
  justify-self: end;
}

.dayCellTotal {
  align-self: end;
  justify-self: center;
  text-align: center;
  width: 100%;
}

.dayCellAction {
  align-items: center;
  background: #fff;
  border: 1px solid #d2ddd7;
  border-radius: 5px;
  color: var(--accent-dark);
  display: inline-flex;
  font-size: 11px;
  font-weight: 900;
  height: 22px;
  justify-content: center;
  max-width: 52px;
  min-width: 24px;
  overflow: hidden;
  padding: 0 6px;
  position: absolute;
  right: 5px;
  text-overflow: ellipsis;
  top: 5px;
  white-space: nowrap;
  width: auto;
  z-index: 1;
}

.dayCellAction:hover,
.dayCellAction:focus-visible {
  background: var(--accent-soft);
  border-color: #b8cec3;
  outline: none;
}

.dayCellDelete {
  color: #7b4e43;
  font-size: 15px;
  font-weight: 950;
  min-width: 22px;
  padding: 0;
  width: 22px;
}

.dayCell.filledCell .dayCellDelete {
  right: 5px;
  top: 5px;
}

.dayCellDelete:hover,
.dayCellDelete:focus-visible {
  background: #f5eeee;
  border-color: #d7c2bd;
}

.dayProofBadge,
.manualProofBadge,
.scanProofBadge {
  align-items: center;
  border: 1px solid #d2ddd7;
  border-radius: 999px;
  display: inline-flex;
  font-size: 10px;
  font-weight: 900;
  gap: 3px;
  line-height: 1;
  max-width: calc(100% - 38px);
  min-height: 20px;
  overflow: hidden;
  padding: 0 6px;
  position: absolute;
  text-overflow: ellipsis;
  text-transform: uppercase;
  top: 6px;
  white-space: nowrap;
  z-index: 1;
}

.dayProofBadge {
  background: #f7f9f8;
  color: #5e6d65;
  left: 5px;
}

.manualProofBadge {
  background: #f4f4f1;
  border-color: #d9ddd8;
  color: #68726c;
  left: 5px;
}

.scanProofBadge {
  background: var(--accent-soft);
  border-color: #bdd7ca;
  color: var(--accent-dark);
  display: none;
  left: 5px;
}

.dayCell:has(.dayCellAction) .dayProofBadge,
.dayCell:has(.dayCellAction) .manualProofBadge,
.dayCell:has(.dayCellAction) .scanProofBadge {
  max-width: calc(100% - 30px);
}

.weeklyHeaderRow > span:last-child,
.weekTotal {
  align-items: center;
  justify-content: center;
  text-align: center;
}

.savedGrid {
  display: grid;
  min-height: 220px;
}

.jobBreakoutEmpty {
  align-content: center;
  color: var(--muted);
  display: grid;
  gap: 8px;
  justify-items: center;
  min-height: 120px;
  padding: 14px;
  text-align: center;
}

.jobBreakoutEmpty strong {
  color: var(--accent-dark);
  font-size: 17px;
  font-weight: 950;
}

.jobBreakoutGrid {
  display: grid;
  gap: 7px;
  grid-template-columns: repeat(auto-fit, minmax(560px, 1fr));
  padding: 7px;
}

.jobBreakoutCard {
  --job-breakout-height: 220px;
  background: #fbfcfb;
  border: 1px solid var(--line);
  border-radius: 7px;
  overflow: hidden;
}

.jobBreakoutHeader {
  align-items: center;
  background: #143a31;
  color: #fff;
  display: grid;
  gap: 4px 9px;
  grid-template-columns: minmax(0, 1fr) minmax(92px, auto);
  min-height: 33px;
  padding: 5px 9px;
}

.jobBreakoutHeader strong {
  font-size: 18px;
  font-weight: 950;
  letter-spacing: 0;
}

.jobBreakoutHeader em {
  font-size: 13px;
  font-style: normal;
  font-weight: 900;
  justify-self: end;
}

.jobBreakoutHeaderActions {
  align-items: center;
  display: inline-flex;
  gap: 7px;
  justify-self: end;
}

.jobBreakoutRefreshButton {
  display: none;
}

.jobBreakoutHeaderRefresh {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.22);
  color: #fff;
  display: inline-flex;
  height: 27px;
  min-width: 30px;
}

.jobBreakoutTotals {
  background: #eef6f2;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  padding: 4px 9px;
}

.jobBreakoutTotals span {
  color: var(--accent-dark);
  font-size: 13px;
  font-weight: 950;
}

.jobBreakoutTotals em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 950;
  margin-right: 5px;
  text-transform: uppercase;
}

.jobCompanyGroups {
  align-items: stretch;
  display: grid;
  gap: 5px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  padding: 5px;
}

.jobCompanyGroup {
  border: 1px solid var(--line);
  border-radius: 6px;
  height: var(--job-breakout-height);
  max-height: none;
  min-height: 0;
  min-width: 0;
  overflow-x: hidden;
  overflow-y: auto;
  resize: none;
  scrollbar-gutter: auto;
}

.jobBreakoutResizeBar {
  align-items: center;
  cursor: ns-resize;
  display: flex;
  height: 16px;
  justify-content: center;
  padding: 0 8px 5px;
  touch-action: none;
}

.jobBreakoutResizeBar::before {
  background: #b9c7c0;
  border-radius: 999px;
  content: "";
  height: 4px;
  opacity: 0.9;
  width: min(280px, 42%);
}

.jobBreakoutResizeBar:hover::before,
.jobBreakoutResizeBar:focus-visible::before,
.resizingJobBreakout .jobBreakoutResizeBar::before {
  background: var(--accent);
  opacity: 1;
}

.jobBreakoutResizeBar:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.jobCompanyGroup h3 {
  align-items: center;
  color: #fff;
  display: grid;
  font-weight: 950;
  gap: 2px 10px;
  grid-template-columns: minmax(0, 1fr) auto;
  min-height: 34px;
  margin: -1px -1px 0;
  padding: 6px 9px 5px;
  position: sticky;
  top: 0;
  width: calc(100% + 2px);
  z-index: 1;
}

.jobCompanyGroup h3 > span {
  font-size: 18px;
  line-height: 1;
  min-width: 0;
}

.jobCompanyGroup h3 > strong {
  font-size: 15px;
  justify-self: end;
  line-height: 1;
}

.jobCompanyGroup h3 > em {
  display: flex;
  font-size: 9px;
  font-style: normal;
  font-weight: 900;
  gap: 6px;
  grid-column: 2;
  justify-content: flex-end;
  justify-self: end;
  line-height: 1;
  opacity: 0.86;
  text-transform: uppercase;
  white-space: nowrap;
}

.jobCompanyGroup.company-hm h3 {
  background: #c83232;
}

.jobCompanyGroup.company-alfa h3 {
  background: #168a46;
}

.jobCompanyGroup.company-sec h3 {
  background: #2369d1;
}

.jobEmployeeRow {
  align-items: center;
  background: #fff;
  border-bottom: 1px solid var(--line);
  color: var(--ink);
  display: grid;
  gap: 4px;
  grid-template-columns: minmax(86px, 1fr) minmax(40px, auto) minmax(40px, auto) minmax(54px, auto);
  min-height: 27px;
  min-width: 0;
  padding: 2px 6px;
}

.jobEmployeeRow:last-child {
  border-bottom: 0;
}

.jobEmployeeRow strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.emptyCompanyRow {
  background: #f6f8f7;
  color: var(--muted);
  min-height: 24px;
}

.emptyCompanyRow strong {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.jobEmployeeRow.rosterOnlyEmployee {
  opacity: 0.72;
}

.jobEmployeeRow.rosterOnlyEmployee strong span {
  color: var(--muted);
}

.jobEmployeeRow.rosterOnlyEmployee .savedHourMetric,
.jobEmployeeRow.rosterOnlyEmployee .emptyDayStrip {
  color: var(--muted);
}

.jobEmployeeRow.company-hm strong span,
.weeklyPersonRow.company-hm .employeeName strong {
  color: #a82929;
}

.jobEmployeeRow.company-alfa strong span,
.weeklyPersonRow.company-alfa .employeeName strong {
  color: #0f6f39;
}

.jobEmployeeRow.company-sec strong span,
.weeklyPersonRow.company-sec .employeeName strong {
  color: #1f62bd;
}

.companySavedGrid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  padding: 12px;
}

.companySavedColumn {
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  min-height: 500px;
  min-width: 0;
  overflow: hidden;
}

.companySavedColumn h3 {
  align-items: center;
  border-bottom: 1px solid var(--line);
  color: #fff;
  display: flex;
  font-size: 22px;
  font-weight: 950;
  justify-content: center;
  min-height: 52px;
  padding: 0 12px;
  text-align: center;
}

.companySavedColumn h3::before {
  content: none;
}

.companySavedColumn.company-hm h3 {
  background: #c83232;
}

.companySavedColumn.company-alfa h3 {
  background: #168a46;
}

.companySavedColumn.company-sec h3 {
  background: #2369d1;
}

.savedRow {
  align-items: center;
  background: #fff;
  border-bottom: 1px solid var(--line);
  border-left: 0;
  border-right: 0;
  border-top: 0;
  color: var(--ink);
  display: grid;
  font: inherit;
  gap: 12px;
  grid-template-columns: 70px minmax(120px, 0.9fr) minmax(0, 1.1fr);
  min-height: 40px;
  padding: 0 10px;
  text-align: left;
  width: 100%;
}

.savedEntryRow {
  grid-template-columns: 70px minmax(120px, 0.9fr) minmax(0, 1.1fr) 24px;
}

.savedRow span {
  color: var(--muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.weeklyPersonRow {
  cursor: pointer;
  min-height: 30px;
  padding: 3px 6px;
}

.weeklyPersonRow[data-delete-entries],
.savedEntryRow[data-delete-entries] {
  -webkit-touch-callout: none;
}

.weeklyPersonRow:hover,
.weeklyPersonRow:focus-visible {
  background: #f2f7f4;
  outline: none;
}

.weeklyPersonRow.selected {
  background: #e8f2ed;
  box-shadow: inset 4px 0 0 var(--accent);
}

.weeklyPersonRow.company-hm.selected {
  background: #fff0f0;
  box-shadow: inset 5px 0 0 #c83232;
}

.weeklyPersonRow.company-alfa.selected {
  background: #edf8f1;
  box-shadow: inset 5px 0 0 #168a46;
}

.weeklyPersonRow.company-sec.selected {
  background: #edf5ff;
  box-shadow: inset 5px 0 0 #2369d1;
}

.savedEmployeeName {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.savedEmployeeWithProof {
  align-items: center;
  display: flex;
  gap: 6px;
  min-width: 0;
}

.savedEmployeeWithProof span {
  color: inherit;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.savedProofButton {
  align-items: center;
  background: #eef6f2;
  border: 1px solid #bdd7ca;
  border-radius: 5px;
  color: var(--accent-dark);
  display: inline-flex;
  flex: 0 0 auto;
  font-size: 12px;
  height: 22px;
  justify-content: center;
  min-height: 22px;
  min-width: 24px;
  padding: 0;
  width: 24px;
}

.savedProofButton:hover,
.savedProofButton:focus-visible {
  background: #dcece4;
  border-color: #8fbca8;
  outline: none;
}

.savedRow .savedEmployeeBlock {
  color: var(--ink);
  display: grid;
  gap: 4px;
  min-width: 0;
  overflow: visible;
  white-space: normal;
}

.savedEntryJobs {
  min-width: 0;
  overflow: hidden;
}

.savedRow .savedJobBreakout {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  max-height: 40px;
  min-width: 0;
  overflow: hidden;
  white-space: normal;
}

.savedRow .savedJobChip {
  align-items: center;
  background: #f2f6f4;
  border: 1px solid #d7e1dc;
  border-radius: 999px;
  color: #3d5148;
  display: inline-flex;
  flex: 0 1 auto;
  font-size: 11px;
  font-weight: 850;
  gap: 4px;
  line-height: 1;
  max-width: 100%;
  min-height: 19px;
  padding: 3px 5px;
  white-space: nowrap;
}

.savedJobChip b {
  color: var(--ink);
  font-size: 11px;
  font-weight: 950;
  max-width: 92px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.savedHourMetric {
  align-items: baseline;
  display: flex;
  gap: 4px;
  justify-content: flex-end;
  min-width: 0;
  white-space: nowrap;
}

.savedHourMetric em {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}

.savedHourTotal {
  color: var(--ink);
  font-weight: 900;
}

.entryContextMenu {
  background:
    linear-gradient(180deg, #272b32 0%, #1c1f24 100%);
  border: 1px solid #3b424d;
  border-radius: 8px;
  box-shadow:
    0 22px 58px rgba(0, 0, 0, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
  display: grid;
  min-width: 190px;
  overflow: hidden;
  padding: 6px;
  position: fixed;
  z-index: 1000;
}

.entryContextMenu[hidden] {
  display: none;
}

.entryContextMenu button {
  background: transparent;
  border: 0;
  border-radius: 7px;
  color: #f4f6fa;
  cursor: pointer;
  font-size: 14px;
  font-weight: 850;
  justify-content: flex-start;
  min-height: 38px;
  padding: 0 12px;
  text-align: left;
}

.entryContextMenu button:hover,
.entryContextMenu button:focus-visible {
  background: #303640;
  outline: none;
}

.entryContextMenu button:disabled {
  color: #78818c;
  cursor: not-allowed;
}

.entryContextMenu .dangerMenuItem {
  color: #ff8a8a;
}

.entryContextMenu .dangerMenuItem:hover,
.entryContextMenu .dangerMenuItem:focus-visible {
  background: rgba(200, 50, 50, 0.18);
}

.proofButton {
  margin-right: auto;
}

.receiptDialog .proofButton {
  margin-right: 0;
}

.receiptDialog .secondaryProofButton {
  margin-right: auto;
}

.proofStatus {
  background: #f8faf9;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  margin: 2px 0 0;
  padding: 10px 12px;
}

.modulePage {
  padding: 0;
}

.poDashboard,
.maintenanceDashboard {
  background: #fbfcfb;
}

.moduleHeader {
  align-items: center;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 10px;
  justify-content: space-between;
  min-height: 44px;
  padding: 8px 10px;
}

.moduleHeader > div {
  min-width: 0;
}

.moduleHeader p {
  color: var(--muted);
  line-height: 1.25;
  margin-top: 2px;
  overflow-wrap: anywhere;
}

.moduleStatus {
  background: var(--accent-soft);
  border: 1px solid #c9ded4;
  border-radius: 999px;
  color: var(--accent-dark);
  font-size: 11px;
  font-weight: 900;
  padding: 6px 9px;
  text-transform: none;
  white-space: nowrap;
}

.moduleStatus:where(:not(:empty)) {
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
}

.moduleBody {
  display: grid;
  gap: 7px;
  padding: 7px 9px 9px;
}

.poDashboard .moduleBody {
  align-items: start;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.42fr);
}

.poActionGrid {
  align-items: start;
  display: grid;
  gap: 7px;
  grid-template-columns: minmax(260px, 0.8fr) minmax(360px, 1.2fr);
}

.poDashboard .poActionGrid {
  grid-column: 1 / -1;
}

.poWorkflowStrip {
  align-items: center;
  background:
    linear-gradient(180deg, #ffffff 0, #f5f8f7 100%);
  border: 1px solid #d7e0db;
  border-radius: 7px;
  display: grid;
  gap: 7px;
  grid-column: 1 / -1;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  padding: 8px;
}

.poWorkflowStrip span {
  align-items: center;
  background: #fff;
  border: 1px solid #dce5e0;
  border-radius: 6px;
  color: var(--muted);
  display: flex;
  font-size: 12px;
  font-weight: 900;
  gap: 8px;
  min-height: 34px;
  min-width: 0;
  padding: 6px 8px;
}

.poWorkflowStep.is-active {
  border-color: #a8c9b8;
  box-shadow: inset 4px 0 0 var(--accent);
  color: var(--accent-dark);
}

.poWorkflowStep.is-complete {
  background: #f4faf6;
  border-color: #b8d2c5;
  color: var(--accent-dark);
}

.poWorkflowStep.is-upcoming {
  opacity: 0.78;
}

.poWorkflowStrip strong {
  align-items: center;
  background: var(--hm-red);
  border-radius: 50%;
  color: #fff;
  display: inline-flex;
  flex: 0 0 auto;
  font-size: 12px;
  height: 22px;
  justify-content: center;
  width: 22px;
}

.poQuickBrief {
  display: grid;
  gap: 8px;
  grid-column: 1 / -1;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.poQuickBrief > div {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(247, 249, 248, 0.92));
  border: 1px solid #d7e0db;
  border-left: 4px solid var(--hm-red);
  border-radius: 7px;
  display: grid;
  gap: 4px;
  min-height: 82px;
  padding: 10px 12px;
}

.poQuickBrief strong {
  color: var(--accent-dark);
  font-size: 18px;
  line-height: 1.1;
}

.poQuickBrief em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
  line-height: 1.35;
}

.poDashboard .primaryModuleAction {
  align-self: start;
}

.poDashboard .poPrimaryAction {
  border-color: #b9cfc3;
  min-height: 72px;
  padding: 10px;
}

.poDashboard .poPrimaryAction .moduleIcon {
  height: 44px;
  width: 44px;
}

.poDashboard .poPrimaryAction strong {
  font-size: 17px;
}

.poDashboard .moduleSummaryHeader,
.poDashboard .poSummaryGrid {
  grid-column: 1;
}

.poDashboard .receiptList {
  align-self: stretch;
  grid-column: 2;
  grid-row: 2 / span 2;
}

#copyPoDirectoryButton,
#copyTruckDirectoryButton,
#viewTruckDirectoryButton {
  background: #fff;
  border-color: #c7d5ce;
  color: var(--accent-dark);
  font-size: 12px;
  font-weight: 900;
  height: 32px;
  min-width: 92px;
  padding: 0 10px;
}

#copyPoDirectoryButton:not(:disabled):hover,
#copyTruckDirectoryButton:not(:disabled):hover,
#viewTruckDirectoryButton:not(:disabled):hover {
  background: var(--accent-soft);
  border-color: #acc8ba;
}

#copyPoDirectoryButton:disabled,
#copyTruckDirectoryButton:disabled,
#viewTruckDirectoryButton:disabled {
  background: #f4f6f5;
  border-color: #d8e0dc;
  color: #8a9690;
}

.primaryModuleAction,
.jobLinkCard,
.summaryCard,
.receiptCaptureCard,
.receiptHistory {
  background: #fff;
  border: 1px solid #d7e0db;
  border-radius: 6px;
}

.primaryModuleAction {
  align-items: center;
  background: #fff;
  border-color: #cbd8d1;
  box-shadow: none;
  color: var(--ink);
  display: grid;
  gap: 7px;
  grid-template-columns: 38px minmax(0, 1fr);
  height: auto;
  justify-content: stretch;
  min-height: 58px;
  padding: 7px;
  text-align: left;
  width: 100%;
}

.primaryModuleAction:not(:disabled):hover,
.primaryModuleAction:not(:disabled):focus-visible {
  background: #f4faf6;
  border-color: #a8c9b8;
  box-shadow: inset 4px 0 0 var(--accent);
}

.primaryModuleAction:not(:disabled):active {
  transform: translateY(1px);
}

.primaryModuleAction strong,
.receiptCaptureCard strong {
  color: var(--accent-dark);
  display: block;
  font-size: 15px;
  line-height: 1.12;
}

.primaryModuleAction small,
.maintenanceChoices small {
  color: var(--muted);
  display: block;
  font-size: 10px;
  font-weight: 650;
  line-height: 1.25;
  margin-top: 3px;
  text-transform: none;
}

.moduleIcon {
  align-items: center;
  background: var(--accent);
  border-radius: 6px;
  color: #fff;
  display: inline-flex;
  font-size: 18px;
  font-weight: 900;
  height: 38px;
  justify-content: center;
  width: 38px;
}

.jobLinkCard {
  align-content: center;
  display: grid;
  gap: 4px;
  padding: 7px;
}

.poQueuePanel {
  align-content: start;
  min-height: 58px;
}

.poQueuePanel p {
  font-size: 11px;
  line-height: 1.28;
}

.poQueueList {
  display: grid;
  gap: 3px;
  max-height: 96px;
  overflow: auto;
}

.poQueueList.sourcePoList {
  gap: 4px;
  max-height: 178px;
}

.poQueueList:empty::before {
  background: #fff;
  border: 1px dashed #cbd8d1;
  border-radius: 6px;
  color: var(--muted);
  content: "No recent POs";
  font-size: 12px;
  font-weight: 800;
  padding: 7px 8px;
}

.poQueueList > * {
  background: #fff;
  border: 1px solid #d9e4de;
  border-radius: 5px;
  min-height: 26px;
  padding: 4px 6px;
}

.poQueueList > .sourcePoButton {
  align-items: center;
  appearance: none;
  background: #fff;
  border-color: #d9e4de;
  color: var(--ink);
  cursor: pointer;
  display: grid;
  gap: 5px 7px;
  grid-template-columns: minmax(82px, auto) minmax(0, 1fr) minmax(70px, auto);
  height: auto;
  justify-content: stretch;
  min-height: 36px;
  min-width: 0;
  padding: 5px 6px;
  text-align: left;
  width: 100%;
}

.sourcePoButton:hover,
.sourcePoButton:focus-visible {
  background: #f4faf6;
  border-color: #a8c9b8;
  box-shadow: inset 3px 0 0 var(--accent);
  outline: none;
}

.sourcePoNumber {
  color: var(--accent-dark);
  font-size: 12px;
  font-weight: 950;
  white-space: nowrap;
}

.sourcePoText {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.sourcePoText strong,
.sourcePoText em {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sourcePoText strong {
  color: var(--ink);
  font-size: 12px;
  line-height: 1.15;
}

.sourcePoText em {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
}

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

.jobLinkCard strong,
.summaryCard strong,
.receiptListRow strong,
.historyRow strong {
  line-height: 1.25;
}

.jobLinkCard p {
  color: var(--muted);
  line-height: 1.45;
}

.moduleEyebrow {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.miniSteps {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 4px;
}

.miniSteps span {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--accent-dark);
  font-size: 12px;
  font-weight: 800;
  padding: 6px 9px;
}

.moduleSummaryHeader {
  align-items: center;
  display: flex;
  gap: 8px;
  justify-content: space-between;
  min-height: 30px;
}

.moduleSummaryHeader h3 {
  font-size: 16px;
  line-height: 1.2;
  margin: 1px 0 0;
}

.miniButtonGroup {
  display: flex;
  gap: 6px;
}

.miniButtonGroup button {
  min-width: 72px;
}

.poSummaryGrid {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.poSummaryGrid > .empty {
  align-content: center;
  background: #fff;
  border: 1px dashed #cbd8d1;
  border-radius: 7px;
  color: var(--muted);
  display: grid;
  font-weight: 750;
  min-height: 64px;
}

.summaryCard {
  display: grid;
  gap: 5px;
  min-width: 0;
  padding: 6px;
}

.summaryCard > div:first-child {
  align-items: flex-start;
  display: grid;
  gap: 6px;
  min-width: 0;
}

.jobBadge,
.truckBadge {
  align-items: center;
  background: #fff;
  border: 1px solid #c9ded4;
  border-radius: 6px;
  color: var(--accent-dark);
  display: inline-flex;
  font-size: 12px;
  font-weight: 900;
  height: 25px;
  justify-content: center;
  min-width: 42px;
  padding: 0 6px;
  width: fit-content;
}

.summaryCard dl {
  display: grid;
  gap: 5px;
  margin: 0;
}

.summaryCard dl div {
  align-items: start;
  background: #fff;
  border: 1px solid #d9e4de;
  border-radius: 5px;
  display: grid;
  gap: 2px;
  min-height: 28px;
  padding: 4px 5px;
}

.summaryCard dt,
.summaryCard dd {
  margin: 0;
}

.summaryCard dt,
.receiptListRow span,
.historyRow em {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.summaryCard dd {
  font-weight: 850;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.statusPill {
  border-radius: 999px;
  font-size: 12px;
  font-weight: 850;
  justify-self: start;
  padding: 6px 9px;
}

.statusPill.ready {
  background: var(--accent-soft);
  color: var(--accent-dark);
}

.statusPill.hold {
  background: #fff4cc;
  color: #795900;
}

.statusPill.missing {
  background: #fff4cc;
  color: #795900;
}

.statusPill.review {
  background: #fff1f1;
  color: #a63232;
}

.statusPill.approved {
  background: var(--accent-soft);
  color: var(--accent-dark);
}

.statusPill.draft {
  background: #eef3ef;
  color: var(--muted);
}

.poStatusChips {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  min-width: 0;
}

.poStatusChip {
  align-items: center;
  background: #f6f8f7;
  border: 1px solid #d7e0db;
  border-radius: 999px;
  color: var(--muted);
  display: inline-flex;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: 0;
  line-height: 1;
  min-height: 20px;
  padding: 4px 7px;
  text-transform: uppercase;
  white-space: nowrap;
}

.poStatusChip.source {
  background: #fff1f1;
  border-color: #e7b4b4;
  color: #a63232;
}

.poStatusChip.monthly,
.poStatusChip.hold,
.poStatusChip.missing {
  background: #fff4cc;
  border-color: #e6cf78;
  color: #795900;
}

.poStatusChip.review {
  background: #fff1f1;
  border-color: #e7b4b4;
  color: #a63232;
}

.poStatusChip.active,
.poStatusChip.ready,
.poStatusChip.approved {
  background: var(--accent-soft);
  border-color: #b8d2c5;
  color: var(--accent-dark);
}

.poStatusChip.draft,
.poStatusChip.count {
  background: #eef3ef;
  color: var(--muted);
}

.poStatusChip.action {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.receiptList,
.historyRows {
  border: 1px solid var(--line);
  border-radius: 6px;
  overflow: hidden;
}

.receiptList {
  background: #fff;
  display: grid;
}

.poDashboard .receiptDirectory::before {
  border-bottom: 1px solid var(--line);
  color: var(--muted);
  content: "Receipt directory";
  font-size: 11px;
  font-weight: 900;
  padding: 6px 8px 5px;
  text-transform: uppercase;
}

.receiptDirectory {
  max-height: min(36vh, 320px);
  overflow: auto;
}

.receiptListRow,
.historyRow {
  align-items: center;
  background: #fff;
  border-bottom: 1px solid var(--line);
  display: grid;
  gap: 6px;
  grid-template-columns: 62px minmax(0, 1fr) auto;
  min-height: 29px;
  min-width: 0;
  padding: 4px 6px;
}

.receiptListRow > *,
.historyRow > * {
  min-width: 0;
}

.receiptListRow strong,
.historyRow strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.poDashboard .receiptListRow {
  align-items: start;
  grid-template-columns: 54px minmax(0, 1fr);
  min-height: 40px;
}

.poDashboard .poQueueCard {
  align-items: center;
  grid-template-columns: minmax(62px, auto) minmax(0, 1fr) minmax(84px, auto);
  min-height: 46px;
}

.poQueueDetails {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.poDashboard .poQueueCard .jobBadge {
  color: var(--accent-dark);
  font-size: 12px;
  font-weight: 900;
}

.poDashboard .receiptListRow strong {
  overflow: visible;
  text-overflow: clip;
  white-space: normal;
}

.poDashboard .receiptListRow em {
  grid-column: 2;
  white-space: normal;
}

.poDashboard .receiptDirectoryRow {
  align-items: center;
  grid-template-columns: 56px minmax(0, 1fr) minmax(88px, auto);
  min-height: 31px;
}

.poDirectoryDetails {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.poDashboard .receiptDirectoryRow strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.poDashboard .receiptDirectoryRow em {
  grid-column: auto;
  justify-self: end;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.poDashboard .receiptDirectoryRow .poDirectoryDetails em {
  grid-column: auto;
  justify-self: start;
}

.poDashboard .receiptDirectoryRow .poDirectoryDetails small {
  color: #6f7b75;
  font-size: 10px;
  font-weight: 800;
  line-height: 1.25;
}

.poDashboard .receiptDirectoryRow .poStatusChips {
  justify-content: flex-end;
  justify-self: end;
}

.poDashboard .receiptDirectoryRow .poStatusChip {
  min-height: 18px;
  padding: 3px 6px;
}

.sourceReceiptRow,
.sourcePoCard {
  border-left: 4px solid #a63232;
}

.sourceExampleBar {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(auto-fit, minmax(128px, 1fr));
}

.sourceExampleBar button {
  align-items: start;
  background: #f7faf8;
  border: 1px solid #d7e0db;
  border-radius: 6px;
  color: var(--ink);
  display: grid;
  gap: 2px;
  min-height: 48px;
  padding: 7px 8px;
  text-align: left;
}

.sourceExampleBar button:hover,
.sourceExampleBar button:focus-visible {
  background: #edf6f1;
  border-color: #9bb9a9;
}

.sourceExampleBar span {
  color: var(--accent);
  font-size: 11px;
  font-weight: 1000;
}

.sourceExampleBar strong {
  font-size: 12px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sourceReceiptRow strong::after {
  color: var(--muted);
  content: " source";
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.receiptDirectory .empty {
  border: 0;
  display: grid;
  place-items: center;
  min-height: 56px;
  padding: 10px;
}

.summaryCard[data-receipt-url],
.receiptListRow[data-receipt-url],
.historyRow[data-receipt-url],
.officeTable tr[data-receipt-url] {
  cursor: pointer;
  transition:
    background-color 140ms ease,
    box-shadow 140ms ease,
    color 140ms ease;
}

.receiptListRow[data-receipt-url],
.historyRow[data-receipt-url] {
  box-shadow: inset 2px 0 0 #9ab7aa;
  padding-right: 46px;
  position: relative;
}

.summaryCard[data-receipt-url] {
  box-shadow: inset 0 -2px 0 #9ab7aa;
}

.officeTable tr[data-receipt-url] {
  box-shadow: inset 2px 0 0 #9ab7aa;
}

.officeTable tr[data-receipt-url] td:last-child {
  color: var(--accent-dark);
  font-weight: 950;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
  white-space: nowrap;
}

.receiptListRow[data-receipt-url]::after,
.historyRow[data-receipt-url]::after {
  color: #6b7c73;
  content: "Open";
  font-size: 10px;
  font-weight: 900;
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  text-transform: uppercase;
}

.summaryCard[data-receipt-url]:hover,
.summaryCard[data-receipt-url]:focus-visible,
.receiptListRow[data-receipt-url]:hover,
.receiptListRow[data-receipt-url]:focus-visible,
.historyRow[data-receipt-url]:hover,
.historyRow[data-receipt-url]:focus-visible,
.officeTable tr[data-receipt-url]:hover,
.officeTable tr[data-receipt-url]:focus-visible {
  background: #f3f8f5;
  box-shadow: inset 3px 0 0 var(--accent);
  outline: none;
}

.summaryCard[data-receipt-url]:hover,
.summaryCard[data-receipt-url]:focus-visible {
  box-shadow:
    inset 0 -2px 0 var(--accent),
    0 0 0 2px rgba(30, 95, 77, 0.08);
}

.receiptListRow[data-receipt-url]:focus-visible,
.historyRow[data-receipt-url]:focus-visible,
.officeTable tr[data-receipt-url]:focus-visible {
  outline: 2px solid rgba(30, 95, 77, 0.34);
  outline-offset: -2px;
}

.receiptListRow[data-receipt-url]:hover strong,
.receiptListRow[data-receipt-url]:focus-visible strong,
.historyRow[data-receipt-url]:hover strong,
.historyRow[data-receipt-url]:focus-visible strong,
.officeTable tr[data-receipt-url]:hover td:last-child,
.officeTable tr[data-receipt-url]:focus-visible td:last-child {
  color: var(--accent-dark);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.jobLinkCard p,
.truckReminderPanel p {
  color: var(--muted);
  font-size: 12px;
  font-weight: 650;
  line-height: 1.35;
  margin: 0;
}

.receiptListRow:last-child,
.historyRow:last-child {
  border-bottom: 0;
}

.receiptListRow em,
.historyRow em {
  font-style: normal;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.maintenanceChoices {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(180px, 1fr));
  padding: 0;
}

.maintenanceChoices button {
  align-content: center;
  align-items: center;
  background:
    linear-gradient(180deg, #ffffff 0%, #f8faf9 100%);
  border: 1px solid #d2ddd7;
  border-radius: 5px;
  box-shadow: none;
  color: var(--ink);
  display: grid;
  gap: 4px 10px;
  grid-template-columns: 58px minmax(0, 1fr);
  grid-template-rows: auto auto;
  height: auto;
  justify-content: stretch;
  min-height: 104px;
  min-width: 0;
  padding: 10px 11px;
  text-align: left;
  width: 100%;
}

.maintenanceChoices button:hover,
.maintenanceChoices button:focus-visible {
  background: #f4faf6;
  border-color: #a8c9b8;
  box-shadow: inset 4px 0 0 var(--accent);
}

.maintenanceChoices button:active {
  transform: translateY(1px);
}

.maintenanceChoices button > span {
  align-items: center;
  background: var(--accent-soft);
  border: 1px solid #cbd8d1;
  border-radius: 8px;
  display: inline-flex;
  font-size: 34px;
  grid-row: 1 / 3;
  height: 58px;
  justify-content: center;
  width: 58px;
}

.maintenanceChoices strong {
  color: var(--accent-dark);
  font-size: 18px;
  line-height: 1.1;
  min-width: 0;
}

.maintenanceChoices small {
  font-size: 12px;
  font-weight: 750;
  line-height: 1.28;
  margin-top: 3px;
  min-width: 0;
}

.truckReceiptPanel {
  display: grid;
  align-items: stretch;
  gap: 9px;
  grid-template-areas:
    "capture history"
    "reminders history";
  grid-template-columns: minmax(260px, 0.72fr) minmax(360px, 1.28fr);
}

.truckReceiptPanel > .receiptHistory {
  grid-area: history;
  min-height: 272px;
}

.truckReceiptPanel > .maintenancePrimaryAction {
  grid-area: capture;
  min-height: 92px;
}

.truckReceiptPanel > .truckReminderPanel {
  grid-area: reminders;
  min-height: 87px;
}

.receiptCaptureCard {
  align-items: center;
  display: grid;
  gap: 7px;
  grid-template-columns: 38px minmax(0, 1fr);
  padding: 7px;
}

.receiptCaptureCard p {
  color: var(--muted);
  line-height: 1.35;
  margin-top: 4px;
}

.receiptCaptureCard button {
  grid-column: 1 / -1;
  min-height: 38px;
  width: 100%;
}

.maintenancePrimaryAction {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.12), transparent 34%),
    linear-gradient(180deg, #d64a4a 0%, #b92b2f 100%);
  border-color: #cbd8d1;
  box-shadow: 0 10px 22px rgba(200, 50, 50, 0.12);
  color: #fff;
  gap: 7px;
  grid-template-columns: 44px minmax(0, 1fr);
  min-height: 70px;
  padding: 9px;
}

.maintenancePrimaryAction .moduleIcon {
  background: rgba(15, 18, 22, 0.18);
  border-color: rgba(255, 255, 255, 0.16);
  font-size: 26px;
  height: 44px;
  width: 44px;
}

.maintenancePrimaryAction strong {
  color: #fff;
  font-size: 18px;
  line-height: 1.04;
}

.maintenancePrimaryAction small {
  color: rgba(255, 255, 255, 0.88);
  font-size: 11px;
  line-height: 1.22;
  margin-top: 3px;
}

.maintenancePrimaryAction .moduleEyebrow {
  color: rgba(255, 255, 255, 0.78);
}

.receiptHistory {
  display: grid;
  gap: 4px;
  min-height: 70px;
  padding: 6px;
}

.receiptHistory .moduleSummaryHeader {
  min-height: 30px;
}

.historyRows {
  background: #fff;
  max-height: min(22vh, 134px);
  overflow: auto;
}

.maintenanceDashboard .historyRows {
  max-height: min(44vh, 300px);
}

.truckHistoryGroup {
  display: grid;
  gap: 4px;
  padding: 5px;
}

.truckHistoryGroup + .truckHistoryGroup {
  border-top: 1px solid var(--line);
}

.truckHistoryEmptyGrid {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: 6px;
}

.truckHistoryEmptyCard {
  background: #fff;
  border: 1px dashed #cbd8d1;
  border-radius: 6px;
  display: grid;
  gap: 4px;
  min-height: 84px;
  padding: 10px;
}

.truckHistoryEmptyCard span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
}

.truckHistoryEmptyCard strong {
  color: var(--accent-dark);
  font-size: 14px;
}

.truckHistoryEmptyCard em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  font-weight: 750;
  line-height: 1.3;
}

.historyRows > .empty {
  border: 0;
  min-height: 48px;
}

.truckReminderPanel {
  align-content: start;
  background: #f8faf9;
  border: 1px solid var(--line);
  border-radius: 6px;
  display: grid;
  gap: 4px;
  min-height: 70px;
  padding: 6px;
}

.truckReminderPanel.urgent {
  background: #fff5e5;
  border-color: #e6b76e;
}

.truckReminderPanel.clear {
  background: #effaf3;
  border-color: #b7d9c2;
}

.truckReminderPanel strong {
  color: var(--accent-dark);
  font-size: 14px;
  line-height: 1.18;
}

.truckReminderPanel p {
  color: var(--muted);
  font-size: 11px;
  font-weight: 650;
  line-height: 1.3;
  margin: 0;
}

.truckOwnerDirectory {
  background: #fff;
  border: 1px solid #d7e0db;
  border-radius: 6px;
  display: grid;
  gap: 6px;
  padding: 6px;
}

.truckOwnerDirectory[hidden] {
  display: none;
}

.truckOwnerDirectoryHeader {
  align-items: center;
  display: flex;
  gap: 8px;
  justify-content: space-between;
}

.truckOwnerDirectoryHeader strong {
  color: var(--accent-dark);
  display: block;
  font-size: 14px;
  line-height: 1.1;
}

.truckOwnerDirectoryHeader em {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}

.truckOwnerDirectoryRows {
  display: grid;
  gap: 5px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.truckOwnerRow {
  align-items: center;
  background: #fff;
  border: 1px solid var(--line);
  border-left: 4px solid #9fb9ac;
  border-radius: 5px;
  display: grid;
  gap: 2px 6px;
  grid-template-columns: minmax(86px, auto) minmax(0, 1fr);
  min-height: 34px;
  padding: 5px 7px;
}

.truckOwnerRow strong {
  color: var(--ink);
  font-size: 13px;
  line-height: 1.15;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.truckOwnerRow em {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
  grid-column: 2;
  line-height: 1.2;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.historyRow {
  grid-template-columns: 54px minmax(0, 1fr) minmax(54px, auto);
}

.historyRow .truckBadge {
  max-width: 54px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.officeLock,
.betaSheetHero,
.officeDetails,
.officeSection,
.officeMetricGrid > div {
  background: #fbfcfb;
  border: 1px solid #d7e0db;
  border-radius: 6px;
}

.officeLock {
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) 260px;
  padding: 11px;
}

.officeCopyBar {
  background: #f8faf9;
  border: 1px solid #d7e0db;
  border-radius: 6px;
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  padding: 5px;
}

.officeCopyBar button,
.officeSectionAction {
  background: #fff;
  border-color: #b9d3c6;
  color: var(--accent-dark);
  font-size: 11px;
  font-weight: 900;
  min-height: 30px;
  min-width: 0;
  padding: 0 9px;
}

.officeCopyBar button:disabled {
  background: #f1f4f2;
  border-color: #dbe1dd;
  color: #8c9a94;
}

.officeActionPrimary {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.officeMasterActions .officeSectionAction {
  justify-self: start;
}

.officeActionGrid {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(auto-fit, minmax(134px, 1fr));
}

.officeActionRail {
  display: grid;
  gap: 6px;
}

.officeActionRail .officeCopyBar {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.officeActionHelp {
  color: var(--muted);
  font-size: 11px;
  line-height: 1.35;
  margin: 0;
}

.officeActionTertiary {
  background: #fff;
  border-color: #c6d0d9;
  color: #21313d;
  font-size: 10px;
  justify-self: stretch;
}

.officeSecurityPriority {
  box-shadow: 0 0 0 1px #dbe5ef inset;
}

.officeSectionAction {
  justify-self: end;
}

.officePrioritySection {
  background: linear-gradient(180deg, #fff, #f8fafb);
}

.officePriorityCards {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(auto-fit, minmax(162px, 1fr));
}

.officePriorityCard {
  appearance: none;
  background: #fff;
  border: 1px solid #dce5df;
  border-left: 5px solid #8d9590;
  border-radius: 6px;
  color: var(--ink);
  cursor: pointer;
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: 8px;
  text-align: left;
}

.officePriorityCard:hover,
.officePriorityCard:focus-visible {
  border-color: #b7d2c3;
  box-shadow: 0 10px 22px rgba(30, 95, 77, 0.08);
  outline: 0;
}

.officePriorityCard span {
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.officePriorityCard strong {
  color: var(--accent-dark);
  font-size: 18px;
  line-height: 1.1;
}

.officePriorityCard em {
  color: var(--muted);
  font-style: normal;
  font-size: 11px;
  font-weight: 800;
  line-height: 1.2;
}

.officePriorityCard.priority {
  border-left-color: #d6a319;
}

.officePriorityCard.steady {
  border-left-color: #7e8f84;
}

.officeLock strong {
  color: var(--accent-dark);
  display: block;
  font-size: 20px;
  margin-top: 4px;
}

.officeLock p {
  color: var(--muted);
  line-height: 1.45;
  margin-top: 8px;
}

.officeLogin {
  align-content: end;
  display: grid;
  gap: 8px;
}

.officeLogin button {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
  width: 100%;
}

.adminMessage {
  grid-column: 1 / -1;
}

.officeContent {
  display: grid;
  gap: 7px;
}

.officeContent[hidden],
.officeLock[hidden] {
  display: none;
}

.officeSummary {
  display: grid;
  gap: 9px;
}

.officeMetricGrid {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
}

.officeQuickBrief {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.officeQuickBrief > div {
  background: #fff;
  border: 1px solid #d7e0db;
  border-left: 4px solid var(--accent);
  border-radius: 6px;
  display: grid;
  gap: 4px;
  min-height: 86px;
  padding: 10px 12px;
}

.officeQuickBrief strong {
  color: var(--accent-dark);
  font-size: 18px;
  line-height: 1.15;
}

.officeQuickBrief em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  font-weight: 750;
  line-height: 1.35;
}

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

.officeCompanyReadout {
  align-items: start;
  background:
    linear-gradient(180deg, #ffffff 0, #f8faf9 100%);
  border: 1px solid #d7e0db;
  border-left: 4px solid var(--accent);
  border-radius: 7px;
  color: var(--ink);
  display: grid;
  gap: 4px;
  min-height: 82px;
  padding: 10px 12px;
  text-align: left;
}

.officeCompanyReadout.active {
  border-color: #aebdb4;
  box-shadow: inset 0 0 0 1px rgba(30, 95, 77, 0.16), 0 10px 22px rgba(31, 35, 41, 0.08);
}

.officeCompanyReadout span {
  color: var(--muted);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: 0;
  text-transform: uppercase;
}

.officeCompanyReadout strong {
  color: var(--accent-dark);
  font-size: 18px;
  line-height: 1.1;
}

.officeCompanyReadout em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
}

.officeCompanyReadout.company-hm { border-left-color: var(--hm-red); }
.officeCompanyReadout.company-alfa { border-left-color: #168a46; }
.officeCompanyReadout.company-sec { border-left-color: #2369d1; }

.officeMetricGrid > div {
  display: grid;
  gap: 2px;
  padding: 6px 7px;
}

.officeMetricGrid span,
.officeNote {
  color: var(--muted);
}

.officeMetricGrid strong {
  color: var(--accent-dark);
  font-size: 15px;
}

.betaSheetHero {
  align-items: center;
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(190px, 320px) auto minmax(0, 1fr);
  padding: 12px;
}

.betaSheetHero h4 {
  color: #1f252b;
  font-size: 19px;
  margin: 2px 0 0;
}

.betaSheetHero p {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  margin: 4px 0 0;
}

.betaSheetHero > strong {
  color: #a9272a;
  font-size: 34px;
  font-weight: 950;
  justify-self: center;
  line-height: 1;
}

.betaSheetHeroStats {
  display: grid;
  gap: 5px;
  grid-template-columns: repeat(auto-fit, minmax(148px, 1fr));
}

.betaSheetHeroStats span {
  background: #fff;
  border: 1px solid #d7e0db;
  border-radius: 5px;
  color: var(--muted);
  display: grid;
  font-size: 11px;
  font-weight: 850;
  gap: 2px;
  min-height: 38px;
  padding: 5px 7px;
}

.betaSheetHeroStats b {
  color: var(--accent-dark);
  font-size: 14px;
  line-height: 1.2;
}

.betaSheetHeroStats em {
  color: #7b8580;
  font-size: 9px;
  font-style: normal;
  font-weight: 950;
  letter-spacing: 0;
  text-transform: uppercase;
}

.masterReadout {
  display: grid;
  gap: 7px;
  grid-template-columns: repeat(auto-fit, minmax(154px, 1fr));
}

.masterReadoutItem {
  align-items: start;
  background: #fbfcfb;
  border: 1px solid #d7e0db;
  border-left: 4px solid #9fa8a3;
  border-radius: 6px;
  color: #20282d;
  cursor: pointer;
  display: grid;
  gap: 3px;
  height: auto;
  justify-content: stretch;
  min-height: 76px;
  min-width: 0;
  padding: 9px 10px;
  text-align: left;
}

.masterReadoutItem:hover,
.masterReadoutItem:focus-visible {
  background: #f4faf6;
  border-color: #b8d0c3;
  outline: 2px solid rgba(30, 95, 77, 0.15);
}

.masterReadoutItem span {
  color: #5f6b65;
  font-size: 10px;
  font-weight: 950;
  text-transform: uppercase;
}

.masterReadoutItem strong {
  color: var(--accent-dark);
  font-size: 18px;
  line-height: 1.05;
}

.masterReadoutItem em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 850;
  line-height: 1.25;
}

.masterReadoutItem.security {
  border-left-color: #8d6bcb;
}

.masterReadoutItem.jobs {
  border-left-color: #b82929;
}

.masterReadoutItem.labor {
  border-left-color: #147a3f;
}

.masterReadoutItem.receipts {
  border-left-color: #1f62bd;
}

.masterReadoutItem.scans {
  border-left-color: #d6a319;
}

.masterReadoutItem.directory {
  border-left-color: #607080;
}

.officeSection {
  display: grid;
  gap: 6px;
  padding: 7px;
}

.officeSectionHeader {
  align-items: center;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  min-width: 0;
}

.officeSection h4 {
  font-size: 13px;
  margin: 2px 0 0;
}

.officeSectionHeader h4 {
  color: #20282d;
  font-size: 13px;
  margin: 2px 0 0;
}

.officeSectionHeader > strong {
  color: var(--accent-dark);
  font-size: 12px;
  font-weight: 950;
  text-align: right;
}

.officeJobTotalGrid {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(auto-fit, minmax(124px, 1fr));
  max-height: 138px;
  overflow: auto;
}

.officeJobTotalCard {
  background: #fff;
  border: 1px solid #d7e0db;
  border-left: 4px solid #b82929;
  border-radius: 5px;
  display: grid;
  gap: 2px;
  min-height: 56px;
  padding: 6px 8px;
}

.officeJobTotalCard span {
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.officeJobTotalCard strong {
  color: #20282d;
  font-size: 14px;
}

.officeJobTotalCard em {
  color: #a9272a;
  font-size: 13px;
  font-style: normal;
  font-weight: 950;
}

.officeDetails {
  overflow: hidden;
}

.officeDetails[open] {
  padding-bottom: 7px;
}

.officeDetails summary {
  align-items: center;
  cursor: pointer;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  list-style: none;
  min-height: 42px;
  padding: 9px 11px;
}

.officeDetails[open] summary {
  border-bottom: 1px solid #d7e0db;
  margin-bottom: 7px;
}

.officeDetails summary::-webkit-details-marker {
  display: none;
}

.officeDetails summary::before {
  color: #a9272a;
  content: ">";
  font-size: 13px;
  font-weight: 950;
  transition: transform 160ms ease;
}

.officeDetails[open] summary::before {
  transform: rotate(90deg);
}

.officeDetails summary span {
  color: #20282d;
  flex: 1;
  font-size: 13px;
  font-weight: 950;
  min-width: 0;
}

.officeDetails summary strong {
  color: var(--accent-dark);
  font-size: 11px;
  font-weight: 950;
  text-align: right;
}

.officeDetails > :not(summary) {
  margin-left: 8px;
  margin-right: 8px;
}

.officeSubSection {
  display: grid;
  gap: 6px;
  padding-bottom: 8px;
}

.officeSubSection + .officeSubSection {
  border-top: 1px solid #d7e0db;
  padding-top: 8px;
}

.officeSection [data-office-company-filter].company-hm,
.officeDetails [data-office-company-filter].company-hm {
  color: #8f1f1f;
  border-bottom: 3px solid #b82929;
}

.officeSection [data-office-company-filter].company-alfa,
.officeDetails [data-office-company-filter].company-alfa {
  color: #0f5f33;
  border-bottom: 3px solid var(--accent);
}

.officeSection [data-office-company-filter].company-sec,
.officeDetails [data-office-company-filter].company-sec {
  color: #174e99;
  border-bottom: 3px solid #1f62bd;
}

.officeSection [data-office-company-filter].company-hm.active,
.officeDetails [data-office-company-filter].company-hm.active {
  background: #b82929;
  border-color: #b82929;
  color: #fff;
}

.officeSection [data-office-company-filter].company-alfa.active,
.officeDetails [data-office-company-filter].company-alfa.active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.officeSection [data-office-company-filter].company-sec.active,
.officeDetails [data-office-company-filter].company-sec.active {
  background: #1f62bd;
  border-color: #1f62bd;
  color: #fff;
}

.officeTableWrap {
  background: #fff;
  border: 1px solid #d7e0db;
  border-radius: 5px;
  overflow: auto;
}

.officeTable {
  min-width: 920px;
}

.compactOfficeTable {
  min-width: 360px;
}

.officeEmployeeTable {
  min-width: 1020px;
}

.securityTable {
  min-width: 1180px;
}

.securitySection .officeTableWrap {
  max-height: 360px;
}

.securitySection .compactSecurityAudit {
  max-height: 220px;
}

.officeTable td {
  background: transparent;
  font-size: 12px;
  height: 28px;
  padding: 3px 5px;
}

.officeTable th {
  background: #e3f0e8;
  border-bottom: 2px solid #b7d2c3;
  color: #203d34;
  font-size: 11px;
  height: 28px;
  padding: 3px 5px;
}

.officeTable tbody tr {
  background: #fff;
}

.officeTable tbody tr:nth-child(even) {
  background: #eef6f2;
}

.officeTable tbody tr:hover {
  background: #e7f2ed;
}

.officeTable tbody tr.officeRowDirty {
  background: #fff8dc;
}

.officeTable td:nth-child(2),
.officeTable td:nth-child(3),
.officeTable td:nth-child(4) {
  color: var(--accent-dark);
  font-weight: 900;
}

.officeEditField {
  background: #fff;
  border: 1px solid #d4e0da;
  border-radius: 5px;
  font-weight: 800;
  height: 26px;
  min-width: 70px;
  width: 100%;
}

.officeEditField::placeholder {
  color: #8a9690;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.officeRowActions {
  align-items: center;
  display: grid;
  gap: 3px;
  grid-template-columns: 1fr;
  justify-items: end;
  min-width: 74px;
}

.officeRowActions button {
  align-items: center;
  border: 1px solid #cbd9d2;
  border-radius: 5px;
  color: var(--accent-dark);
  display: inline-flex;
  font-size: 11px;
  font-weight: 900;
  height: 25px;
  justify-content: center;
  padding: 0 5px;
}

.officeRowActions button:first-child {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.officeRowActions button:disabled {
  display: none;
}

.officeRowActions span {
  background: #edf6f1;
  border: 1px solid #cfe1d7;
  border-radius: 999px;
  color: #66746e;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  padding: 5px 8px;
}

.officeRowDirty .officeRowActions {
  grid-template-columns: 46px 54px;
  justify-items: stretch;
  min-width: 104px;
}

.officeRowDirty .officeRowActions span {
  grid-column: 1 / -1;
  justify-self: end;
}

.officeRowDirty .officeRowActions span {
  color: #9d6a00;
}

.placeholderField {
  background: #fff;
  border: 1px dashed #c4d1ca;
  border-radius: 6px;
  color: #8a9690;
  display: inline-flex;
  font-size: 12px;
  font-weight: 800;
  min-width: 82px;
  padding: 7px 9px;
  text-transform: uppercase;
}

.officeEmpty {
  color: var(--muted);
  font-weight: 700;
  text-align: center;
}

.officeCompanyPill {
  --office-company-color: var(--accent-dark);
  background: transparent;
  border-left: 3px solid var(--office-company-color);
  border-radius: 3px;
  color: var(--office-company-color);
  display: inline-flex;
  font-size: 10px;
  font-weight: 900;
  justify-content: center;
  line-height: 1.1;
  min-width: 0;
  padding: 2px 5px 2px 6px;
}

.officeCompanyPill.company-hm {
  --office-company-color: #b82929;
  background: transparent;
}

.officeCompanyPill.company-alfa {
  --office-company-color: #147a3f;
  background: transparent;
}

.officeCompanyPill.company-sec {
  --office-company-color: #1f62bd;
  background: transparent;
}

.officeJobGrid {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(auto-fit, minmax(min(420px, 100%), 1fr));
}

.officeJobCard {
  background: #fff;
  border: 1px solid #d7e0db;
  border-radius: 6px;
  display: grid;
  gap: 6px;
  padding: 7px;
}

.officeJobTop {
  align-items: center;
  display: flex;
  gap: 8px;
  justify-content: space-between;
}

.officeJobTop h5 {
  color: var(--accent-dark);
  font-size: 16px;
  margin: 2px 0 0;
}

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

.officeJobStats span {
  background: #f8faf9;
  border: 1px solid #dbe4df;
  border-radius: 5px;
  color: var(--muted);
  display: grid;
  font-size: 10px;
  font-weight: 750;
  gap: 2px;
  padding: 4px 5px;
}

.officeJobStats strong {
  color: var(--accent-dark);
  font-size: 13px;
}

.officeBoardGrid {
  display: grid;
  gap: 7px;
  grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
  max-height: 236px;
  overflow: auto;
}

.officeBoardCard {
  background: #fff;
  border: 1px solid #d7e0db;
  border-top: 4px solid #9ca7b0;
  border-radius: 6px;
  display: grid;
  gap: 7px;
  padding: 8px;
}

.officeBoardCard.current {
  border-top-color: #147a3f;
}

.officeBoardCard.check {
  border-top-color: #d6a319;
}

.officeBoardCard.empty {
  border-top-color: #b82929;
}

.officeBoardCardTop {
  align-items: center;
  display: flex;
  gap: 8px;
  justify-content: space-between;
}

.officeBoardCardTop h5 {
  color: #20282d;
  font-size: 15px;
  margin: 2px 0 0;
}

.officeBoardStatus {
  background: #eef2f0;
  border: 1px solid #d5dfd9;
  border-radius: 999px;
  color: var(--accent-dark);
  font-size: 10px;
  font-weight: 950;
  padding: 5px 7px;
  text-transform: uppercase;
  white-space: nowrap;
}

.officeBoardStatus.empty {
  background: #fff0f0;
  border-color: #e5b8b8;
  color: #9e2528;
}

.officeBoardStatus.check {
  background: #fff8dc;
  border-color: #e6d28d;
  color: #8a6500;
}

.officeBoardStats,
.officeBoardDays,
.officeBoardCompanies {
  display: grid;
  gap: 4px;
}

.officeBoardStats {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.officeBoardStats span,
.officeBoardDay,
.officeBoardCompany,
.officeBoardMuted {
  background: #f8faf9;
  border: 1px solid #dbe4df;
  border-radius: 5px;
}

.officeBoardStats span {
  color: var(--muted);
  display: grid;
  font-size: 10px;
  font-weight: 850;
  gap: 2px;
  padding: 4px 5px;
}

.officeBoardStats em {
  color: var(--muted);
  font-size: 9px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}

.officeBoardStats strong {
  color: var(--accent-dark);
  font-size: 13px;
}

.officeBoardDays {
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

.officeBoardDay {
  color: var(--muted);
  display: grid;
  font-size: 10px;
  font-weight: 900;
  gap: 2px;
  min-height: 38px;
  padding: 4px;
  text-align: center;
}

.officeBoardDay.filled {
  border-color: #b7d2c3;
  box-shadow: inset 0 3px 0 #147a3f;
}

.officeBoardDay b {
  color: #20282d;
}

.officeBoardDay em {
  font-style: normal;
}

.officeBoardCompanies {
  grid-template-columns: repeat(auto-fit, minmax(82px, 1fr));
}

.officeBoardCompany,
.officeBoardMuted {
  color: var(--accent-dark);
  font-size: 10px;
  font-weight: 950;
  padding: 5px 6px;
}

.officeBoardCompany.company-hm {
  border-left: 4px solid #b82929;
}

.officeBoardCompany.company-alfa {
  border-left: 4px solid #147a3f;
}

.officeBoardCompany.company-sec {
  border-left: 4px solid #1f62bd;
}

.officeBoardMuted {
  color: var(--muted);
}

.officeBoardCard footer {
  border-top: 1px solid #edf1ee;
  color: var(--muted);
  display: flex;
  font-size: 11px;
  font-weight: 800;
  gap: 8px;
  justify-content: space-between;
  min-width: 0;
  padding-top: 5px;
}

.officeBoardCard footer em {
  font-style: normal;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.scanAuditGrid {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(auto-fit, minmax(min(320px, 100%), 1fr));
}

.scanAuditCard {
  background: #fff;
  border: 1px solid #d7e0db;
  border-radius: 6px;
  cursor: pointer;
  display: grid;
  gap: 7px;
  padding: 8px;
}

.scanAuditCard:hover,
.scanAuditCard:focus-visible {
  background: #f6faf8;
  outline: 2px solid rgba(30, 95, 77, 0.16);
}

.scanAuditCard.needsReview {
  background: #fff9e5;
  border-color: #e2c979;
}

.scanAuditCard.matched {
  background: #f7fbf8;
  border-color: #bdd7ca;
}

.scanAuditCard h5 {
  color: var(--accent-dark);
  font-size: 15px;
  margin: 2px 0 0;
}

.scanAuditCard > strong {
  color: #7a5a00;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}

.scanAuditCard.matched > strong {
  color: var(--accent-dark);
}

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

.scanAuditStats span {
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid rgba(160, 180, 170, 0.42);
  border-radius: 5px;
  color: var(--accent-dark);
  display: grid;
  font-size: 13px;
  font-weight: 950;
  gap: 2px;
  padding: 5px;
}

.scanAuditStats em {
  color: var(--muted);
  font-size: 9px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}

.scanAuditCard p {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.3;
  margin: 0;
}

.officeMiniRows,
.directoryGrid {
  display: grid;
  gap: 4px;
}

.officeMiniRows {
  max-height: 150px;
  overflow: auto;
}

.officeMiniRows > div,
.directoryRow {
  align-items: center;
  background: #fff;
  border: 1px solid var(--line);
  border-left-width: 4px;
  border-radius: 5px;
  display: grid;
  gap: 4px;
  grid-template-columns: minmax(0, 1fr) minmax(0, 120px);
  min-height: 26px;
  padding: 3px 6px;
}

.directoryRow {
  border-left-color: #9fb9ac;
}

.directoryRow.company-hm {
  border-left-color: #b82929;
}

.directoryRow.company-hm strong {
  color: #8f1f1f;
}

.directoryRow.company-alfa {
  border-left-color: #147a3f;
}

.directoryRow.company-alfa strong {
  color: #0f5f33;
}

.directoryRow.company-sec {
  border-left-color: #1f62bd;
}

.directoryRow.company-sec strong {
  color: #174e99;
}

.officeMiniRows > div.company-hm {
  border-left-color: #b82929;
}

.officeMiniRows > div.company-alfa {
  border-left-color: #147a3f;
}

.officeMiniRows > div.company-sec {
  border-left-color: #1f62bd;
}

.officeMiniRows strong,
.directoryRow strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.officeMiniRows span:last-child,
.directoryRow span:last-child {
  color: var(--muted);
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.directoryGrid {
  background: #f7faf8;
  border: 1px solid #d7e0db;
  border-radius: 5px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  max-height: 228px;
  overflow: auto;
  padding: 5px;
}

.officeNote {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  font-size: 13px;
  padding: 12px;
}

.bossHero,
.bossProjectCard {
  background: #fbfcfb;
  border: 1px solid #d7e0db;
  border-radius: 6px;
}

.bossHero {
  align-items: center;
  display: flex;
  gap: 12px;
  justify-content: space-between;
  padding: 12px;
}

.bossHero h4 {
  color: var(--accent-dark);
  font-size: 22px;
  line-height: 1.1;
  margin: 2px 0 4px;
}

.bossHero p {
  color: var(--muted);
  font-weight: 700;
}

.bossHero > strong {
  color: var(--accent-dark);
  font-size: 32px;
  line-height: 1;
}

.bossProjectGrid {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.pugHeroStats {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  min-width: min(520px, 44vw);
}

.pugHeroStats span,
.pugLaneStats span,
.pugProjectSummary span {
  background: #fff;
  border: 1px solid #d7e0db;
  border-radius: 6px;
  color: var(--muted);
  display: grid;
  font-size: 11px;
  font-weight: 850;
  gap: 2px;
  min-width: 0;
  padding: 7px 8px;
}

.pugHeroStats b,
.pugLaneStats b,
.pugProjectSummary b {
  color: var(--accent-dark);
  font-size: 18px;
  line-height: 1;
}

.pugSourceSummary {
  align-items: center;
  background: #fbfcfb;
  border: 1px solid #d7e0db;
  border-radius: 6px;
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(240px, 0.45fr) minmax(0, 1fr);
  padding: 10px;
}

.pugWeekRail {
  align-items: center;
  background: #fbfcfb;
  border: 1px solid #d7e0db;
  border-radius: 6px;
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(116px, auto)) minmax(0, 1fr);
  padding: 8px;
}

.pugWeekRail button {
  background: #fff;
  border-color: #c7d5ce;
  color: var(--accent-dark);
  font-size: 12px;
  font-weight: 950;
  min-height: 34px;
  padding: 0 12px;
}

.pugWeekRail span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.3;
}

.pugSourceSummary strong {
  color: var(--accent-dark);
  display: block;
  font-size: 18px;
  line-height: 1.1;
  margin-top: 3px;
}

.pugProjectSummary {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.pugProjectBoard {
  display: grid;
  gap: 10px;
}

.pugProjectLane {
  --project-color: #8a939f;
  --project-soft: rgba(138, 147, 159, 0.14);
  background: #fbfcfb;
  border: 1px solid #d7e0db;
  border-left: 5px solid var(--project-color);
  border-radius: 6px;
  display: grid;
  gap: 7px;
  padding: 8px 9px;
}

.pugProjectLaneHeader {
  align-items: center;
  display: flex;
  gap: 10px;
  justify-content: space-between;
}

.pugProjectLaneHeader h3 {
  color: var(--accent-dark);
  font-size: 22px;
  line-height: 1;
  margin: 2px 0 0;
  max-width: min(520px, 58vw);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.pugLaneStats {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(4, minmax(72px, 1fr));
  min-width: min(420px, 48vw);
}

.pugLaneStats span {
  min-width: 0;
  padding: 6px 8px;
}

.pugJobCardGrid {
  display: grid;
  gap: 8px;
  grid-auto-rows: minmax(0, 1fr);
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.pugJobCard {
  --project-color: #8a939f;
  --project-soft: rgba(138, 147, 159, 0.14);
  background: #fff;
  border: 1px solid #d7e0db;
  border-left: 4px solid var(--project-color);
  border-top: 5px solid var(--project-color);
  border-radius: 6px;
  display: grid;
  gap: 8px;
  min-height: 196px;
  min-width: 0;
  padding: 9px;
}

.project-adi {
  --project-color: #d94a4a;
  --project-soft: rgba(217, 74, 74, 0.15);
}

.project-xai {
  --project-color: #4c8df0;
  --project-soft: rgba(76, 141, 240, 0.15);
}

.project-sdi {
  --project-color: #37b77a;
  --project-soft: rgba(55, 183, 122, 0.15);
}

.project-pug {
  --project-color: #b86bf0;
  --project-soft: rgba(184, 107, 240, 0.15);
}

.project-hm {
  --project-color: #c83232;
  --project-soft: rgba(200, 50, 50, 0.15);
}

.pugProjectLaneHeader h3,
.pugJobTop h4 {
  text-shadow: 0 0 22px var(--project-soft);
}

.pugJobCard.current {
  border-top-color: #35b86b;
}

.pugJobCard.check {
  border-top-color: #f0b83f;
}

.pugJobCard.empty {
  border-top-color: #d94a4a;
}

.pugJobTop {
  align-items: start;
  display: flex;
  gap: 8px;
  justify-content: space-between;
}

.pugJobTop h4 {
  color: var(--ink);
  font-size: 23px;
  line-height: 1;
  margin: 3px 0 0;
}

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

.pugJobStats span {
  background: #f3f6f4;
  border: 1px solid #d7e0db;
  border-radius: 5px;
  display: grid;
  gap: 2px;
  min-width: 0;
  padding: 5px 6px;
}

.pugJobStats em {
  color: var(--muted);
  font-size: 9px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.pugJobStats strong {
  color: var(--accent-dark);
  font-size: 16px;
  line-height: 1;
}

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

.pugDayDot {
  background: #eef2ef;
  border: 1px solid #d7e0db;
  border-radius: 5px;
  color: var(--muted);
  display: grid;
  gap: 3px;
  min-height: 42px;
  padding: 5px 3px;
  text-align: center;
}

.pugDayDot.filled {
  background: #e9f7ee;
  border-color: #9cd5b1;
  color: var(--accent-dark);
}

.pugDayDot b {
  font-size: 10px;
  line-height: 1;
}

.pugDayDot em {
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
}

.pugCompanyStrip {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  min-height: 24px;
}

.pugJobCard footer {
  border-top: 1px solid #d7e0db;
  color: var(--muted);
  display: grid;
  gap: 2px;
  padding-top: 7px;
}

.pugJobCard footer span {
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
}

.pugJobCard footer em {
  font-size: 11px;
  font-style: normal;
  font-weight: 750;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.bossProjectCard {
  display: grid;
  gap: 8px;
  padding: 9px;
}

.bossProjectTop {
  align-items: start;
  display: flex;
  gap: 8px;
  justify-content: space-between;
}

.bossProjectTop h4 {
  color: var(--accent-dark);
  font-size: 22px;
  line-height: 1;
  margin: 3px 0 4px;
}

.bossProjectTop p {
  color: var(--muted);
  font-weight: 700;
}

.bossStatus {
  border-radius: 999px;
  font-size: 11px;
  padding: 5px 8px;
  white-space: nowrap;
}

.bossStatus.current {
  background: var(--accent-soft);
  color: var(--accent-dark);
}

.bossStatus.check {
  background: #fff4cc;
  color: #795900;
}

.bossStatus.empty {
  background: #eef3ef;
  color: var(--muted);
}

.bossBigStats {
  display: grid;
  gap: 5px;
  grid-template-columns: 1.35fr repeat(3, minmax(0, 0.85fr));
}

.bossBigStats div {
  background: #fff;
  border: 1px solid #d7e0db;
  border-radius: 5px;
  display: grid;
  gap: 2px;
  min-width: 0;
  padding: 6px 7px;
}

.bossBigStats span {
  color: var(--muted);
  font-size: 10px;
  font-weight: 850;
  line-height: 1.1;
  overflow: hidden;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.bossBigStats strong {
  color: var(--accent-dark);
  font-size: 19px;
  line-height: 1;
}

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

.bossDayTile {
  background: #fff;
  border: 1px solid #d7e0db;
  border-radius: 5px;
  display: grid;
  gap: 4px;
  min-height: 66px;
  padding: 6px;
}

.bossDayTile.filled {
  border-color: #b9d3c6;
  box-shadow: inset 0 4px 0 var(--accent);
}

.bossDayTile > strong {
  font-size: 13px;
}

.bossDayTile > span {
  color: var(--accent-dark);
  font-size: 16px;
  font-weight: 900;
  min-height: 18px;
}

.bossDayTile > div {
  align-content: start;
  display: grid;
  gap: 4px;
}

.bossCompanyChip {
  border-radius: 999px;
  color: #fff;
  display: inline-flex;
  font-size: 10px;
  font-weight: 900;
  justify-content: center;
  padding: 4px 6px;
  white-space: nowrap;
}

.bossCompanyChip.green {
  background: #168a46;
}

.bossCompanyChip.red {
  background: #c83232;
}

.bossCompanyChip.blue {
  background: #2369d1;
}

.bossCompanyChip.gray {
  background: #76827d;
}

.bossCompanyTotals {
  display: grid;
  gap: 5px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.bossCompanyTotal {
  background: #fff;
  border: 1px solid var(--line);
  border-left: 5px solid #76827d;
  border-radius: 5px;
  display: grid;
  gap: 2px;
  min-width: 0;
  padding: 7px 8px;
}

.bossCompanyTotal em {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  font-weight: 950;
  text-transform: uppercase;
}

.bossCompanyTotal strong {
  color: var(--ink);
  font-size: 20px;
  line-height: 1;
}

.bossCompanyTotal.red {
  border-left-color: #c83232;
}

.bossCompanyTotal.red strong {
  color: #c83232;
}

.bossCompanyTotal.green {
  border-left-color: #168a46;
}

.bossCompanyTotal.green strong {
  color: #168a46;
}

.bossCompanyTotal.blue {
  border-left-color: #2369d1;
}

.bossCompanyTotal.blue strong {
  color: #2369d1;
}

.bossJobList {
  background: #fff;
  border: 1px solid #d7e0db;
  border-radius: 5px;
  display: grid;
  gap: 5px;
  padding: 7px;
}

.bossJobList span {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

.bossJobList strong {
  color: var(--accent-dark);
}

.bossEmptyLine {
  color: var(--muted);
  font-weight: 700;
}

.bossReceiptButton,
.bossCloseButton {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
  min-height: 34px;
  width: 100%;
}

.bossCloseButton {
  background: #fff;
  border-color: var(--line);
  color: var(--ink);
}

.bossReceiptPanel {
  background: #fff;
  border: 1px solid #d7e0db;
  border-radius: 5px;
  display: grid;
  gap: 5px;
  padding: 7px;
}

.bossReceiptPanel[hidden] {
  display: none;
}

.bossReceiptRow {
  align-items: center;
  border-bottom: 1px solid var(--line);
  display: grid;
  gap: 6px;
  grid-template-columns: 78px minmax(0, 1fr) auto;
  min-height: 30px;
}

.bossReceiptRow:last-of-type {
  border-bottom: 0;
}

.bossReceiptRow em {
  color: var(--muted);
  font-style: normal;
  font-weight: 800;
}

#officePage.bossMode .officeDashboard {
  background:
    radial-gradient(circle at 72% -8%, rgba(200, 50, 50, 0.22), transparent 30%),
    linear-gradient(180deg, #25282e 0, #17191d 52%, #111316 100%);
  border-color: #3a3f48;
  box-shadow: 0 24px 76px rgba(0, 0, 0, 0.36);
  color: #f5f7fb;
}

#officePage.bossMode .moduleHeader,
#officePage.bossMode .moduleSummaryHeader {
  background: rgba(20, 22, 26, 0.44);
  border-color: #30343d;
}

#officePage.bossMode .moduleHeader h2,
#officePage.bossMode .moduleSummaryHeader h3 {
  color: #f8fbff;
}

#officePage.bossMode .moduleHeader p,
#officePage.bossMode .moduleEyebrow {
  color: #8f98a8;
}

#officePage.bossMode .moduleStatus,
#officePage.bossMode #officeStatus {
  background: rgba(200, 50, 50, 0.18);
  border-color: rgba(255, 90, 90, 0.44);
  color: #ff7676;
}

#officePage.bossMode .officeContent {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), transparent 190px),
    #17191d;
  border-top: 1px solid rgba(255, 255, 255, 0.035);
  padding: 8px;
}

#officePage.bossMode .bossHero,
#officePage.bossMode .bossProjectCard,
#officePage.bossMode .pugSourceSummary,
#officePage.bossMode .pugProjectLane,
#officePage.bossMode .pugJobCard {
  background: #24272d;
  border-color: #3b4049;
  box-shadow: 0 16px 42px rgba(0, 0, 0, 0.25);
}

#officePage.bossMode .bossHero {
  background:
    linear-gradient(135deg, rgba(200, 50, 50, 0.28), transparent 43%),
    linear-gradient(180deg, #292c33 0, #22252b 100%);
  border-color: rgba(224, 82, 82, 0.36);
}

#officePage.bossMode .bossHero h4,
#officePage.bossMode .bossProjectTop h4,
#officePage.bossMode .pugProjectLaneHeader h3,
#officePage.bossMode .pugJobTop h4,
#officePage.bossMode .pugSourceSummary strong,
#officePage.bossMode .bossJobList strong,
#officePage.bossMode .bossBigStats strong,
#officePage.bossMode .pugHeroStats b,
#officePage.bossMode .pugLaneStats b,
#officePage.bossMode .pugProjectSummary b,
#officePage.bossMode .pugJobStats strong {
  color: #fff;
}

#officePage.bossMode .bossHero p,
#officePage.bossMode .bossProjectTop p,
#officePage.bossMode .bossEmptyLine,
#officePage.bossMode .bossReceiptRow em,
#officePage.bossMode .pugHeroStats span,
#officePage.bossMode .pugLaneStats span,
#officePage.bossMode .pugProjectSummary span,
#officePage.bossMode .pugJobStats em,
#officePage.bossMode .pugJobCard footer {
  color: #9ba2ad;
}

#officePage.bossMode .bossHero > strong {
  color: #ff4d4d;
  font-size: 44px;
  letter-spacing: 0;
}

#officePage.bossMode .bossStatus {
  background: #242831;
  border: 1px solid #303743;
  color: #dce7f7;
}

#officePage.bossMode .bossStatus.current {
  background: rgba(200, 50, 50, 0.18);
  border-color: rgba(255, 90, 90, 0.46);
  color: #ff7676;
}

#officePage.bossMode .bossStatus.check {
  background: rgba(249, 211, 107, 0.16);
  border-color: rgba(249, 211, 107, 0.42);
  color: #ffd866;
}

#officePage.bossMode .bossStatus.empty {
  background: #23262d;
  color: #8f98a8;
}

#officePage.bossMode .bossBigStats div,
#officePage.bossMode .bossDayTile,
#officePage.bossMode .bossJobList,
#officePage.bossMode .bossReceiptPanel,
#officePage.bossMode .bossCompanyTotal,
#officePage.bossMode .pugHeroStats span,
#officePage.bossMode .pugLaneStats span,
#officePage.bossMode .pugProjectSummary span,
#officePage.bossMode .pugJobStats span,
#officePage.bossMode .pugDayDot,
#officePage.bossMode .pugWeekRail {
  background: linear-gradient(180deg, #30333a 0, #292c32 100%);
  border-color: #3b4049;
}

#officePage.bossMode .pugWeekRail button {
  background: #242831;
  border-color: #424a56;
  color: #f5f7fb;
}

#officePage.bossMode .pugWeekRail span {
  color: #9ba2ad;
}

#officePage.bossMode .bossBigStats div {
  border-left: 4px solid #4b515c;
}

#officePage.bossMode .bossBigStats .bossStatHours {
  border-left-color: #ff5a5a;
}

#officePage.bossMode .bossBigStats .bossStatPeople,
#officePage.bossMode .bossBigStats .bossStatJobs,
#officePage.bossMode .bossBigStats .bossStatTrucks {
  border-left-color: #626a76;
}

#officePage.bossMode .bossBigStats span,
#officePage.bossMode .bossDayTile > strong,
#officePage.bossMode .bossCompanyTotal em {
  color: #8f98a8;
}

#officePage.bossMode .bossBigStats .bossStatHours strong {
  color: #ff5a5a;
}

#officePage.bossMode .bossCompanyTotal strong {
  color: #f4f6fa;
}

#officePage.bossMode .bossCompanyTotal.red strong {
  color: #ff5a5a;
}

#officePage.bossMode .bossCompanyTotal.red em {
  color: #ff8383;
}

#officePage.bossMode .bossCompanyTotal.green strong {
  color: #35d06d;
}

#officePage.bossMode .bossCompanyTotal.green em {
  color: #6ee995;
}

#officePage.bossMode .bossCompanyTotal.blue strong {
  color: #5ca2ff;
}

#officePage.bossMode .bossCompanyTotal.blue em {
  color: #8abdff;
}

#officePage.bossMode .bossDayTile > span {
  color: #f8fbff;
}

#officePage.bossMode .bossDayTile.filled {
  border-color: rgba(185, 41, 41, 0.56);
  box-shadow: inset 0 4px 0 #c83232;
}

#officePage.bossMode .pugDayDot.filled {
  background: linear-gradient(180deg, rgba(51, 120, 78, 0.52), rgba(43, 78, 58, 0.72));
  border-color: rgba(81, 202, 124, 0.55);
  color: #f7fbf8;
}

#officePage.bossMode .pugJobCard.current {
  border-top-color: #35d06d;
}

#officePage.bossMode .pugJobCard.check {
  border-top-color: #ffd866;
}

#officePage.bossMode .pugJobCard.empty {
  border-top-color: #ff5a5a;
}

#officePage.bossMode .pugJobCard footer {
  border-color: #343943;
}

#officePage.bossMode .bossCompanyChip {
  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.18);
}

#officePage.bossMode .bossReceiptRow {
  border-color: #30343d;
}

#officePage.bossMode .bossReceiptRow strong,
#officePage.bossMode .bossReceiptRow span {
  color: #f2f5fa;
}

#officePage.bossMode .bossReceiptRow[data-receipt-url] {
  box-shadow: inset 3px 0 0 rgba(255, 90, 90, 0.55);
  cursor: pointer;
}

#officePage.bossMode .bossReceiptRow[data-receipt-url]:hover,
#officePage.bossMode .bossReceiptRow[data-receipt-url]:focus-visible {
  background: #343841;
  box-shadow: inset 4px 0 0 #ff5a5a;
  outline: none;
}

#officePage.bossMode #adminLogoutButton,
#officePage.bossMode .bossReceiptButton {
  background: #2a2e36;
  border-color: #444b56;
  color: #fff;
}

#officePage.bossMode #adminLogoutButton:hover,
#officePage.bossMode #adminLogoutButton:focus-visible,
#officePage.bossMode .bossReceiptButton:hover,
#officePage.bossMode .bossReceiptButton:focus-visible {
  background: rgba(200, 50, 50, 0.22);
  border-color: rgba(255, 90, 90, 0.58);
}

#officePage.bossMode .empty {
  background: linear-gradient(180deg, #30333a 0, #292c32 100%);
  border: 1px solid #3b4049;
  border-radius: 5px;
  color: #aeb5c0;
}

#officePage.bossMode .bossCloseButton {
  background: #252932;
  border-color: #3a404c;
  color: #f7f9fc;
}

@media (min-width: 1600px) {
  body.bossModeActive .shell {
    max-width: none;
    padding: 14px 18px;
  }

  #officePage.bossMode .officeContent {
    gap: 12px;
    padding: 12px;
  }

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

  .pugJobCard {
    min-height: 214px;
  }

  .pugJobTop h4 {
    font-size: 28px;
  }
}

.padded {
  padding: 14px;
}

.entryDialog {
  background: #f7f9f7;
  border: 1px solid rgba(51, 60, 54, 0.18);
  border-radius: 8px;
  box-shadow: 0 28px 80px rgba(14, 20, 18, 0.34);
  max-width: min(420px, calc(100vw - 28px));
  padding: 0;
  width: 420px;
}

.receiptDialog {
  max-width: min(540px, calc(100vw - 28px));
  width: 540px;
}

.receiptPreviewDialog {
  background: #f7f9f7;
  border: 1px solid rgba(51, 60, 54, 0.18);
  border-radius: 8px;
  box-shadow: 0 28px 80px rgba(14, 20, 18, 0.34);
  max-width: min(860px, calc(100vw - 24px));
  padding: 10px;
  width: 860px;
}

.entryDialog,
.receiptPreviewDialog,
.confirmDialog {
  box-sizing: border-box;
  max-height: calc(100vh - 28px);
  max-height: calc(100dvh - 28px);
  overflow: auto;
  overscroll-behavior: contain;
}

.receiptPreviewDialog::backdrop {
  backdrop-filter: blur(10px) saturate(0.9);
  background:
    radial-gradient(circle at 50% 28%, rgba(200, 50, 50, 0.12), transparent 34%),
    rgba(10, 12, 14, 0.64);
}

.confirmDialog {
  background:
    linear-gradient(180deg, #2b3038 0, #1f2329 100%);
  border: 1px solid #454c57;
  border-radius: 8px;
  box-shadow: 0 28px 80px rgba(8, 10, 12, 0.46);
  max-width: min(430px, calc(100vw - 28px));
  padding: 0;
  width: 430px;
}

.confirmDialog::backdrop {
  backdrop-filter: blur(12px) saturate(0.88);
  background:
    radial-gradient(circle at 50% 32%, rgba(200, 50, 50, 0.16), transparent 34%),
    rgba(8, 10, 12, 0.68);
}

.confirmDialogBody {
  display: grid;
  gap: 12px;
  grid-template-columns: 42px minmax(0, 1fr);
  padding: 16px;
}

.confirmIcon {
  align-items: center;
  background: rgba(200, 50, 50, 0.16);
  border: 1px solid rgba(224, 82, 82, 0.42);
  border-radius: 8px;
  color: #ffb4a8;
  display: flex;
  font-size: 22px;
  font-weight: 950;
  height: 42px;
  justify-content: center;
}

.confirmDialog h2 {
  color: #f7f9fc;
  font-size: 19px;
  margin: 0;
}

.confirmDialog p {
  color: #c5ccd6;
  font-weight: 750;
  line-height: 1.42;
  margin: 6px 0 0;
  white-space: pre-line;
}

.confirmDialogDetail {
  color: #ffb9b0 !important;
  font-size: 12px;
}

.confirmDialogActions {
  background: rgba(12, 14, 17, 0.42);
  border-top: 1px solid #3a414b;
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  padding: 10px 12px;
}

.confirmDialogActions button {
  min-width: 112px;
}

.confirmDialogActions #confirmCancelButton {
  background: #343a43;
  border-color: #4b5360;
  color: #eef2f7;
}

.confirmDialogActions #confirmCancelButton:hover,
.confirmDialogActions #confirmCancelButton:focus-visible {
  background: #424a56;
  border-color: #626c7a;
}

.dangerConfirmButton {
  background:
    linear-gradient(180deg, #dc4545 0%, #b62b1e 100%);
  border-color: #e05252;
  box-shadow:
    0 10px 22px rgba(200, 50, 50, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.2);
  color: #fff;
}

.confirmDialog:not(.dangerConfirm) .confirmIcon {
  background: rgba(87, 96, 110, 0.34);
  border-color: rgba(147, 157, 173, 0.46);
  color: #eef2f7;
}

.confirmDialog:not(.dangerConfirm) .dangerConfirmButton {
  background:
    linear-gradient(180deg, #3a414c 0%, #262b33 100%);
  border-color: #586171;
}

.receiptPreviewDialog .dialogHeader {
  grid-template-columns: minmax(0, 1fr) 36px;
  margin-bottom: 8px;
}

.receiptPreviewDialog .dialogHeader h2 {
  text-align: left;
}

.receiptPreviewDialog iframe {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 7px;
  height: min(74vh, 720px);
  width: 100%;
}

.entryDialog::backdrop {
  backdrop-filter: blur(10px) saturate(0.9);
  background:
    radial-gradient(circle at 50% 28%, rgba(200, 50, 50, 0.12), transparent 34%),
    rgba(10, 12, 14, 0.62);
}

dialog[open] {
  animation: dialogEnter 150ms ease-out;
}

dialog[open]::backdrop {
  animation: dialogBackdropEnter 150ms ease-out;
}

@keyframes dialogEnter {
  from {
    opacity: 0;
    transform: translateY(10px) scale(0.985);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes dialogBackdropEnter {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@media (prefers-reduced-motion: reduce) {
  dialog[open],
  dialog[open]::backdrop {
    animation: none;
  }
}

.entryDialog form {
  padding: 0;
}

.dialogHeader,
.dialogActions {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

.dialogHeader {
  background:
    linear-gradient(180deg, #2b3038 0, #20242a 100%);
  border-bottom: 1px solid #414852;
  color: #f7f9fc;
  display: grid;
  gap: 8px;
  grid-template-columns: 36px minmax(0, 1fr) 36px 36px;
  margin-bottom: 0;
  padding: 10px 12px;
}

.dialogHeader h2 {
  align-self: center;
  color: #f7f9fc;
  font-size: 17px;
  text-align: center;
}

.receiptDialog .dialogHeader {
  grid-template-columns: minmax(0, 1fr) 36px;
}

.receiptDialog .dialogHeader h2 {
  text-align: left;
}

.dialogActions {
  background: #eef2ef;
  border-top: 1px solid #d4ddd7;
  gap: 7px;
  justify-content: flex-end;
  margin-top: 2px;
  padding: 10px 12px;
}

.entryDialog form > .field,
.entryDialog form > .proofStatus,
.entryDialog form > .jobChoiceGrid,
.entryDialog form > .receiptValueGrid {
  margin-left: 12px;
  margin-right: 12px;
}

.entryDialog form > .field:first-of-type,
.entryDialog form > .receiptValueGrid:first-of-type {
  margin-top: 12px;
}

.iconButton {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.22);
  border-radius: 50%;
  color: #f7f9fc;
  font-size: 24px;
  height: 36px;
  min-width: 36px;
  padding: 0;
}

.dayNavButton {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.22);
  border-radius: 50%;
  color: #f7f9fc;
  font-size: 22px;
  height: 36px;
  min-width: 36px;
  padding: 0;
}

.receiptValueGrid {
  display: grid;
  gap: 7px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 12px;
}

.receiptValueGrid .field {
  margin-bottom: 0;
}

.receiptWideField {
  grid-column: span 2;
}

.jobChoiceGrid {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.jobChoice {
  background: var(--soft);
  font-weight: 800;
  justify-content: center;
  min-width: 0;
  width: 100%;
}

.jobChoice.selected {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.suggestionList {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 7px;
  box-shadow: 0 14px 30px rgba(20, 35, 28, 0.16);
  display: grid;
  left: 0;
  overflow: hidden;
  position: absolute;
  right: 0;
  top: calc(100% - 4px);
  z-index: 8;
}

.suggestionList[hidden] {
  display: none;
}

.employeeSuggestion {
  border: 0;
  border-bottom: 1px solid var(--line);
  border-radius: 0;
  justify-content: flex-start;
  min-width: 0;
  width: 100%;
}

.employeeSuggestion:last-child {
  border-bottom: 0;
}

@media (max-width: 1180px) {
  .shell {
    max-width: 100%;
    padding: 8px;
  }

  .workspace {
    grid-template-columns: 204px minmax(0, 1fr);
  }

  .review {
    min-height: 462px;
  }

  .tableWrap {
    max-height: min(64vh, 540px);
  }

  .scanQualityBar {
    gap: 5px;
    padding: 4px 6px;
  }

  .scanQualityChip {
    font-size: 9px;
    padding: 0 6px;
  }

  .scanQualityBar button {
    font-size: 10px;
    padding: 0 7px;
  }

  .weeklyScroller {
    max-height: min(44vh, 410px);
  }

  .weeklySummaryStrip,
  .weeklySummaryGrid,
  .weeklySummaryRow {
    gap: 5px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    padding: 6px 8px;
  }

  .weeklySummaryStrip > *,
  .weeklySummaryGrid > *,
  .weeklySummaryRow > *,
  .weeklySummaryCard,
  .weeklySummaryItem,
  .weeklySummaryMetric,
  .weeklyMetricCard {
    min-height: 42px;
    padding: 5px 7px;
  }

  .weeklySummaryStrip :where(span, small, em),
  .weeklySummaryGrid :where(span, small, em),
  .weeklySummaryRow :where(span, small, em),
  .weeklySummaryCard :where(span, small, em),
  .weeklySummaryItem :where(span, small, em),
  .weeklySummaryMetric :where(span, small, em),
  .weeklyMetricCard :where(span, small, em) {
    line-height: 1.12;
    overflow-wrap: anywhere;
    white-space: normal;
  }

  .weeklySummaryStrip .company-hm,
  .weeklySummaryGrid .company-hm,
  .weeklySummaryRow .company-hm {
    border-left-color: #b82929;
  }

  .weeklySummaryStrip .company-alfa,
  .weeklySummaryGrid .company-alfa,
  .weeklySummaryRow .company-alfa {
    border-left-color: #147a3f;
  }

  .weeklySummaryStrip .company-sec,
  .weeklySummaryGrid .company-sec,
  .weeklySummaryRow .company-sec {
    border-left-color: #1f62bd;
  }

  .jobBreakoutGrid {
    gap: 6px;
    grid-template-columns: 1fr;
    padding: 6px;
  }

  .jobBreakoutHeader {
    min-height: 31px;
    padding: 4px 8px;
  }

  .jobBreakoutHeader strong {
    font-size: 17px;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .jobBreakoutTotals {
    gap: 7px;
    padding: 4px 8px;
  }

  .jobCompanyGroups {
    gap: 4px;
    grid-template-columns: minmax(0, 0.96fr) minmax(0, 1.08fr) minmax(0, 0.96fr);
    padding: 4px;
  }

  .jobCompanyGroup {
    height: var(--job-breakout-height);
    max-height: none;
    min-height: 0;
    resize: none;
  }

  .jobCompanyGroup h3 {
    grid-template-columns: minmax(0, 1fr) auto;
    min-height: 32px;
    padding: 5px 7px 4px;
  }

  .jobCompanyGroup h3 > span {
    font-size: 16px;
  }

  .jobCompanyGroup h3 > strong {
    font-size: 13px;
  }

  .jobCompanyGroup h3 > span,
  .jobCompanyGroup h3 > strong,
  .jobCompanyGroup h3 > em {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .jobCompanyGroup h3 > em {
    grid-column: 2;
    justify-content: flex-end;
    justify-self: end;
  }

  .jobEmployeeRow {
    gap: 3px;
    grid-template-columns: minmax(70px, 1fr) minmax(35px, auto) minmax(35px, auto) minmax(48px, auto);
    min-height: 25px;
    padding: 2px 5px;
  }

  .jobEmployeeRow .savedHourMetric {
    font-size: 12px;
    min-width: 0;
    white-space: nowrap;
  }

  .moduleBody {
    gap: 6px;
    padding: 6px 8px 8px;
  }

  .poDashboard .moduleBody {
    grid-template-columns: minmax(0, 1fr) minmax(218px, 0.28fr);
  }

  .poActionGrid {
    grid-template-columns: minmax(230px, 0.78fr) minmax(330px, 1.22fr);
  }

  .poDashboard .primaryModuleAction,
  .poDashboard .jobLinkCard {
    min-height: 52px;
  }

  .poDashboard .primaryModuleAction {
    grid-template-columns: 34px minmax(0, 1fr);
  }

  .poDashboard .moduleIcon {
    font-size: 16px;
    height: 34px;
    width: 34px;
  }

  .poDashboard .primaryModuleAction strong {
    font-size: 14px;
  }

  .poDashboard .primaryModuleAction small,
  .poDashboard .poQueuePanel p {
    font-size: 10px;
    line-height: 1.22;
  }

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

  .poDashboard .receiptDirectory {
    max-height: 172px;
  }

  .poDashboard .receiptDirectoryRow {
    align-items: center;
    grid-template-columns: 52px minmax(0, 1fr) minmax(84px, auto);
  }

  .poDashboard .receiptDirectoryRow .poDirectoryDetails em {
    grid-column: auto;
    justify-self: start;
    white-space: nowrap;
  }

  .summaryCard {
    gap: 4px;
    padding: 5px;
  }

  .truckReceiptPanel {
    grid-template-areas:
      "capture history"
      "reminders history";
    grid-template-columns: minmax(236px, 0.76fr) minmax(300px, 1.24fr);
  }

  .truckReminderPanel {
    grid-column: auto;
  }

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

  .maintenanceChoices button {
    gap: 4px 9px;
    grid-template-columns: 52px minmax(0, 1fr);
    min-height: 96px;
    padding: 9px;
  }

  .maintenanceChoices button > span {
    font-size: 31px;
    height: 52px;
    width: 52px;
  }

  .maintenanceChoices strong {
    font-size: 17px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .maintenanceChoices small {
    font-size: 12px;
    line-height: 1.22;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: normal;
  }

  .receiptHistory {
    padding: 5px;
  }

  .historyRows {
    max-height: min(20vh, 120px);
  }

  .truckReminderPanel {
    padding: 6px 7px;
  }

  .truckReminderPanel strong {
    font-size: 13px;
  }

  .officeMetricGrid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .officeMetricGrid > div {
    min-height: 50px;
  }

  .officeMetricGrid span,
  .officeMetricGrid strong {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .betaSheetHero {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .betaSheetHeroStats {
    grid-column: 1 / -1;
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .officeSection {
    gap: 5px;
    padding: 6px;
  }

  .officeTable {
    min-width: 840px;
  }

  .officeTable td {
    height: 26px;
    padding: 2px 5px;
  }

  .officeTable th {
    height: 26px;
    padding: 2px 5px;
  }

  .directoryGrid {
    gap: 3px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-height: 188px;
    padding: 4px;
  }

  .directoryRow {
    grid-template-columns: minmax(0, 1fr) minmax(0, 104px);
    min-height: 25px;
    padding: 2px 5px;
  }

  .officeJobGrid {
    grid-template-columns: repeat(auto-fit, minmax(min(360px, 100%), 1fr));
  }

  .officeBoardGrid {
    max-height: 220px;
  }

  .officeJobCard {
    gap: 5px;
    padding: 6px;
  }

  .officeJobStats {
    gap: 3px;
  }

  .officeMiniRows {
    max-height: 126px;
  }

  .saveApprovedWrap {
    min-width: 250px;
  }

  .bossHero {
    padding: 10px;
  }

  .bossHero > strong {
    font-size: 28px;
  }

  #officePage.bossMode .bossHero > strong {
    font-size: 34px;
  }

  .bossProjectCard {
    gap: 7px;
    padding: 8px;
  }

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

  .bossBigStats div {
    padding: 5px 6px;
  }

  .bossDayTile {
    min-height: 58px;
    padding: 5px;
  }

  .bossReceiptRow {
    grid-template-columns: 70px minmax(0, 1fr) auto;
  }

  .pugHeroStats {
    min-width: 0;
  }

  .pugSourceSummary {
    grid-template-columns: 1fr;
  }

  .pugProjectLaneHeader {
    align-items: stretch;
    flex-direction: column;
  }

  .pugLaneStats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    min-width: 0;
  }

  .pugLaneStats span {
    min-width: 0;
  }
}

@media (max-width: 860px) {
  .shell {
    padding: 10px;
  }

  .workspace,
  .appHeader {
    grid-template-columns: 1fr;
  }

  .appHeader {
    align-items: stretch;
    flex-direction: column;
  }

  .headerActions {
    align-items: stretch;
    flex-direction: column;
  }

  .pageTabs {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .pageTabs button {
    min-width: 0;
  }

  .officeAccessButton {
    width: 100%;
  }

  .quickAddButton {
    width: 100%;
  }

  .workspace {
    display: grid;
  }

  .tableWrap {
    max-height: 56vh;
    min-height: 270px;
  }

  th {
    height: 38px;
  }

  td {
    height: 42px;
  }

  td input {
    height: 34px;
  }

  .approvalBox {
    height: 36px;
  }

  .approvalBox span {
    height: 29px;
    width: 29px;
  }

  .side {
    order: 2;
  }

  .savedRow {
    gap: 4px;
    grid-template-columns: 1fr;
    padding: 9px 14px;
  }

  .weeklyPersonRow {
    gap: 8px;
  }

  .weeklySummaryStrip,
  .weeklySummaryGrid,
  .weeklySummaryRow {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .jobBreakoutGrid {
    grid-template-columns: 1fr;
  }

  .moduleHeader {
    align-items: stretch;
    flex-direction: column;
  }

  .poActionGrid,
  .truckReceiptPanel,
  .officeLock,
  .betaSheetHero {
    grid-template-areas: none;
    grid-template-columns: 1fr;
  }

  .betaSheetHero > strong {
    justify-self: start;
  }

  .betaSheetHeroStats {
    grid-column: auto;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .truckReceiptPanel > .receiptHistory,
  .truckReceiptPanel > .maintenancePrimaryAction,
  .truckReceiptPanel > .truckReminderPanel {
    grid-area: auto;
  }

  .poDashboard .moduleBody {
    grid-template-columns: 1fr;
  }

  .poDashboard .poActionGrid,
  .poDashboard .moduleSummaryHeader,
  .poDashboard .poSummaryGrid,
  .poDashboard .receiptList {
    grid-column: auto;
    grid-row: auto;
  }

  .receiptDirectory {
    max-height: 220px;
  }

  .poDashboard .receiptDirectoryRow {
    grid-template-columns: 58px minmax(0, 1fr) minmax(78px, auto);
  }

  .poSummaryGrid,
  .maintenanceChoices,
  .officeMetricGrid,
  .officeJobTotalGrid,
  .bossProjectGrid,
  .companySavedGrid,
  .jobCompanyGroups,
  .directoryGrid {
    grid-template-columns: 1fr 1fr;
  }

  .officeSectionHeader {
    align-items: stretch;
    flex-direction: column;
  }

  .officeSectionHeader > strong,
  .officeSectionAction {
    align-self: start;
    justify-self: start;
    text-align: left;
  }

  .officeJobGrid {
    grid-template-columns: 1fr;
  }

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

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

  .receiptListRow,
  .historyRow {
    align-items: start;
    grid-template-columns: 78px minmax(0, 1fr);
  }

  .receiptListRow em,
  .historyRow em {
    grid-column: 2;
    white-space: normal;
  }

  .historyRow {
    grid-template-columns: 54px minmax(0, 1fr);
  }

  .maintenanceChoices button {
    grid-template-columns: 74px minmax(0, 1fr);
    min-height: 124px;
    padding: 11px;
  }

  .maintenanceChoices button > span {
    font-size: 42px;
    height: 74px;
    width: 74px;
  }

  .maintenanceChoices strong {
    font-size: 16px;
  }

  .maintenancePrimaryAction {
    grid-template-columns: 50px minmax(0, 1fr);
    min-height: 76px;
    padding: 8px;
  }

  .maintenancePrimaryAction .moduleIcon {
    font-size: 29px;
    height: 50px;
    width: 50px;
  }

  .maintenancePrimaryAction strong {
    font-size: 17px;
  }

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

@media (max-width: 1180px) and (max-height: 820px) {
  .appHeader {
    margin-bottom: 8px;
  }

  .review {
    min-height: 430px;
  }

  .tableWrap {
    max-height: min(58vh, 456px);
    min-height: 284px;
  }

  .entryDialog,
  .receiptPreviewDialog,
  .confirmDialog {
    max-height: calc(100vh - 18px);
    max-height: calc(100dvh - 18px);
  }

  .receiptPreviewDialog iframe {
    height: min(68vh, 620px);
  }
}

@media (max-width: 520px) {
  .shell {
    padding: 7px;
  }

  .brandIcon {
    height: 38px;
    width: 38px;
  }

  .cameraCopy h2 {
    font-size: 24px;
  }

  .primaryPhoto {
    min-height: 112px;
    width: 188px;
  }

  .primaryPhoto::before {
    font-size: 46px;
  }

  .primaryPhoto span::after {
    font-size: 18px;
  }

  .secondaryPhoto {
    min-height: 50px;
  }

  .tableHeader,
  .sheetHeader {
    align-items: flex-start;
    flex-direction: column;
    padding: 8px 10px;
  }

  .scanPager {
    grid-column: 1 / -1;
    width: 100%;
  }

  .scanStatusHeader {
    grid-template-columns: 1fr auto;
  }

  .scanTools {
    justify-self: start;
  }

  .sheetActions {
    align-items: stretch;
    flex-direction: column;
    width: 100%;
  }

  .scanDayBanner {
    align-items: flex-start;
    grid-template-columns: 1fr;
    min-height: 0;
    padding: 7px 10px;
  }

  .scanDayBanner [data-scan-title] {
    font-size: 19px;
  }

  .scanBannerMeta {
    justify-content: flex-start;
  }

  .scanDayBanner small {
    text-align: left;
  }

  .scanDateOverride {
    justify-self: stretch;
    width: 100%;
  }

  .scanDateOverride span {
    text-align: left;
  }

  .scanQualityBar {
    align-items: stretch;
    grid-template-columns: 1fr;
  }

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

  .scanQualityChip {
    justify-content: space-between;
    width: 100%;
  }

  .scanQualityChip.total {
    grid-column: 1 / -1;
  }

  .scanQualityActions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .scanQualityBar button {
    width: 100%;
  }

  #scanPageLabel {
    flex: 1;
  }

  .sheetHeader button,
  .tableHeader > button {
    width: 100%;
  }

  .scanPager button,
  .scanTools button,
  .iconRefreshButton,
  .sheetHeader .weeklyTopRefreshButton {
    width: auto;
  }

  .reviewActions {
    flex-direction: column;
    padding: 8px 10px 10px;
  }

  .saveApprovedWrap {
    align-items: stretch;
    justify-items: stretch;
    min-width: 0;
    width: 100%;
  }

  .saveApprovedWrap span {
    max-width: none;
    text-align: center;
  }

  .saveRequirements {
    gap: 4px;
    grid-template-columns: 1fr;
    justify-content: stretch;
    max-width: none;
  }

  .emptyScanRow td {
    height: 240px;
  }

  .emptyScanPrompt {
    padding: 20px 14px;
    width: calc(100vw - 18px);
  }

  .emptyScanPrompt strong {
    font-size: 21px;
  }

  .emptyScanPrompt span,
  .emptyScanPrompt li {
    font-size: 14px;
  }

  .scanReviewButton {
    justify-content: center;
    min-width: 0;
    width: 100%;
  }

  .weeklyTable {
    min-width: calc(210px + (var(--week-columns) * 92px));
  }

  .weeklySummaryStrip,
  .weeklySummaryGrid,
  .weeklySummaryRow {
    gap: 5px;
    grid-template-columns: 1fr;
    padding: 6px 7px;
  }

  .weeklySummaryStrip > *,
  .weeklySummaryGrid > *,
  .weeklySummaryRow > *,
  .weeklySummaryCard,
  .weeklySummaryItem,
  .weeklySummaryMetric,
  .weeklyMetricCard {
    min-height: 38px;
    padding: 5px 7px;
  }

  .weeklyHeaderRow,
  .weeklyRowSheet {
    grid-template-columns: minmax(118px, 144px) repeat(var(--week-columns), minmax(92px, 1fr)) 66px !important;
  }

  .weeklyHeaderRow > span,
  .weeklyRowSheet > .employeeName,
  .weeklyRowSheet > .weekTotal,
  .weeklyEmpty > strong,
  .weeklyEmpty > span,
  .dayHead {
    min-height: 34px;
    padding: 5px 6px;
  }

  .dayCell {
    min-height: 56px;
    padding: 5px;
  }

  .dayCell:has(.dayProofBadge),
  .dayCell:has(.manualProofBadge) {
    padding-top: 27px;
  }

  .dayCell.filledCell:has(.dayCellAction) {
    padding-top: 5px;
  }

  .dayCellEntry {
    min-height: 36px;
    padding-right: 28px;
  }

  .dayCellAction {
    height: 21px;
    max-width: 46px;
    min-width: 22px;
    padding: 0 5px;
  }

  .dayProofBadge,
  .manualProofBadge,
  .scanProofBadge {
    font-size: 9px;
    min-height: 19px;
    padding: 0 5px;
  }

  .saveScanButton {
    min-height: 42px;
    width: 100%;
  }

  .moduleBody {
    padding: 8px;
  }

  .moduleHeader {
    padding: 9px 8px;
  }

  .primaryModuleAction,
  .receiptCaptureCard {
    grid-template-columns: 42px minmax(0, 1fr);
    min-height: 0;
    padding: 8px;
  }

  .primaryModuleAction strong,
  .receiptCaptureCard strong {
    font-size: 16px;
  }

  .moduleIcon {
    font-size: 18px;
    height: 42px;
    width: 42px;
  }

  .maintenancePrimaryAction {
    gap: 8px;
    grid-template-columns: 48px minmax(0, 1fr);
    min-height: 70px;
    padding: 8px;
  }

  .maintenancePrimaryAction .moduleIcon {
    font-size: 28px;
    height: 48px;
    width: 48px;
  }

  .maintenancePrimaryAction strong {
    font-size: 17px;
  }

  .maintenancePrimaryAction small {
    font-size: 11px;
  }

  .moduleSummaryHeader {
    align-items: stretch;
    flex-direction: column;
  }

  .moduleSummaryHeader button {
    width: 100%;
  }

  #copyPoDirectoryButton {
    width: 100%;
  }

  .maintenanceDashboard .moduleSummaryHeader {
    align-items: center;
    flex-direction: row;
  }

  .maintenanceDashboard .moduleSummaryHeader button {
    min-width: 92px;
    width: auto;
  }

  .miniButtonGroup {
    width: auto;
  }

  .poDashboard .receiptDirectoryRow {
    align-items: start;
    grid-template-columns: 56px minmax(0, 1fr);
  }

  .poDashboard .receiptDirectoryRow strong {
    white-space: normal;
  }

  .poDashboard .receiptDirectoryRow em {
    grid-column: 2;
    justify-self: start;
    white-space: normal;
  }

  .poDashboard .receiptDirectoryRow .poStatusChips {
    grid-column: 2;
    justify-content: flex-start;
    justify-self: start;
  }

  .poDashboard .poQueueCard {
    grid-template-columns: minmax(58px, auto) minmax(0, 1fr);
  }

  .poDashboard .poQueueCard .poStatusChips {
    grid-column: 2;
    justify-content: flex-start;
  }

  .sourcePoButton .poStatusChips {
    justify-content: flex-start;
  }

  .poQueueList > .sourcePoButton {
    grid-template-columns: 1fr;
  }

  .poSummaryGrid,
  .maintenanceChoices,
  .officeMetricGrid,
  .betaSheetHeroStats,
  .officeJobTotalGrid,
  .bossProjectGrid,
  .companySavedGrid,
  .jobCompanyGroups,
  .officeJobGrid,
  .directoryGrid,
  .officeJobStats,
  .officeBoardGrid,
  .officeBoardStats,
  .officeBoardCompanies,
  .bossBigStats {
    grid-template-columns: 1fr;
  }

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

  .jobBreakoutHeader {
    grid-template-columns: 1fr;
  }

  .jobBreakoutHeader em {
    justify-self: start;
  }

  .savedHourMetric {
    gap: 3px;
  }

  .maintenanceChoices {
    gap: 9px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .maintenanceChoices button {
    align-content: start;
    gap: 8px;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    justify-items: center;
    min-height: 142px;
    padding: 10px 8px;
    text-align: center;
  }

  .maintenanceChoices button > span {
    font-size: 44px;
    grid-row: auto;
    height: 72px;
    width: 72px;
  }

  .maintenanceChoices strong {
    font-size: 18px;
  }

  .maintenanceChoices small {
    font-size: 11px;
    line-height: 1.2;
  }

  .receiptValueGrid {
    grid-template-columns: 1fr;
  }

  .receiptWideField {
    grid-column: auto;
  }

  .receiptDialog {
    max-width: min(420px, calc(100vw - 18px));
  }

  .entryDialog,
  .receiptDialog,
  .confirmDialog {
    max-width: calc(100vw - 14px);
    width: calc(100vw - 14px);
  }

  .confirmDialogBody {
    gap: 12px;
    grid-template-columns: 36px minmax(0, 1fr);
    padding: 14px;
  }

  .confirmIcon {
    font-size: 20px;
    height: 36px;
  }

  .confirmDialogActions {
    padding: 10px;
  }

  .receiptDialog .dialogActions {
    align-items: stretch;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .receiptDialog .dialogActions button {
    min-width: 0;
    width: 100%;
  }

  .receiptDialog .secondaryProofButton {
    margin-right: 0;
  }

  .bossHero,
  .bossProjectTop {
    align-items: stretch;
    flex-direction: column;
  }

  .bossHero > strong {
    font-size: 28px;
  }

  #officePage.bossMode .bossHero > strong {
    font-size: 32px;
  }

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

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

  .receiptListRow,
  .historyRow {
    grid-template-columns: 1fr;
  }

  .receiptListRow em,
  .historyRow em {
    grid-column: auto;
  }
}

/* Alpha graphite facelift: shared dark operations cockpit styling. */
body:not(.appLocked) {
  color-scheme: dark;
  background:
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.035) 0 1px, transparent 1px 8px),
    radial-gradient(circle at 88% -8%, rgba(200, 50, 50, 0.22), transparent 28%),
    linear-gradient(180deg, #343840 0, #22262c 320px, #171a1f 100%);
  color: #eef2f7;
}

body:not(.appLocked) .shell {
  background: transparent;
}

body:not(.appLocked) .brand h1,
body:not(.appLocked) .moduleHeader h2,
body:not(.appLocked) .sheetHeader h2,
body:not(.appLocked) .tableHeader span,
body:not(.appLocked) h2,
body:not(.appLocked) h3,
body:not(.appLocked) h4 {
  color: #f7f9fc;
}

body:not(.appLocked) #statusText,
body:not(.appLocked) .moduleHeader p,
body:not(.appLocked) .hint,
body:not(.appLocked) .moduleEyebrow,
body:not(.appLocked) .weeklySummaryMetric span,
body:not(.appLocked) .weeklySummaryItem span {
  color: #aeb6c3;
}

body:not(.appLocked) .pageTabs,
body:not(.appLocked) .officeAccessButton {
  background: rgba(32, 36, 43, 0.94);
  border-color: #444b56;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.26);
}

body:not(.appLocked) .tabButton,
body:not(.appLocked) .officeAccessButton {
  color: #e9eef5;
}

body:not(.appLocked) .tabButton:not(.active),
body:not(.appLocked) .officeAccessButton:not(.active) {
  background: #292e36;
  border-color: #3c434e;
}

body:not(.appLocked) .tabButton:not(.active):hover,
body:not(.appLocked) .tabButton:not(.active):focus-visible,
body:not(.appLocked) .officeAccessButton:not(.active):hover,
body:not(.appLocked) .officeAccessButton:not(.active):focus-visible {
  background: #343a44;
  border-color: #59616f;
}

body:not(.appLocked) .tabButton.active,
body:not(.appLocked) .officeAccessButton.active {
  background: linear-gradient(180deg, #d34747 0, #af272b 100%);
  border-color: #e45a5a;
  color: #fff;
}

body:not(.appLocked) .panel,
body:not(.appLocked) .modulePage,
body:not(.appLocked) .poDashboard,
body:not(.appLocked) .maintenanceDashboard,
body:not(.appLocked) .officeDashboard,
body:not(.appLocked) .weeklySheet,
body:not(.appLocked) .saved {
  background: linear-gradient(180deg, #262a31 0, #20242a 100%);
  border-color: #3b424d;
  box-shadow: 0 20px 52px rgba(0, 0, 0, 0.22);
  color: #eef2f7;
}

body:not(.appLocked) .pageView > .panel {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

body:not(.appLocked) .pageView > .panel > .sheetHeader,
body:not(.appLocked) .pageView > .panel > .moduleHeader {
  background: transparent;
  border-color: rgba(255, 255, 255, 0.08);
  padding-left: 4px;
  padding-right: 4px;
}

body:not(.appLocked) .pageView > .modulePage .moduleBody,
body:not(.appLocked) .pageView > .officeDashboard .officeContent {
  background: transparent;
}

body:not(.appLocked) .side,
body:not(.appLocked) .moduleBody,
body:not(.appLocked) .officeContent {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), transparent 170px),
    #1e2228;
}

body:not(.appLocked) .moduleHeader,
body:not(.appLocked) .sheetHeader,
body:not(.appLocked) .tableHeader,
body:not(.appLocked) .reviewActions,
body:not(.appLocked) .moduleSummaryHeader {
  background: rgba(18, 20, 24, 0.42);
  border-color: #343b45;
}

body:not(.appLocked) .pageView > .panel > .sheetHeader,
body:not(.appLocked) .pageView > .panel > .moduleHeader,
body:not(.appLocked) .pageView > .modulePage .moduleBody,
body:not(.appLocked) .pageView > .officeDashboard .officeContent {
  background: transparent;
}

body:not(.appLocked) select,
body:not(.appLocked) input,
body:not(.appLocked) textarea {
  background: #171a1f;
  border-color: #48505d;
  color: #f3f6fa;
}

body:not(.appLocked) select:focus,
body:not(.appLocked) input:focus,
body:not(.appLocked) textarea:focus {
  border-color: #e05252;
  box-shadow: 0 0 0 3px rgba(200, 50, 50, 0.2);
  outline: none;
}

body:not(.appLocked) button:not(.tabButton):not(.officeAccessButton):not(.savedProofButton):not(.dayCellAction):not(.dayCellDelete) {
  background: #2b3038;
  border-color: #4a5260;
  color: #f5f7fb;
}

body:not(.appLocked) button:not(.tabButton):not(.officeAccessButton):not(.savedProofButton):not(.dayCellAction):not(.dayCellDelete):hover,
body:not(.appLocked) button:not(.tabButton):not(.officeAccessButton):not(.savedProofButton):not(.dayCellAction):not(.dayCellDelete):focus-visible {
  background: #363d48;
  border-color: #626b78;
}

body:not(.appLocked) .quickAddButton,
body:not(.appLocked) .saveScanButton,
body:not(.appLocked) .primaryModuleAction,
body:not(.appLocked) .officeActionPrimary,
body:not(.appLocked) .officeLogin button,
body:not(.appLocked) .officeRowActions button:first-child {
  background: linear-gradient(180deg, #d34747 0, #b7292d 100%) !important;
  border-color: #e05252 !important;
  box-shadow: 0 10px 24px rgba(200, 50, 50, 0.18);
  color: #fff !important;
}

body:not(.appLocked) .moduleStatus,
body:not(.appLocked) .statusPill.ready {
  background: rgba(200, 50, 50, 0.16);
  border-color: rgba(255, 90, 90, 0.42);
  color: #ff8a8a;
}

body:not(.appLocked) .weeklySummaryStrip > *,
body:not(.appLocked) .weeklySummaryGrid > *,
body:not(.appLocked) .weeklySummaryRow > *,
body:not(.appLocked) .weeklySummaryCard,
body:not(.appLocked) .weeklySummaryItem,
body:not(.appLocked) .weeklySummaryMetric,
body:not(.appLocked) .weeklyMetricCard,
body:not(.appLocked) .jobBreakoutCard,
body:not(.appLocked) .jobLinkCard,
body:not(.appLocked) .summaryCard,
body:not(.appLocked) .receiptCaptureCard,
body:not(.appLocked) .receiptHistory,
body:not(.appLocked) .truckReminderPanel,
body:not(.appLocked) .officeLock,
body:not(.appLocked) .betaSheetHero,
body:not(.appLocked) .officeDetails,
body:not(.appLocked) .officeSection,
body:not(.appLocked) .officeMetricGrid > div,
body:not(.appLocked) .betaSheetHeroStats span,
body:not(.appLocked) .officeJobTotalCard,
body:not(.appLocked) .officeJobCard,
body:not(.appLocked) .scanAuditCard,
body:not(.appLocked) .officeBoardCard,
body:not(.appLocked) .officeBoardStats span,
body:not(.appLocked) .officeBoardDay,
body:not(.appLocked) .officeBoardCompany,
body:not(.appLocked) .officeBoardMuted,
body:not(.appLocked) .bossHero,
body:not(.appLocked) .bossProjectCard,
body:not(.appLocked) .bossBigStats div,
body:not(.appLocked) .bossDayTile,
body:not(.appLocked) .bossJobList,
body:not(.appLocked) .bossReceiptPanel,
body:not(.appLocked) .bossCompanyTotal,
body:not(.appLocked) .officeNote {
  background: linear-gradient(180deg, #2c3038 0, #252932 100%);
  border-color: #3d444f;
  color: #eef2f7;
}

body:not(.appLocked) .weeklySummaryStrip {
  background: rgba(18, 20, 24, 0.58);
  border-color: #343b45;
}

body:not(.appLocked) .betaSheetHero > strong {
  color: #ff5a5a;
}

body:not(.appLocked) .officeDetails summary {
  border-color: #343b45;
}

body:not(.appLocked) .officeDetails summary::before {
  color: #ff7777;
}

body:not(.appLocked) .officeSubSection + .officeSubSection,
body:not(.appLocked) .officeBoardCard footer {
  border-color: #343b45;
}

body:not(.appLocked) .officeBoardCard.current {
  border-top-color: #35d06d;
}

body:not(.appLocked) .officeBoardCard.check {
  border-top-color: #ffd866;
}

body:not(.appLocked) .officeBoardCard.empty {
  border-top-color: #ff5a5a;
}

body:not(.appLocked) .officeBoardDay.filled {
  border-color: rgba(62, 173, 111, 0.36);
  box-shadow: inset 0 3px 0 #35d06d;
}

body:not(.appLocked) .officeBoardStatus {
  background: #242830;
  border-color: #3a414b;
  color: #dce7f7;
}

body:not(.appLocked) .officeBoardStatus.current {
  background: rgba(62, 173, 111, 0.15);
  border-color: rgba(62, 173, 111, 0.36);
  color: #83dda7;
}

body:not(.appLocked) .officeBoardStatus.check {
  background: rgba(249, 211, 107, 0.14);
  border-color: rgba(249, 211, 107, 0.36);
  color: #f5d57f;
}

body:not(.appLocked) .officeBoardStatus.empty {
  background: rgba(211, 71, 71, 0.16);
  border-color: rgba(224, 82, 82, 0.42);
  color: #ffadad;
}

body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock {
  background: transparent;
  border-color: #3a414b;
  box-shadow: none;
  color: #eef2f7;
}

body:not(.appLocked) .weeklySummaryStrip .weeklySummaryLabel,
body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock em {
  color: #aeb6c3;
}

body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock strong {
  color: #f6f8fb;
}

body:not(.appLocked) .weeklySummaryPill {
  background: #242932;
  border-color: #3f4651;
  color: #d9e0e8;
}

body:not(.appLocked) .weeklySummaryPill b {
  color: #f6f8fb;
}

body:not(.appLocked) .weeklySummaryPill.company-hm b {
  color: #ff7777;
}

body:not(.appLocked) .weeklySummaryPill.company-alfa b {
  color: #51d586;
}

body:not(.appLocked) .weeklySummaryPill.company-sec b {
  color: #75a7ff;
}

body:not(.appLocked) .weeklyProgress {
  background: #343b45;
}

body:not(.appLocked) .weeklyProgress span {
  background: linear-gradient(90deg, #c83232, #51d586);
}

body:not(.appLocked) .jobBreakoutCard {
  background: rgba(28, 32, 39, 0.7);
  border-color: #303743;
  box-shadow: none;
}

body:not(.appLocked) .jobBreakoutTotals {
  background: rgba(11, 13, 16, 0.24);
  border-color: #303743;
}

body:not(.appLocked) .jobCompanyGroups {
  padding: 4px 0 0;
}

body:not(.appLocked) .jobBreakoutResizeBar::before {
  background: #6f7885;
}

body:not(.appLocked) .jobBreakoutResizeBar:hover::before,
body:not(.appLocked) .jobBreakoutResizeBar:focus-visible::before,
body:not(.appLocked) .resizingJobBreakout .jobBreakoutResizeBar::before {
  background: #e05252;
}

body:not(.appLocked) .receiptHistory,
body:not(.appLocked) .jobLinkCard,
body:not(.appLocked) .truckReminderPanel,
body:not(.appLocked) .truckOwnerDirectory,
body:not(.appLocked) .truckOwnerRow,
body:not(.appLocked) .officeSection {
  box-shadow: none;
}

body:not(.appLocked) .poDashboard .moduleSummaryHeader,
body:not(.appLocked) .receiptHistory .moduleSummaryHeader {
  background: transparent;
  border-color: rgba(255, 255, 255, 0.08);
  padding-left: 0;
  padding-right: 0;
}

body:not(.appLocked) .sourceReceiptRow,
body:not(.appLocked) .sourcePoCard {
  border-left-color: #d34747;
}

body:not(.appLocked) .sourcePoButton {
  background: #242830;
  border-color: #3a414b;
  color: #edf1f6;
  min-height: 37px;
  min-width: 0;
  transition:
    background-color 140ms ease,
    border-color 140ms ease,
    box-shadow 140ms ease,
    transform 120ms ease;
}

body:not(.appLocked) .sourceExampleBar button {
  background: #242830;
  border-color: #3a414b;
  color: #edf1f6;
  border-left: 4px solid #8f9aa7;
  border-radius: 9px;
  display: grid;
  gap: 5px;
  min-width: 0;
  padding: 8px 9px;
  position: relative;
  text-align: left;
  transition:
    background-color 140ms ease,
    border-color 140ms ease,
    border-left-color 140ms ease,
    box-shadow 140ms ease,
    transform 120ms ease;
}

body:not(.appLocked) .sourcePoButton:hover,
body:not(.appLocked) .sourcePoButton:focus-visible,
body:not(.appLocked) .sourceExampleBar button:hover,
body:not(.appLocked) .sourceExampleBar button:focus-visible {
  background: #2d333d;
  border-color: #57606d;
  border-left-color: #d34747;
  box-shadow:
    0 10px 24px rgba(0, 0, 0, 0.24),
    inset 4px 0 0 rgba(211, 71, 71, 0.4);
  transform: translateY(-1px);
}

body:not(.appLocked) .sourcePoButton:focus-visible,
body:not(.appLocked) .sourceExampleBar button:focus-visible {
  outline: 2px solid rgba(211, 71, 71, 0.55);
  outline-offset: 2px;
}

body:not(.appLocked) .sourcePoButton:active,
body:not(.appLocked) .sourceExampleBar button:active {
  transform: translateY(0);
  box-shadow: none;
}

body:not(.appLocked) .sourcePoNumber,
body:not(.appLocked) .sourcePoText strong,
body:not(.appLocked) .sourceExampleBar strong {
  color: #fff;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

body:not(.appLocked) .sourcePoText em,
body:not(.appLocked) .sourceExampleBar span {
  color: #a5aebc;
}

body:not(.appLocked) .sourcePoText em,
body:not(.appLocked) .sourcePoText strong,
body:not(.appLocked) .sourceExampleBar button span,
body:not(.appLocked) .sourceExampleBar button strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

body:not(.appLocked) .sourcePoText em,
body:not(.appLocked) .sourceExampleBar button span {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  line-height: 1.15;
  max-width: 100%;
  white-space: normal;
}

body:not(.appLocked) .sourcePoText em {
  overflow-wrap: anywhere;
}

body:not(.appLocked) .sourceExampleBar {
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 8px;
}

body:not(.appLocked) .sourceExampleBar button strong {
  font-size: 13px;
  font-weight: 950;
}

body:not(.appLocked) .sourceExampleBar button span {
  color: #d4dde8;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

body:not(.appLocked) .poStatusChip {
  background: #1b1f25;
  border-color: #434a55;
  color: #cfd6df;
}

body:not(.appLocked) .poStatusChip.source {
  background: rgba(211, 71, 71, 0.16);
  border-color: rgba(224, 82, 82, 0.42);
  color: #ffadad;
}

body:not(.appLocked) .poStatusChip.monthly,
body:not(.appLocked) .poStatusChip.hold,
body:not(.appLocked) .poStatusChip.missing {
  background: rgba(249, 211, 107, 0.14);
  border-color: rgba(249, 211, 107, 0.36);
  color: #f5d57f;
}

body:not(.appLocked) .poStatusChip.review {
  background: rgba(211, 71, 71, 0.16);
  border-color: rgba(224, 82, 82, 0.42);
  color: #ffadad;
}

body:not(.appLocked) .poStatusChip.active,
body:not(.appLocked) .poStatusChip.ready,
body:not(.appLocked) .poStatusChip.approved {
  background: rgba(62, 173, 111, 0.15);
  border-color: rgba(62, 173, 111, 0.36);
  color: #83dda7;
}

body:not(.appLocked) .poStatusChip.action {
  background: #d34747;
  border-color: #e05252;
  color: #fff;
}

body:not(.appLocked) .truckOwnerDirectoryHeader strong,
body:not(.appLocked) .truckOwnerRow strong {
  color: #edf1f6;
}

body:not(.appLocked) .truckOwnerDirectoryHeader em,
body:not(.appLocked) .truckOwnerRow em {
  color: #9fa8b5;
}

body:not(.appLocked) .weeklyHeaderRow,
body:not(.appLocked) .jobBreakoutHeader,
body:not(.appLocked) .officeTable th {
  background: linear-gradient(180deg, #171a1f 0, #111317 100%);
  border-color: #3a414b;
  color: #cfd6df;
}

body:not(.appLocked) .weeklyRowSheet > .employeeName,
body:not(.appLocked) .weeklyRowSheet > .weekTotal,
body:not(.appLocked) .dayCell,
body:not(.appLocked) .entryPill,
body:not(.appLocked) .officeTableWrap,
body:not(.appLocked) .officeTable tbody tr,
body:not(.appLocked) .receiptList,
body:not(.appLocked) .historyRows,
body:not(.appLocked) .receiptListRow,
body:not(.appLocked) .historyRow,
body:not(.appLocked) .poQueueList > *,
body:not(.appLocked) .summaryCard dl div,
body:not(.appLocked) .directoryGrid,
body:not(.appLocked) .directoryRow,
body:not(.appLocked) .officeMiniRows > div {
  background: #242830;
  border-color: #3a414b;
  color: #edf1f6;
}

body:not(.appLocked) .officeTable tbody tr:nth-child(even),
body:not(.appLocked) .dayCell:hover,
body:not(.appLocked) .dayCell:focus-visible,
body:not(.appLocked) .receiptListRow[data-receipt-url]:hover,
body:not(.appLocked) .historyRow[data-receipt-url]:hover,
body:not(.appLocked) .officeTable tr[data-receipt-url]:hover {
  background: #2d333d;
}

body:not(.appLocked) .dayCell.partialDay,
body:not(.appLocked) .statusPill.hold,
body:not(.appLocked) .statusPill.missing,
body:not(.appLocked) .truckReminderPanel.urgent,
body:not(.appLocked) .officeTable tbody tr.officeRowDirty {
  background: rgba(249, 211, 107, 0.14);
  border-color: rgba(249, 211, 107, 0.36);
}

body:not(.appLocked) .statusPill.review {
  background: rgba(211, 71, 71, 0.16);
  color: #ffadad;
}

body:not(.appLocked) .statusPill.approved {
  background: rgba(62, 173, 111, 0.15);
  color: #83dda7;
}

body:not(.appLocked) .statusPill.draft,
body:not(.appLocked) .empty,
body:not(.appLocked) .smallEmpty,
body:not(.appLocked) .jobBreakoutEmpty,
body:not(.appLocked) .emptyCompanyRow {
  background: #22262d;
  border-color: #3a414b;
  color: #9fa8b5;
}

body:not(.appLocked) .weeklySummaryMetric strong,
body:not(.appLocked) .weeklySummaryItem strong,
body:not(.appLocked) .weeklySelectPrompt strong,
body:not(.appLocked) .jobBreakoutEmpty strong,
body:not(.appLocked) .primaryModuleAction strong,
body:not(.appLocked) .receiptCaptureCard strong,
body:not(.appLocked) .maintenanceChoices strong,
body:not(.appLocked) .truckReminderPanel strong,
body:not(.appLocked) .officeLock strong,
body:not(.appLocked) .betaSheetHero h4,
body:not(.appLocked) .betaSheetHeroStats b,
body:not(.appLocked) .officeSectionHeader h4,
body:not(.appLocked) .officeSectionHeader > strong,
body:not(.appLocked) .officeDetails summary span,
body:not(.appLocked) .officeDetails summary strong,
body:not(.appLocked) .officeMetricGrid strong,
body:not(.appLocked) .officeJobTotalCard strong,
body:not(.appLocked) .officeJobTotalCard em,
body:not(.appLocked) .officeJobTop h5,
body:not(.appLocked) .officeJobStats strong,
body:not(.appLocked) .scanAuditCard h5,
body:not(.appLocked) .officeBoardCardTop h5,
body:not(.appLocked) .officeBoardStats strong,
body:not(.appLocked) .officeBoardDay b,
body:not(.appLocked) .bossHero h4,
body:not(.appLocked) .bossProjectTop h4,
body:not(.appLocked) .bossJobList strong,
body:not(.appLocked) .jobLinkCard strong,
body:not(.appLocked) .summaryCard dd {
  color: #fff;
}

body:not(.appLocked) .primaryModuleAction small,
body:not(.appLocked) .maintenanceChoices small,
body:not(.appLocked) .jobLinkCard p,
body:not(.appLocked) .truckReminderPanel p,
body:not(.appLocked) .summaryCard dt,
body:not(.appLocked) .receiptListRow span,
body:not(.appLocked) .historyRow em,
body:not(.appLocked) .officeLock p,
body:not(.appLocked) .betaSheetHero p,
body:not(.appLocked) .betaSheetHeroStats span,
body:not(.appLocked) .officeMetricGrid span,
body:not(.appLocked) .officeJobTotalCard span,
body:not(.appLocked) .officeMiniRows span:last-child,
body:not(.appLocked) .directoryRow span:last-child,
body:not(.appLocked) .scanAuditCard p,
body:not(.appLocked) .officeBoardStats em,
body:not(.appLocked) .officeBoardDay,
body:not(.appLocked) .officeBoardDay em,
body:not(.appLocked) .officeBoardMuted,
body:not(.appLocked) .officeBoardCard footer,
body:not(.appLocked) .bossHero p,
body:not(.appLocked) .bossProjectTop p,
body:not(.appLocked) .bossBigStats span,
body:not(.appLocked) .bossDayTile > strong,
body:not(.appLocked) .bossCompanyTotal em,
body:not(.appLocked) .proofStatus {
  color: #a5aebc;
}

body:not(.appLocked) .moduleIcon,
body:not(.appLocked) .scanReviewButton {
  background: linear-gradient(180deg, #d34747 0, #b7292d 100%);
  border-color: #e05252;
  color: #fff;
}

body:not(.appLocked) .secondaryScanButton {
  background: #2b3038;
  border-color: #48505d;
  color: #f5f7fb;
}

body:not(.appLocked) .maintenanceChoices button,
body:not(.appLocked) .primaryModuleAction,
body:not(.appLocked) .receiptCaptureCard {
  background: linear-gradient(180deg, #2d323b 0, #252a32 100%);
  border-color: #444b56;
  color: #eef2f7;
}

body:not(.appLocked) .maintenanceChoices button > span {
  background: #1c2026;
  border-color: #444b56;
}

body:not(.appLocked) .jobCompanyGroup {
  background: #191c21;
  border-color: #3b424d;
}

body:not(.appLocked) .jobEmployeeRow.weeklyPersonRow {
  background:
    linear-gradient(180deg, #2f343d 0, #282d35 100%);
  border: 1px solid #414852;
  border-left-width: 5px;
  border-radius: 6px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
  gap: 6px;
  grid-template-columns: minmax(0, 1fr) minmax(70px, auto) minmax(58px, auto);
  min-height: 36px;
  margin: 4px;
  padding: 4px 7px 4px 8px;
}

body:not(.appLocked) .jobEmployeeRow.weeklyPersonRow.company-hm {
  border-left-color: #d34747;
}

body:not(.appLocked) .jobEmployeeRow.weeklyPersonRow.company-alfa {
  border-left-color: #25a95b;
}

body:not(.appLocked) .jobEmployeeRow.weeklyPersonRow.company-sec {
  border-left-color: #4d91f0;
}

body:not(.appLocked) .jobEmployeeRow.weeklyPersonRow.rosterOnlyEmployee {
  background: linear-gradient(180deg, #242932 0, #20242b 100%);
  border-left-color: #65707f;
  opacity: 1;
}

body:not(.appLocked) .jobEmployeeRow.weeklyPersonRow.rosterOnlyEmployee strong span,
body:not(.appLocked) .jobEmployeeRow.weeklyPersonRow.rosterOnlyEmployee .savedHourMetric,
body:not(.appLocked) .jobEmployeeRow.weeklyPersonRow.rosterOnlyEmployee .emptyDayStrip {
  color: #87919f;
}

body:not(.appLocked) .jobEmployeeRow.weeklyPersonRow:hover,
body:not(.appLocked) .jobEmployeeRow.weeklyPersonRow:focus-visible {
  background: #363d48;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 0 0 2px rgba(255, 255, 255, 0.04);
}

body:not(.appLocked) .weeklyPersonRow.selected {
  background: linear-gradient(180deg, #3a3032 0, #30272a 100%);
  box-shadow:
    inset 0 0 0 1px rgba(255, 90, 90, 0.32),
    0 0 0 2px rgba(200, 50, 50, 0.16);
}

body:not(.appLocked) .weeklyPersonRow.company-alfa.selected {
  background: linear-gradient(180deg, #25372d 0, #202d26 100%);
  box-shadow:
    inset 0 0 0 1px rgba(53, 208, 109, 0.28),
    0 0 0 2px rgba(37, 169, 91, 0.14);
}

body:not(.appLocked) .weeklyPersonRow.company-sec.selected {
  background: linear-gradient(180deg, #253143 0, #202938 100%);
  box-shadow:
    inset 0 0 0 1px rgba(77, 145, 240, 0.28),
    0 0 0 2px rgba(77, 145, 240, 0.14);
}

body:not(.appLocked) .jobEmployeeRow.company-hm strong span {
  color: #ff7777;
}

body:not(.appLocked) .jobEmployeeRow.company-alfa strong span {
  color: #58db85;
}

body:not(.appLocked) .jobEmployeeRow.company-sec strong span {
  color: #7db1ff;
}

body:not(.appLocked) .savedDayStrip {
  align-items: center;
  display: flex;
  gap: 4px;
  min-width: 0;
  overflow: hidden;
}

body:not(.appLocked) .jobEmployeeRow.weeklyPersonRow .savedHourMetric:not(.savedHourTotal) {
  display: none;
}

body:not(.appLocked) .savedDayChip {
  align-items: baseline;
  background: #1b1f25;
  border: 1px solid #434a55;
  border-radius: 999px;
  color: #eef2f7;
  display: inline-flex;
  flex: 0 0 auto;
  font-size: 10px;
  gap: 4px;
  line-height: 1;
  min-height: 21px;
  padding: 4px 6px;
}

body:not(.appLocked) .savedDayChip em {
  color: #9ea7b4;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}

body:not(.appLocked) .savedDayChip strong {
  color: #fff;
  font-size: 11px;
}

body:not(.appLocked) .emptyDayStrip {
  color: #77818e;
  font-size: 11px;
  font-weight: 800;
}

body:not(.appLocked) .savedHourMetric {
  background: #1b1f25;
  border: 1px solid #3e4550;
  border-radius: 999px;
  color: #eef2f7;
  justify-content: center;
  min-height: 22px;
  padding: 3px 7px;
}

body:not(.appLocked) .savedHourMetric em {
  color: #8f99a7;
}

body:not(.appLocked) .savedHourTotal {
  background: rgba(200, 50, 50, 0.18);
  border-color: rgba(255, 90, 90, 0.36);
  color: #fff;
}

body:not(.appLocked) .savedProofButton {
  background: #1d2229;
  border-color: #4a5260;
  color: #f5f7fb;
}

body:not(.appLocked) .entryDialog,
body:not(.appLocked) .receiptPreviewDialog {
  background: linear-gradient(180deg, #242830 0, #1c2026 100%);
  border-color: #454c57;
  color: #eef2f7;
}

body:not(.appLocked) .entryDialog label,
body:not(.appLocked) .receiptDialog label,
body:not(.appLocked) .proofStatus {
  color: #cfd6df;
}

body:not(.appLocked) .dialogActions {
  background: rgba(12, 14, 17, 0.42);
  border-top-color: #3a414b;
}

body:not(.appLocked) .receiptPreviewDialog iframe {
  background: #f7f7f3;
}

@media (max-width: 760px) {
  body:not(.appLocked) .jobEmployeeRow.weeklyPersonRow {
    grid-template-columns: minmax(0, 1fr) minmax(72px, auto) minmax(72px, auto);
  }

  body:not(.appLocked) .savedDayStrip {
    grid-column: 1 / -1;
    order: 5;
  }

  body:not(.appLocked) .savedHourMetric:not(.savedHourTotal) {
    display: none;
  }
}

body:not(.appLocked) .primaryModuleAction,
body:not(.appLocked) .maintenancePrimaryAction,
body:not(.appLocked) .scanReviewButton,
body:not(.appLocked) .quickAddButton {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.08), transparent 34%),
    linear-gradient(180deg, #d34747 0, #ad2529 100%) !important;
  border-color: #e05252 !important;
  color: #fff !important;
}

body:not(.appLocked) .primaryModuleAction strong,
body:not(.appLocked) .primaryModuleAction small,
body:not(.appLocked) .maintenancePrimaryAction strong,
body:not(.appLocked) .maintenancePrimaryAction small {
  color: #fff;
}

body:not(.appLocked) #scanPage .review {
  --scan-border: #454d59;
  --scan-check: #222730;
  --scan-grid: #3d4550;
  --scan-head: #191d23;
  --scan-hover: #343b46;
  --scan-row: #242932;
  --scan-row-alt: #29303a;
  --scan-shell: #20242b;
  background: linear-gradient(180deg, #252a32 0, #1f232a 100%);
  min-height: calc(100vh - 112px);
}

body:not(.appLocked) #scanPage[data-company="alfa"] .review,
body:not(.appLocked) #scanPage[data-company="hm"] .review,
body:not(.appLocked) #scanPage[data-company="sec"] .review {
  --scan-border: #454d59;
  --scan-check: #222730;
  --scan-grid: #3d4550;
  --scan-head: #191d23;
  --scan-hover: #343b46;
}

body:not(.appLocked) #scanPage .review .tableWrap,
body:not(.appLocked) #scanPage .review tbody,
body:not(.appLocked) #scanPage .review .emptyScanRow td {
  background: #20242b;
}

body:not(.appLocked) #scanPage .review th {
  color: #cfd6df;
}

body:not(.appLocked) #scanPage .review td,
body:not(.appLocked) #scanPage .review td input,
body:not(.appLocked) #scanPage .review .scanJobHeader strong {
  color: #f1f4f8;
}

body:not(.appLocked) #scanPage .review td input:focus {
  background: #111419;
  border-color: #e05252;
  box-shadow: 0 0 0 2px rgba(200, 50, 50, 0.18);
}

body:not(.appLocked) #scanPage .scanDayBanner,
body:not(.appLocked) #scanPage .reviewActions,
body:not(.appLocked) #scanPage .scanQualityBar,
body:not(.appLocked) .saveApprovedWrap {
  background: #1c2026;
  border-color: #3b424d;
}

body:not(.appLocked) #scanPage .scanWarningItem {
  background: #34281a;
  border-color: #745522;
  color: #f4c875;
}

body:not(.appLocked) #scanPage .clearScanButton {
  background: #261c20;
  border-color: #7b3b42;
  color: #f08c8c;
}

body:not(.appLocked) #scanPage .clearScanButton:not(:disabled):hover,
body:not(.appLocked) #scanPage .clearScanButton:not(:disabled):focus-visible {
  background: #332126;
  border-color: #b84d58;
}

body:not(.appLocked) #scanPage .scanDayBanner [data-scan-title],
body:not(.appLocked) #scanPage .emptyScanPrompt strong {
  color: #f7f9fc;
}

body:not(.appLocked) #scanPage .scanDayBanner [data-scan-label],
body:not(.appLocked) #scanPage .scanDateOverride span,
body:not(.appLocked) #scanPage .scanDayBanner small,
body:not(.appLocked) #scanPage .emptyScanPrompt,
body:not(.appLocked) #scanPage .emptyScanPrompt span {
  color: #aeb6c3;
}

body:not(.appLocked) #scanPage .scanDateControl {
  background: #171b21;
  border-color: #3a414b;
  color: #cfd6df;
}

body:not(.appLocked) #scanPage .emptyJobList {
  background: #171b21;
  border-color: #3b424d;
}

body:not(.appLocked) #scanPage .emptyJobList strong {
  color: #f1f4f8;
}

body:not(.appLocked) #scanPage .emptyJobList span {
  color: #aeb6c3;
}

body:not(.appLocked) #rowCount,
body:not(.appLocked) .scanPager,
body:not(.appLocked) .saveRequirements li,
body:not(.appLocked) #scanPage .emptyScanPrompt li {
  background: #262b33;
  border-color: #444c58;
  color: #cfd6df;
}

body:not(.appLocked) .saveRequirements li.done {
  background: rgba(37, 169, 91, 0.16);
  border-color: rgba(53, 208, 109, 0.38);
  color: #7bea9f;
}

body:not(.appLocked) .saveRequirements li span {
  background: #171a1f;
  border-color: #4a5260;
}

body:not(.appLocked) .emptyScanPrompt:hover {
  background: #2a3039;
}

body:not(.appLocked) .jobBreakoutTotals {
  background: #15181d;
  border-color: #3a414b;
}

body:not(.appLocked) .jobBreakoutTotals span {
  color: #eef2f7;
}

body:not(.appLocked) .jobBreakoutTotals em {
  color: #9ea7b4;
}

body:not(.appLocked) .proofStatus {
  background: #171b20;
  border-color: #444c58;
  color: #cfd6df;
}

body:not(.appLocked) #copyPoDirectoryButton,
body:not(.appLocked) #copyTruckDirectoryButton,
body:not(.appLocked) #viewTruckDirectoryButton,
body:not(.appLocked) .officeSectionAction,
body:not(.appLocked) .officeCopyBar button,
body:not(.appLocked) .officeActionTertiary {
  background: #2b3038;
  border-color: #4a5260;
  color: #eef2f7;
}

body:not(.appLocked) #copyPoDirectoryButton:disabled,
body:not(.appLocked) #copyTruckDirectoryButton:disabled,
body:not(.appLocked) #viewTruckDirectoryButton:disabled,
body:not(.appLocked) button:disabled {
  background: #20242b;
  border-color: #3c444f;
  color: #8f99a7;
  opacity: 1;
}

body:not(.appLocked) #scanPage .scanDayBanner [data-scan-label] {
  background: #262b33;
  border: 1px solid #444c58;
  color: #cfd6df;
}

@media (max-width: 900px) {
  .weeklySummaryStrip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .weeklySummaryStrip .weeklySummaryBlock:nth-child(odd) {
    border-left: 0;
    padding-left: 0;
  }
}

@media (max-width: 620px) {
  .weeklySummaryStrip {
    grid-template-columns: 1fr;
  }

  .weeklySummaryStrip .weeklySummaryBlock {
    border-left: 0;
    border-top: 1px solid #d6e0da;
    padding: 7px 0;
  }

  .weeklySummaryStrip .weeklySummaryBlock:first-child {
    border-top: 0;
  }

  body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock {
    border-top-color: #3a414b;
  }
}

/* UI QA polish: flatten nested shells, stabilize dense cards, and scale work views. */
body:not(.appLocked) {
  --qa-surface: #242830;
  --qa-surface-soft: #1e2228;
  --qa-surface-flat: rgba(255, 255, 255, 0.035);
  --qa-line: #3a414b;
  --qa-line-strong: #4a5260;
  --qa-muted: #a5aebc;
  background:
    linear-gradient(180deg, #30343b 0, #23272e 300px, #171a1f 100%);
}

body.bossModeActive:not(.appLocked) {
  background:
    linear-gradient(180deg, #2b2f36 0, #20242a 320px, #14171b 100%);
}

body:not(.appLocked) .shell {
  width: 100%;
}

body:not(.appLocked) .pageView > .panel,
body:not(.appLocked) #officePage.bossMode .officeDashboard {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

body:not(.appLocked) .pageView > .panel > .sheetHeader,
body:not(.appLocked) .pageView > .panel > .moduleHeader,
body:not(.appLocked) .pageView > .modulePage .moduleBody,
body:not(.appLocked) .pageView > .officeDashboard .officeContent,
body:not(.appLocked) #officePage.bossMode .officeContent {
  background: transparent;
  border-color: rgba(255, 255, 255, 0.08);
}

body:not(.appLocked) #officePage.bossMode .officeContent {
  border-top: 0;
  padding: 8px 0 0;
}

body:not(.appLocked) .moduleHeader,
body:not(.appLocked) .sheetHeader {
  gap: 12px;
  min-height: 46px;
}

body:not(.appLocked) .moduleHeader > div,
body:not(.appLocked) .sheetHeader > div,
body:not(.appLocked) .bossHero > div,
body:not(.appLocked) .pugProjectLaneHeader > div,
body:not(.appLocked) .pugJobTop > div,
body:not(.appLocked) .officeJobTop > div {
  min-width: 0;
}

body:not(.appLocked) .moduleHeader h2,
body:not(.appLocked) .sheetHeader h2,
body:not(.appLocked) .moduleHeader p,
body:not(.appLocked) .pugProjectLaneHeader h3,
body:not(.appLocked) .pugJobTop h4,
body:not(.appLocked) .officeJobTop h5,
body:not(.appLocked) .bossHero h4 {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

body:not(.appLocked) .moduleHeader p,
body:not(.appLocked) .jobLinkCard p,
body:not(.appLocked) .truckReminderPanel p,
body:not(.appLocked) .proofStatus,
body:not(.appLocked) .confirmDialog p {
  overflow-wrap: anywhere;
}

body:not(.appLocked) .moduleStatus,
body:not(.appLocked) .sheetActions,
body:not(.appLocked) .miniButtonGroup,
body:not(.appLocked) .officeSectionAction {
  flex: 0 0 auto;
}

body:not(.appLocked) button,
body:not(.appLocked) .photoButton,
body:not(.appLocked) .poStatusChip,
body:not(.appLocked) .bossCompanyChip,
body:not(.appLocked) .weeklySummaryPill,
body:not(.appLocked) .statusPill,
body:not(.appLocked) .moduleStatus,
body:not(.appLocked) .jobBadge,
body:not(.appLocked) .truckBadge {
  max-width: 100%;
}

body:not(.appLocked) .poStatusChip,
body:not(.appLocked) .bossCompanyChip,
body:not(.appLocked) .weeklySummaryPill,
body:not(.appLocked) .statusPill,
body:not(.appLocked) .moduleStatus,
body:not(.appLocked) .jobBadge,
body:not(.appLocked) .truckBadge,
body:not(.appLocked) .savedHourMetric,
body:not(.appLocked) .savedDayChip {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body:not(.appLocked) .weeklySummaryStrip {
  background: transparent;
  border-bottom-color: var(--qa-line);
  gap: 0;
  padding: 7px 0;
}

body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock {
  border-left-color: var(--qa-line);
  min-height: 50px;
  padding: 4px 14px;
}

body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock:first-child {
  padding-left: 4px;
}

body:not(.appLocked) .weeklySummaryPills {
  max-height: 54px;
  overflow: hidden;
}

body:not(.appLocked) .weeklyScroller {
  max-height: clamp(340px, 48vh, 620px);
  scrollbar-gutter: stable;
}

body:not(.appLocked) .weeklyTable {
  width: 100%;
}

body:not(.appLocked) .weeklyHeaderRow > span,
body:not(.appLocked) .weeklyRowSheet > .employeeName,
body:not(.appLocked) .weeklyRowSheet > .weekTotal,
body:not(.appLocked) .dayHead,
body:not(.appLocked) .dayHead strong,
body:not(.appLocked) .dayHead span,
body:not(.appLocked) .dayCellEntry strong,
body:not(.appLocked) .dayCellEntryJob,
body:not(.appLocked) .dayCellEntryHours,
body:not(.appLocked) .addText {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

body:not(.appLocked) .dayHead span,
body:not(.appLocked) .dayCellEntry strong,
body:not(.appLocked) .dayCellEntryJob,
body:not(.appLocked) .dayCellEntryHours,
body:not(.appLocked) .addText {
  white-space: nowrap;
}

body:not(.appLocked) .dayCellEntries {
  grid-auto-rows: minmax(40px, auto);
}

body:not(.appLocked) .dayCellEntry {
  min-width: 0;
}

body:not(.appLocked) .jobBreakoutGrid {
  gap: 10px;
  padding: 8px 0 0;
}

body:not(.appLocked) .jobBreakoutCard {
  background: transparent;
  border: 0;
  border-radius: 0;
  overflow: visible;
}

body:not(.appLocked) .jobBreakoutHeader {
  border: 1px solid var(--qa-line);
  border-radius: 7px 7px 0 0;
}

body:not(.appLocked) .jobBreakoutTotals {
  border-left: 1px solid var(--qa-line);
  border-right: 1px solid var(--qa-line);
}

body:not(.appLocked) .jobCompanyGroups {
  background: var(--qa-surface-soft);
  border: 1px solid var(--qa-line);
  border-top: 0;
  border-radius: 0 0 7px 7px;
  padding: 5px;
}

body:not(.appLocked) .jobCompanyGroup {
  border-color: var(--qa-line);
  border-radius: 6px;
}

body:not(.appLocked) .jobEmployeeRow.weeklyPersonRow {
  margin: 3px;
}

body:not(.appLocked) .savedDayStrip {
  max-width: 100%;
}

body:not(.appLocked) .poActionGrid,
body:not(.appLocked) .truckReceiptPanel,
body:not(.appLocked) .officeContent,
body:not(.appLocked) .officeSummary {
  gap: 10px;
}

body:not(.appLocked) .poQueuePanel,
body:not(.appLocked) .receiptHistory,
body:not(.appLocked) .truckOwnerDirectory,
body:not(.appLocked) .officeCopyBar,
body:not(.appLocked) .officeSection,
body:not(.appLocked) .pugSourceSummary,
body:not(.appLocked) .pugProjectLane {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

body:not(.appLocked) .poQueuePanel,
body:not(.appLocked) .receiptHistory,
body:not(.appLocked) .truckOwnerDirectory,
body:not(.appLocked) .pugSourceSummary,
body:not(.appLocked) .pugProjectLane {
  padding: 0;
}

body:not(.appLocked) .officeSection {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 0;
  padding: 10px 0 0;
}

body:not(.appLocked) .officeSection:first-of-type {
  border-top: 0;
  padding-top: 0;
}

body:not(.appLocked) .officeCopyBar {
  grid-template-columns: repeat(auto-fit, minmax(152px, 1fr));
  padding: 0;
}

body:not(.appLocked) .summaryCard dl div,
body:not(.appLocked) .officeJobStats span,
body:not(.appLocked) .scanAuditStats span {
  background: var(--qa-surface-flat);
  border-color: rgba(255, 255, 255, 0.08);
}

body:not(.appLocked) .receiptList,
body:not(.appLocked) .historyRows,
body:not(.appLocked) .officeTableWrap,
body:not(.appLocked) .directoryGrid,
body:not(.appLocked) .truckOwnerDirectoryRows {
  scrollbar-gutter: stable;
}

body:not(.appLocked) .receiptList,
body:not(.appLocked) .historyRows,
body:not(.appLocked) .officeTableWrap,
body:not(.appLocked) .directoryGrid {
  border-color: var(--qa-line);
}

body:not(.appLocked) .truckOwnerDirectoryRows {
  gap: 6px;
}

body:not(.appLocked) .truckOwnerRow,
body:not(.appLocked) .directoryRow,
body:not(.appLocked) .officeMiniRows > div {
  min-width: 0;
}

body:not(.appLocked) .pugProjectBoard {
  gap: 12px;
}

body:not(.appLocked) .pugProjectLane {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 0;
  padding-top: 12px;
}

body:not(.appLocked) .pugProjectLane:first-child {
  border-top: 0;
  padding-top: 0;
}

body:not(.appLocked) .pugJobCard {
  grid-template-rows: auto auto auto minmax(24px, auto) auto;
  min-height: 198px;
}

body:not(.appLocked) .pugJobStats span,
body:not(.appLocked) .pugHeroStats span,
body:not(.appLocked) .pugLaneStats span,
body:not(.appLocked) .pugProjectSummary span {
  min-height: 42px;
}

body:not(.appLocked) .pugJobStats strong,
body:not(.appLocked) .pugHeroStats b,
body:not(.appLocked) .pugLaneStats b,
body:not(.appLocked) .pugProjectSummary b,
body:not(.appLocked) .bossBigStats strong,
body:not(.appLocked) .officeMetricGrid strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body:not(.appLocked) .pugDayDot {
  align-content: center;
  min-height: 42px;
  min-width: 0;
}

body:not(.appLocked) .pugJobCard footer {
  min-height: 42px;
}

body:not(.appLocked) .pugJobCard footer em,
body:not(.appLocked) .pugJobCard footer span,
body:not(.appLocked) .bossStatus {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

body:not(.appLocked) .bossStatus {
  max-width: 132px;
}

body:not(.appLocked) .bossHero {
  min-height: 96px;
}

body:not(.appLocked) .bossHero,
body:not(.appLocked) .pugSourceSummary {
  gap: 14px;
}

body:not(.appLocked) .entryDialog,
body:not(.appLocked) .receiptPreviewDialog,
body:not(.appLocked) .confirmDialog {
  border-radius: 10px;
}

body:not(.appLocked) .dialogHeader h2,
body:not(.appLocked) .confirmDialog h2 {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body:not(.appLocked) .dialogActions {
  flex-wrap: wrap;
}

body:not(.appLocked) .dialogActions button,
body:not(.appLocked) .confirmDialogActions button,
body:not(.appLocked) .entryContextMenu button,
body:not(.appLocked) .employeeSuggestion {
  min-height: 38px;
}

body:not(.appLocked) .entryContextMenu {
  background:
    linear-gradient(180deg, #303640 0, #20242b 100%);
  border-color: #4a5260;
  border-radius: 10px;
  box-shadow:
    0 24px 64px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
  min-width: 210px;
}

body:not(.appLocked) .suggestionList {
  background: #20242b;
  border-color: #4a5260;
  box-shadow:
    0 20px 52px rgba(0, 0, 0, 0.36),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
  overflow: auto;
}

body:not(.appLocked) .employeeSuggestion {
  background: #242a32;
  border-bottom-color: #39414c;
  color: #f3f6fa;
}

body:not(.appLocked) .employeeSuggestion:hover,
body:not(.appLocked) .employeeSuggestion:focus-visible {
  background: #333a45;
  border-color: #515b68;
}

@media (min-width: 1600px) {
  body:not(.appLocked) .shell {
    max-width: 2240px;
    padding: 14px 18px;
  }

  body:not(.appLocked) {
    background:
      linear-gradient(180deg, #2d3138 0, #22262c 360px, #15181d 100%);
  }

  body.bossModeActive:not(.appLocked) {
    background:
      linear-gradient(180deg, #292d33 0, #1f2329 380px, #13161a 100%);
  }

  body:not(.appLocked) .weeklyScroller {
    max-height: min(58vh, 760px);
  }

  body:not(.appLocked) .jobBreakoutCard {
    --job-breakout-height: clamp(240px, 24vh, 420px);
  }

  body:not(.appLocked) .pugJobCardGrid {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  }

  body:not(.appLocked) .pugJobCard {
    min-height: 210px;
  }
}

@media (min-width: 2200px) {
  body:not(.appLocked) .shell {
    max-width: none;
  }

  body:not(.appLocked) .weeklyScroller {
    max-height: min(62vh, 920px);
  }

  body:not(.appLocked) .pugProjectBoard {
    grid-template-columns: repeat(auto-fit, minmax(min(980px, 100%), 1fr));
  }

  body:not(.appLocked) .pugJobCardGrid {
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  }

  body:not(.appLocked) .pugHeroStats {
    min-width: min(720px, 44vw);
  }
}

@media (max-width: 1180px) {
  body:not(.appLocked) .moduleHeader,
  body:not(.appLocked) .sheetHeader {
    min-height: 42px;
  }

  body:not(.appLocked) .weeklyScroller {
    max-height: clamp(320px, 46vh, 520px);
  }

  body:not(.appLocked) .jobBreakoutGrid,
  body:not(.appLocked) .poActionGrid,
  body:not(.appLocked) .truckReceiptPanel,
  body:not(.appLocked) .officeContent,
  body:not(.appLocked) .officeSummary {
    gap: 8px;
  }
}

@media (max-width: 900px) {
  body:not(.appLocked) .weeklySummaryStrip {
    padding: 6px 0;
  }

  body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock {
    border-left: 0;
    border-top: 1px solid var(--qa-line);
    padding: 8px 4px;
  }

  body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock:first-child {
    border-top: 0;
  }

  body:not(.appLocked) .pugSourceSummary {
    gap: 10px;
  }
}

@media (max-width: 520px) {
  body:not(.appLocked) .moduleStatus,
  body:not(.appLocked) .bossStatus,
  body:not(.appLocked) .miniButtonGroup,
  body:not(.appLocked) .sheetActions {
    width: 100%;
  }

  body:not(.appLocked) .miniButtonGroup {
    display: grid;
    grid-template-columns: 1fr;
  }

  body:not(.appLocked) .bossStatus {
    max-width: none;
    justify-content: center;
  }

  body:not(.appLocked) .confirmDialogActions {
    display: grid;
    grid-template-columns: 1fr;
  }

body:not(.appLocked) .confirmDialogActions button {
    width: 100%;
  }
}

/* Redline project color system: muted project identity for the Beta Sheet wall. */
:root {
  --project-adi-accent: #5d7690;
  --project-adi-wash: rgba(93, 118, 144, 0.2);
  --project-adi-line: rgba(126, 153, 178, 0.34);
  --project-sdi-accent: #8b6c65;
  --project-sdi-wash: rgba(139, 108, 101, 0.2);
  --project-sdi-line: rgba(166, 131, 123, 0.34);
  --project-xai-accent: #7c7460;
  --project-xai-wash: rgba(124, 116, 96, 0.22);
  --project-xai-line: rgba(162, 151, 124, 0.34);
  --project-pcacounce-accent: #6d7964;
  --project-pcacounce-wash: rgba(109, 121, 100, 0.2);
  --project-pcacounce-line: rgba(146, 158, 130, 0.34);
  --project-smuckers-accent: #7a6478;
  --project-smuckers-wash: rgba(122, 100, 120, 0.2);
  --project-smuckers-line: rgba(158, 130, 156, 0.34);
  --project-3s-accent: #62787d;
  --project-3s-wash: rgba(98, 120, 125, 0.2);
  --project-3s-line: rgba(128, 158, 164, 0.34);
  --project-wastewater-accent: #617569;
  --project-wastewater-wash: rgba(97, 117, 105, 0.2);
  --project-wastewater-line: rgba(127, 154, 138, 0.34);
  --project-wastemanagement-accent: #617569;
  --project-wastemanagement-wash: rgba(97, 117, 105, 0.2);
  --project-wastemanagement-line: rgba(127, 154, 138, 0.34);
  --project-westrock-accent: #806f5e;
  --project-westrock-wash: rgba(128, 111, 94, 0.2);
  --project-westrock-line: rgba(166, 145, 123, 0.34);
  --project-thomasvillechris-accent: #71677e;
  --project-thomasvillechris-wash: rgba(113, 103, 126, 0.2);
  --project-thomasvillechris-line: rgba(148, 135, 165, 0.34);
  --project-default-accent: #6d7480;
  --project-default-wash: rgba(109, 116, 128, 0.18);
  --project-default-line: rgba(145, 153, 166, 0.3);
}

body:not(.appLocked) {
  background:
    radial-gradient(circle at 84% -12%, rgba(200, 50, 50, 0.12), transparent 28%),
    linear-gradient(180deg, #2d3137 0, #23272d 310px, #171a1f 100%);
}

body.bossModeActive:not(.appLocked) {
  background:
    radial-gradient(circle at 78% -12%, rgba(200, 50, 50, 0.1), transparent 30%),
    linear-gradient(180deg, #292d33 0, #20242a 360px, #14171b 100%);
}

body:not(.appLocked) .shell {
  max-width: min(100%, 1920px);
}

body:not(.appLocked) .project-adi {
  --project-accent: var(--project-adi-accent);
  --project-wash: var(--project-adi-wash);
  --project-line: var(--project-adi-line);
}

body:not(.appLocked) .project-sdi {
  --project-accent: var(--project-sdi-accent);
  --project-wash: var(--project-sdi-wash);
  --project-line: var(--project-sdi-line);
}

body:not(.appLocked) .project-xai {
  --project-accent: var(--project-xai-accent);
  --project-wash: var(--project-xai-wash);
  --project-line: var(--project-xai-line);
}

body:not(.appLocked) .project-pcacounce {
  --project-accent: var(--project-pcacounce-accent);
  --project-wash: var(--project-pcacounce-wash);
  --project-line: var(--project-pcacounce-line);
}

body:not(.appLocked) .project-smuckers {
  --project-accent: var(--project-smuckers-accent);
  --project-wash: var(--project-smuckers-wash);
  --project-line: var(--project-smuckers-line);
}

body:not(.appLocked) .project-3s {
  --project-accent: var(--project-3s-accent);
  --project-wash: var(--project-3s-wash);
  --project-line: var(--project-3s-line);
}

body:not(.appLocked) .project-wastewater,
body:not(.appLocked) .project-wastemanagement {
  --project-accent: var(--project-wastewater-accent);
  --project-wash: var(--project-wastewater-wash);
  --project-line: var(--project-wastewater-line);
}

body:not(.appLocked) .project-westrock {
  --project-accent: var(--project-westrock-accent);
  --project-wash: var(--project-westrock-wash);
  --project-line: var(--project-westrock-line);
}

body:not(.appLocked) .project-thomasvillechris {
  --project-accent: var(--project-thomasvillechris-accent);
  --project-wash: var(--project-thomasvillechris-wash);
  --project-line: var(--project-thomasvillechris-line);
}

body:not(.appLocked) .pugProjectLane {
  --project-accent: var(--project-default-accent);
  --project-wash: var(--project-default-wash);
  --project-line: var(--project-default-line);
  background:
    linear-gradient(110deg, var(--project-wash) 0, rgba(255, 255, 255, 0.018) 42%, transparent 78%);
  border-color: var(--project-line);
  border-top: 1px solid var(--project-line);
  box-shadow: inset 4px 0 0 color-mix(in srgb, var(--project-accent) 82%, transparent);
  padding-left: 12px;
}

body:not(.appLocked) .pugProjectLane.project-adi,
body:not(.appLocked) .pugJobCard.project-adi,
body:not(.appLocked) .pugProjectSummary span.project-adi {
  --project-accent: var(--project-adi-accent);
  --project-wash: var(--project-adi-wash);
  --project-line: var(--project-adi-line);
}

body:not(.appLocked) .pugProjectLane.project-sdi,
body:not(.appLocked) .pugJobCard.project-sdi,
body:not(.appLocked) .pugProjectSummary span.project-sdi {
  --project-accent: var(--project-sdi-accent);
  --project-wash: var(--project-sdi-wash);
  --project-line: var(--project-sdi-line);
}

body:not(.appLocked) .pugProjectLane.project-xai,
body:not(.appLocked) .pugJobCard.project-xai,
body:not(.appLocked) .pugProjectSummary span.project-xai {
  --project-accent: var(--project-xai-accent);
  --project-wash: var(--project-xai-wash);
  --project-line: var(--project-xai-line);
}

body:not(.appLocked) .pugProjectLane.project-pcacounce,
body:not(.appLocked) .pugJobCard.project-pcacounce,
body:not(.appLocked) .pugProjectSummary span.project-pcacounce {
  --project-accent: var(--project-pcacounce-accent);
  --project-wash: var(--project-pcacounce-wash);
  --project-line: var(--project-pcacounce-line);
}

body:not(.appLocked) .pugProjectLane.project-smuckers,
body:not(.appLocked) .pugJobCard.project-smuckers,
body:not(.appLocked) .pugProjectSummary span.project-smuckers {
  --project-accent: var(--project-smuckers-accent);
  --project-wash: var(--project-smuckers-wash);
  --project-line: var(--project-smuckers-line);
}

body:not(.appLocked) .pugProjectLane.project-3s,
body:not(.appLocked) .pugJobCard.project-3s,
body:not(.appLocked) .pugProjectSummary span.project-3s {
  --project-accent: var(--project-3s-accent);
  --project-wash: var(--project-3s-wash);
  --project-line: var(--project-3s-line);
}

body:not(.appLocked) .pugProjectLane.project-wastewater,
body:not(.appLocked) .pugJobCard.project-wastewater,
body:not(.appLocked) .pugProjectSummary span.project-wastewater,
body:not(.appLocked) .pugProjectLane.project-wastemanagement,
body:not(.appLocked) .pugJobCard.project-wastemanagement,
body:not(.appLocked) .pugProjectSummary span.project-wastemanagement {
  --project-accent: var(--project-wastewater-accent);
  --project-wash: var(--project-wastewater-wash);
  --project-line: var(--project-wastewater-line);
}

body:not(.appLocked) .pugProjectLane.project-westrock,
body:not(.appLocked) .pugJobCard.project-westrock,
body:not(.appLocked) .pugProjectSummary span.project-westrock {
  --project-accent: var(--project-westrock-accent);
  --project-wash: var(--project-westrock-wash);
  --project-line: var(--project-westrock-line);
}

body:not(.appLocked) .pugProjectLane.project-thomasvillechris,
body:not(.appLocked) .pugJobCard.project-thomasvillechris,
body:not(.appLocked) .pugProjectSummary span.project-thomasvillechris {
  --project-accent: var(--project-thomasvillechris-accent);
  --project-wash: var(--project-thomasvillechris-wash);
  --project-line: var(--project-thomasvillechris-line);
}

body:not(.appLocked) .pugProjectLaneHeader h3 {
  color: color-mix(in srgb, var(--project-accent) 72%, #fff);
}

body:not(.appLocked) .pugLaneStats span,
body:not(.appLocked) .pugProjectSummary span {
  border-color: var(--project-line);
}

body:not(.appLocked) .pugProjectSummary span[class*="project-"] {
  background:
    linear-gradient(135deg, var(--project-wash), rgba(255, 255, 255, 0.035));
  box-shadow: inset 3px 0 0 var(--project-accent);
}

body:not(.appLocked) .pugProjectSummary span[class*="project-"] b {
  color: color-mix(in srgb, var(--project-accent) 74%, #fff);
}

body:not(.appLocked) .pugJobCard {
  --project-accent: var(--project-default-accent);
  --project-wash: var(--project-default-wash);
  --project-line: var(--project-default-line);
  background:
    linear-gradient(135deg, var(--project-wash) 0, rgba(255, 255, 255, 0.025) 36%, rgba(255, 255, 255, 0.01) 100%),
    #24272d;
  border-color: color-mix(in srgb, var(--project-line) 82%, #3b4049);
  box-shadow:
    inset 4px 0 0 color-mix(in srgb, var(--project-accent) 84%, transparent),
    0 14px 34px rgba(0, 0, 0, 0.18);
}

body:not(.appLocked) .pugJobCard .moduleEyebrow {
  color: color-mix(in srgb, var(--project-accent) 58%, #b8c1cf);
}

body:not(.appLocked) .pugJobCard .pugJobTop h4 {
  color: #f8fbff;
}

body:not(.appLocked) .pugJobCard footer {
  border-color: var(--project-line);
}

@media (min-width: 1500px) {
  body:not(.appLocked) .shell {
    max-width: none;
    padding-left: clamp(12px, 1.2vw, 28px);
    padding-right: clamp(12px, 1.2vw, 28px);
  }

  body:not(.appLocked) .workspace {
    grid-template-columns: clamp(218px, 16vw, 320px) minmax(0, 1fr);
  }
}

@media (min-width: 2400px) {
  body:not(.appLocked) .pugProjectBoard {
    grid-template-columns: 1fr;
  }

  body:not(.appLocked) .pugJobCardGrid {
    grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
  }
}

/* Graphite display pass: keep the 5K/TV view calm and remove the scaled glow. */
body:not(.appLocked),
body.bossModeActive:not(.appLocked) {
  background:
    linear-gradient(180deg, rgba(200, 50, 50, 0.05), transparent 210px),
    linear-gradient(180deg, #2b2b2d 0, #202124 300px, #151618 100%);
}

body:not(.appLocked)::before {
  background: none;
}

body:not(.appLocked) .shell {
  max-width: none;
}

@media (min-width: 1500px) {
  body:not(.appLocked) .officeBoardGrid {
    max-height: clamp(420px, 52vh, 980px);
  }

  body:not(.appLocked) .officeBoardCard {
    min-height: 210px;
  }

  body:not(.appLocked) .pugJobCardGrid {
    grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
  }
}

@media (min-width: 2400px) {
  body:not(.appLocked) .officeBoardGrid {
    max-height: clamp(620px, 58vh, 1160px);
  }

  body:not(.appLocked) .pugJobCardGrid {
    grid-template-columns: repeat(auto-fit, minmax(420px, 1fr));
  }
}

/* Unlocked operations graphitization for PO/Truck/Office/Beta pages */
body:not(.appLocked) {
  overflow-x: hidden;
  --unlock-surface: #242a31;
  --unlock-border: #3a404a;
  --unlock-softline: rgba(255, 255, 255, 0.08);
}

body:not(.appLocked) .pageView,
body:not(.appLocked) .pageView > .panel,
body:not(.appLocked) .modulePage,
body:not(.appLocked) .poDashboard,
body:not(.appLocked) .maintenanceDashboard,
body:not(.appLocked) .officeDashboard {
  min-width: 0;
  width: 100%;
}

body:not(.appLocked) .poActionGrid,
body:not(.appLocked) .truckReceiptPanel,
body:not(.appLocked) .officeSummary,
body:not(.appLocked) .officeMetricGrid,
body:not(.appLocked) .officeJobStats,
body:not(.appLocked) .officeJobTotalGrid,
body:not(.appLocked) .officeBoardGrid,
body:not(.appLocked) .betaSheetHero,
body:not(.appLocked) .betaSheetHeroStats,
body:not(.appLocked) .officeSection,
body:not(.appLocked) .poSummaryGrid,
body:not(.appLocked) .sourceExampleBar,
body:not(.appLocked) .maintenanceChoices,
body:not(.appLocked) .jobBreakoutGrid,
body:not(.appLocked) .jobCompanyGroups,
body:not(.appLocked) .bossProjectGrid,
body:not(.appLocked) .companySavedGrid {
  min-width: 0;
}

body:not(.appLocked) .poDashboard .moduleBody,
body:not(.appLocked) .maintenanceDashboard .moduleBody,
body:not(.appLocked) .officeDashboard .officeContent {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.025), transparent 170px), #1d2128;
  border-color: var(--unlock-border);
}

body:not(.appLocked) .poDashboard,
body:not(.appLocked) .maintenanceDashboard {
  border-color: var(--unlock-border);
}

body:not(.appLocked) .primaryModuleAction,
body:not(.appLocked) .maintenancePrimaryAction,
body:not(.appLocked) .officeSectionAction {
  border-color: #4d5561;
}

body:not(.appLocked) .poDashboard .receiptHistory,
body:not(.appLocked) .truckReminderPanel,
body:not(.appLocked) .poQueuePanel,
body:not(.appLocked) .officeJobCard,
body:not(.appLocked) .officeBoardCard,
body:not(.appLocked) .scanAuditCard,
body:not(.appLocked) .officeSummary > .officeSection,
body:not(.appLocked) .sourceExampleBar button,
body:not(.appLocked) .sourcePoButton {
  background: #222830;
  border-color: var(--unlock-border);
}

body:not(.appLocked) .moduleHeader,
body:not(.appLocked) .sheetHeader,
body:not(.appLocked) .tableHeader,
body:not(.appLocked) .dialogActions,
body:not(.appLocked) .reviewActions {
  border-color: var(--unlock-border);
}

body:not(.appLocked) .poActionGrid {
  grid-template-columns: minmax(0, 0.85fr) minmax(280px, 1.15fr);
}

body:not(.appLocked) .truckReceiptPanel {
  grid-template-columns: minmax(0, 0.78fr) minmax(300px, 1.22fr);
}

body:not(.appLocked) .poSummaryGrid,
body:not(.appLocked) .officeMetricGrid,
body:not(.appLocked) .officeJobTotalGrid,
body:not(.appLocked) .officeBoardCompanies,
body:not(.appLocked) .officeBoardStats,
body:not(.appLocked) .officeBoardDays,
body:not(.appLocked) .bossProjectGrid,
body:not(.appLocked) .companySavedGrid,
body:not(.appLocked) .jobCompanyGroups,
body:not(.appLocked) .poActionGrid > .primaryModuleAction,
body:not(.appLocked) .truckReceiptPanel > .receiptHistory,
body:not(.appLocked) .truckReceiptPanel > .truckReminderPanel {
  row-gap: 7px;
  column-gap: 7px;
}

@media (max-width: 1400px) and (min-width: 861px) {
  body:not(.appLocked) .poActionGrid {
    grid-template-columns: minmax(0, 0.82fr) minmax(260px, 1.18fr);
  }

  body:not(.appLocked) .truckReceiptPanel {
    grid-template-columns: minmax(250px, 0.74fr) minmax(280px, 1.26fr);
  }

  body:not(.appLocked) .poSummaryGrid,
  body:not(.appLocked) .officeMetricGrid,
  body:not(.appLocked) .bossProjectGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  body:not(.appLocked) .poActionGrid,
  body:not(.appLocked) .truckReceiptPanel {
    grid-template-columns: 1fr;
  }

  body:not(.appLocked) .sourceExampleBar {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 620px) {
  body:not(.appLocked) .poSummaryGrid,
  body:not(.appLocked) .officeJobTotalGrid,
  body:not(.appLocked) .officeMetricGrid,
  body:not(.appLocked) .bossBigStats,
  body:not(.appLocked) .maintenanceChoices,
  body:not(.appLocked) .jobCompanyGroups,
  body:not(.appLocked) .sourceExampleBar {
    grid-template-columns: 1fr;
  }

  body:not(.appLocked) .sourceExampleBar {
    gap: 6px;
  }

  body:not(.appLocked) .sourcePoButton,
  body:not(.appLocked) .sourceExampleBar button {
    padding-right: 10px;
  }
}

/* Apple-inspired 26.5 visual refresh while preserving H&M palette. */
:root {
  color-scheme: dark;
  --ios-bg-outer: #11171f;
  --ios-bg-inner: #161c24;
  --ios-surface: rgba(255, 255, 255, 0.045);
  --ios-elevated: rgba(255, 255, 255, 0.06);
  --ios-border: rgba(255, 255, 255, 0.16);
  --ios-border-strong: rgba(255, 255, 255, 0.23);
  --ios-ink: #f4f7fb;
  --ios-muted: #aeb6c3;
  --ios-shadow: 0 16px 38px rgba(8, 12, 18, 0.35);
  --ios-shadow-soft: 0 8px 20px rgba(8, 12, 18, 0.24);
  --ios-radius-large: 18px;
  --ios-radius-medium: 14px;
  --ios-radius-small: 10px;
  --ios-ring: rgba(200, 50, 50, 0.45);

  --bg: var(--ios-bg-inner);
  --panel: var(--ios-surface);
  --ink: var(--ios-ink);
  --muted: var(--ios-muted);
  --line: rgba(255, 255, 255, 0.14);
  --soft: #eef0f5;
  --accent: #c83232;
  --accent-dark: #a72f2f;
  --accent-soft: #fff0f0;
  --sky: #c8d5ef;
  --sun: #f7d77f;
}

body,
body .shell {
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Arial, sans-serif;
  letter-spacing: -0.003em;
}

body {
  color: var(--ink);
  background:
    radial-gradient(circle at 100% 0%, rgba(200, 50, 50, 0.35), transparent 40%),
    radial-gradient(circle at 8% 92%, rgba(255, 255, 255, 0.04), transparent 42%),
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.03) 0 2px, rgba(0, 0, 0, 0.03) 2px 4px),
    linear-gradient(155deg, #07090d 0%, #10151c 50%, #090c12 100%);
  text-rendering: optimizeLegibility;
}

body.appLocked {
  background:
    radial-gradient(circle at 100% 0%, rgba(200, 50, 50, 0.42), transparent 40%),
    radial-gradient(circle at 0 95%, rgba(255, 255, 255, 0.08), transparent 44%),
    linear-gradient(155deg, #0a1018 0%, #121925 55%, #0a0d14 100%);
}

body:not(.appLocked) {
  background:
    radial-gradient(circle at 84% -12%, rgba(200, 50, 50, 0.12), transparent 28%),
    linear-gradient(180deg, #2b2f37 0, #23272e 300px, #171a1f 100%);
}

body.appLocked .appLoginScreen {
  align-items: center;
  display: grid;
  min-height: 100vh;
  padding: clamp(14px, 2.8vw, 32px);
}

body.appLocked .appLoginCard {
  align-content: space-between;
  background:
    linear-gradient(180deg, rgba(31, 38, 46, 0.96) 0%, rgba(20, 26, 34, 0.95) 100%);
  border: 1px solid var(--ios-border-strong);
  border-radius: 24px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.14),
    0 24px 60px rgba(2, 7, 14, 0.42);
  display: grid;
  gap: 14px;
  margin: 0 auto;
  max-width: 430px;
  padding: 36px;
  width: min(100%, 430px);
}

body.appLocked .appLoginCard h1 {
  color: #f9fbff;
  font-size: 34px;
  font-weight: 850;
  line-height: 1.04;
  margin-top: 2px;
  text-align: center;
}

body.appLocked .appLoginCard p {
  color: #bcc6d1;
  font-size: 14px;
  line-height: 1.45;
  text-align: center;
}

body.appLocked .appLoginCard label {
  color: #cdd5e0;
  font-size: 12px;
  font-weight: 760;
  margin-top: 6px;
  text-transform: uppercase;
}

body.appLocked .appLoginCard input,
body.appLocked .appLoginMessage {
  border-radius: 11px;
}

body.appLocked .appLoginCard input {
  background: linear-gradient(180deg, #f4f7fb 0, #e8edf5 100%);
  border-color: rgba(255, 255, 255, 0.26);
  color: #14181f;
  min-height: 50px;
}

body.appLocked .appLoginCard button {
  background:
    linear-gradient(180deg, #dc4a4a 0%, #b42e2e 100%);
  border: 1px solid color-mix(in srgb, #e05a5a 80%, transparent);
  border-radius: var(--ios-radius-small);
  box-shadow: 0 15px 28px rgba(192, 42, 42, 0.35);
  color: #fff;
  font-size: 17px;
  font-weight: 860;
  min-height: 52px;
}

body.appLocked .appLoginScreen,
body:not(.appLocked) .shell {
  padding: 10px;
}

body.appLocked .passwordToggle {
  width: 44px;
  height: 44px;
}

body.appLocked .passwordField input {
  border-radius: 11px;
}

body:not(.appLocked) .appHeader {
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 10px;
}

body:not(.appLocked) .brand h1 {
  font-size: 25px;
  font-weight: 760;
  letter-spacing: -0.01em;
}

body:not(.appLocked) .pageTabs,
body:not(.appLocked) .headerActions,
body:not(.appLocked) .miniButtonGroup,
body:not(.appLocked) .sheetActions,
body:not(.appLocked) .officeCopyBar,
body:not(.appLocked) .dialogActions {
  align-items: center;
}

body:not(.appLocked) .pageTabs {
  background: var(--ios-elevated);
  border: 1px solid var(--ios-border);
  border-radius: 999px;
  box-shadow: var(--ios-shadow-soft);
  display: inline-flex;
  gap: 4px;
  padding: 4px;
}

body:not(.appLocked) .pageTabs button,
body:not(.appLocked) .officeAccessButton {
  border-radius: 999px;
  min-width: 100px;
  min-height: 38px;
  padding: 6px 14px;
  transition:
    background-color 120ms ease,
    border-color 120ms ease,
    transform 120ms ease,
    box-shadow 120ms ease;
}

body:not(.appLocked) .pageTabs button.active,
body:not(.appLocked) .officeAccessButton.active {
  background: linear-gradient(180deg, #2f3642 0%, #1e222c 100%);
  border-color: color-mix(in srgb, var(--hm-red) 40%, var(--ios-border-strong));
  color: #f4f7fd;
  box-shadow: inset 0 -2px 0 #db3c3c;
}

body:not(.appLocked) .pageTabs button:hover,
body:not(.appLocked) .officeAccessButton:hover {
  transform: translateY(-1px);
}

body:not(.appLocked) button,
body:not(.appLocked) .photoButton,
body:not(.appLocked) .officeSectionAction,
body:not(.appLocked) .statusPill,
body:not(.appLocked) .poStatusChip,
body:not(.appLocked) .moduleStatus,
body:not(.appLocked) .jobBadge,
body:not(.appLocked) .truckBadge {
  border-radius: 12px;
  min-height: 42px;
  padding: 10px 14px;
}

body:not(.appLocked) .panel,
body:not(.appLocked) .modulePage,
body:not(.appLocked) .poDashboard,
body:not(.appLocked) .maintenanceDashboard,
body:not(.appLocked) .officeDashboard,
body:not(.appLocked) .jobLinkCard,
body:not(.appLocked) .receiptHistory,
body:not(.appLocked) .poSummaryGrid,
body:not(.appLocked) .truckReminderPanel {
  border-radius: var(--ios-radius-large);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.006));
  border: 1px solid var(--ios-border);
  box-shadow: var(--ios-shadow-soft);
}

body:not(.appLocked) .pageView > .panel,
body:not(.appLocked) .sheetHeader,
body:not(.appLocked) .moduleHeader {
  background: transparent;
  border-radius: 0;
  box-shadow: none;
}

body:not(.appLocked) .sheetHeader,
body:not(.appLocked) .moduleHeader,
body:not(.appLocked) .tableHeader {
  border: 1px solid var(--ios-border);
  border-radius: var(--ios-radius-medium);
  padding: 10px 12px;
}

body:not(.appLocked) .scanDayBanner {
  border: 1px solid var(--ios-border);
  border-radius: var(--ios-radius-small);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.042), transparent 180px);
}

body:not(.appLocked) .workspace {
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(220px, 0.24fr) minmax(0, 1fr);
}

body:not(.appLocked) #scanPage {
  min-height: calc(100vh - 92px);
}

body:not(.appLocked) #scanPage .workspace {
  align-items: stretch;
  min-height: calc(100vh - 112px);
}

body:not(.appLocked) #scanPage .side,
body:not(.appLocked) #scanPage .review {
  align-self: stretch;
  min-height: 100%;
}

body:not(.appLocked) #scanPage .side {
  display: flex;
  flex-direction: column;
}

body:not(.appLocked) #scanPage .recentScansPanel {
  flex: 1 1 auto;
  min-height: 320px;
}

body:not(.appLocked) .side {
  border: 1px solid var(--ios-border);
  border-radius: var(--ios-radius-large);
  padding: 12px;
}

body:not(.appLocked) .workspace .panel,
body:not(.appLocked) .review {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.052), rgba(255, 255, 255, 0.012));
  border-color: var(--ios-border);
}

body:not(.appLocked) .weeklySummaryStrip,
body:not(.appLocked) .poActionGrid,
body:not(.appLocked) .truckReceiptPanel,
body:not(.appLocked) .officeSummary,
body:not(.appLocked) .pugSourceSummary {
  gap: 10px;
}

body:not(.appLocked) .weeklySummaryStrip {
  border: 1px solid var(--ios-border);
  border-radius: var(--ios-radius-medium);
  padding: 6px 0;
}

body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock,
body:not(.appLocked) .jobBreakoutTotals,
body:not(.appLocked) .pugProjectSummary span,
body:not(.appLocked) .bossCompanyTotal,
body:not(.appLocked) .officeSection,
body:not(.appLocked) .bossHero,
body:not(.appLocked) .bossStatus {
  border-radius: var(--ios-radius-small);
}

body:not(.appLocked) .jobBreakoutGrid,
body:not(.appLocked) .jobCompanyGroups,
body:not(.appLocked) .poSummaryGrid,
body:not(.appLocked) .receiptList,
body:not(.appLocked) .truckOwnerDirectoryRows,
body:not(.appLocked) .officeTableWrap {
  scrollbar-gutter: stable;
}

body:not(.appLocked) input,
body:not(.appLocked) select,
body:not(.appLocked) textarea {
  background: linear-gradient(180deg, rgba(246, 248, 252, 0.97), rgba(232, 236, 243, 0.98));
  border: 1px solid rgba(255, 255, 255, 0.17);
  border-radius: 11px;
  color: #141a22;
  min-height: 40px;
}

body:not(.appLocked) .entryDialog,
body:not(.appLocked) .receiptPreviewDialog,
body:not(.appLocked) .confirmDialog {
  border-radius: 16px;
  border: 1px solid var(--ios-border);
  box-shadow: 0 28px 60px rgba(0, 0, 0, 0.45);
}

body:not(.appLocked) .sheetActions,
body:not(.appLocked) .miniButtonGroup,
body:not(.appLocked) .dialogActions,
body:not(.appLocked) .officeSectionAction {
  flex-wrap: wrap;
  gap: 8px;
}

body:not(.appLocked) .scanReviewButton,
body:not(.appLocked) .entryDialog .saveButton,
body:not(.appLocked) .entryDialog button,
body:not(.appLocked) .dialogActions button {
  min-height: 44px;
}

body:not(.appLocked) .weeklyScroller,
body:not(.appLocked) .poSummaryGrid,
body:not(.appLocked) .officeContent {
  -webkit-overflow-scrolling: touch;
}

body:not(.appLocked) .bossProjectCard {
  border-radius: 18px;
}

body:not(.appLocked) .pugJobCard {
  border-radius: var(--ios-radius-large);
}

body:not(.appLocked) .jobBreakoutHeader strong,
body:not(.appLocked) .sheetHeader h2,
body:not(.appLocked) .moduleHeader h2,
body:not(.appLocked) .moduleHeader h3 {
  letter-spacing: -0.01em;
}

body:not(.appLocked) .weeklySummaryPill,
body:not(.appLocked) .bossCompanyChip,
body:not(.appLocked) .statusPill {
  border-radius: 999px;
}

@media (min-width: 1200px) {
  body:not(.appLocked) .shell {
    padding: 14px;
  }

  body:not(.appLocked) .pageTabs button,
  body:not(.appLocked) .officeAccessButton {
    min-width: 116px;
  }
}

@media (max-width: 900px) {
  body:not(.appLocked) .workspace {
    grid-template-columns: 1fr;
  }

  body:not(.appLocked) .pageTabs {
    width: 100%;
  }

  body:not(.appLocked) .pageTabs button {
    min-height: 40px;
  }

  body:not(.appLocked) .side {
    order: 2;
  }
}

@media (max-width: 620px) {
  body:not(.appLocked) .appHeader {
    margin-bottom: 8px;
  }

  body:not(.appLocked) .panel,
  body:not(.appLocked) .officeContent {
    border-radius: 12px;
  }

  body:not(.appLocked) h1 {
    font-size: 20px;
  }

  body.appLocked .appLoginCard {
    padding: 28px 22px;
  }
}

/* Apple-like interaction rhythm and high-fidelity affordances. */
::selection {
  background: color-mix(in srgb, var(--hm-red) 24%, transparent);
  color: #fff;
}

@media (prefers-reduced-motion: no-preference) {
  body:not(.appLocked) .pageTabs button,
  body:not(.appLocked) .officeAccessButton,
  body:not(.appLocked) button,
  body:not(.appLocked) .photoButton,
  body:not(.appLocked) .scanReviewButton,
  body:not(.appLocked) .jobLinkCard,
  body:not(.appLocked) .pugJobCard,
  body:not(.appLocked) .modulePage,
  body:not(.appLocked) .weeklySummaryStrip,
  body:not(.appLocked) .weekStrip,
  body:not(.appLocked) .sheetHeader,
  body:not(.appLocked) .moduleHeader {
    transition:
      transform 140ms cubic-bezier(0.16, 1, 0.3, 1),
      background-color 140ms cubic-bezier(0.16, 1, 0.3, 1),
      border-color 140ms cubic-bezier(0.16, 1, 0.3, 1),
      box-shadow 140ms cubic-bezier(0.16, 1, 0.3, 1);
  }
}

body:not(.appLocked) button:focus-visible,
body:not(.appLocked) input:focus-visible,
body:not(.appLocked) select:focus-visible {
  outline: none;
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--hm-red) 30%, transparent);
  border-color: color-mix(in srgb, var(--hm-red) 55%, #fff);
}

body:not(.appLocked) button:active,
body:not(.appLocked) .photoButton:active,
body:not(.appLocked) .scanReviewButton:active,
body:not(.appLocked) select:active {
  transform: translateY(1px) scale(0.996);
}

body:not(.appLocked) .photoButton,
body:not(.appLocked) .scanReviewButton,
body:not(.appLocked) #scanPage .scanReviewButton,
body:not(.appLocked) .sheetActions button,
body:not(.appLocked) .miniButtonGroup button,
body:not(.appLocked) .officeSectionAction {
  backdrop-filter: blur(10px);
}

body:not(.appLocked) .scanReviewButton,
body:not(.appLocked) .clearScanButton,
body:not(.appLocked) #saveButton,
body:not(.appLocked) .quickAddButton,
body:not(.appLocked) .primaryPhoto,
body:not(.appLocked) .primaryModuleAction,
body:not(.appLocked) .maintenancePrimaryAction {
  font-weight: 650;
  letter-spacing: -0.01em;
}

body:not(.appLocked) .pageTabs button:not(.active),
body:not(.appLocked) .officeAccessButton:not(.active) {
  color: #e6ecf5;
}

body:not(.appLocked) .pageTabs button:not(.active):focus-visible,
body:not(.appLocked) .officeAccessButton:not(.active):focus-visible {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--hm-red) 22%, transparent);
}

body:not(.appLocked) .scanDayBanner .scanBannerMeta {
  gap: 8px;
}

body:not(.appLocked) .scanDayBanner [data-scan-title] {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

body:not(.appLocked) .reviewActions {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

body:not(.appLocked) .scanReviewButton {
  min-height: 58px;
  font-size: 15px;
}

body:not(.appLocked) .scanReviewButton span[aria-hidden="true"] {
  display: inline-block;
  font-size: 20px;
  line-height: 1;
  margin-right: 2px;
  transform: translateY(1px);
}

body:not(.appLocked) .weeklySummaryStrip {
  backdrop-filter: blur(2px);
}

body:not(.appLocked) .jobBreakoutGrid {
  overflow: clip;
}

body:not(.appLocked) .weeklyTable {
  scrollbar-width: thin;
  scrollbar-color: color-mix(in srgb, var(--hm-red) 50%, #1f2630) transparent;
}

/* Redline polish overrides: cleaner weekly summary, larger truck targets, flatter nesting. */
body:not(.appLocked) .weeklySummaryStrip {
  align-items: stretch;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.015));
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 14px;
  display: grid;
  gap: 0;
  grid-template-columns: 1.25fr 1.2fr 1fr 1fr;
  padding: 6px 10px;
}

body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock {
  background: transparent;
  border: 0;
  border-left: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 0;
  box-shadow: none;
  display: grid;
  gap: 4px;
  min-height: 56px;
  padding: 4px 12px;
}

body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock:first-child {
  border-left: 0;
  padding-left: 4px;
}

body:not(.appLocked) .weeklySummaryStrip .weeklySummaryLabel {
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

body:not(.appLocked) .weeklySummaryStrip .weeklySummaryWeek strong {
  font-size: 18px;
  line-height: 1.05;
}

body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock strong {
  font-size: 17px;
  font-weight: 950;
}

body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock em {
  font-size: 11px;
  font-style: normal;
  font-weight: 800;
  opacity: 0.86;
}

body:not(.appLocked) .weeklyProgress {
  height: 6px;
  width: min(150px, 100%);
}

body:not(.appLocked) .jobBreakoutCard {
  --job-breakout-height: 250px;
}

body:not(.appLocked) .jobBreakoutHeader {
  min-height: 38px;
  padding: 6px 10px;
}

body:not(.appLocked) .jobBreakoutHeader strong {
  font-size: 20px;
}

body:not(.appLocked) .jobBreakoutTotals {
  justify-content: center;
  padding: 5px 10px;
}

body:not(.appLocked) .jobCompanyGroup h3 {
  align-items: center;
  display: flex;
  justify-content: space-between;
  min-height: 40px;
  padding: 7px 10px 6px;
}

body:not(.appLocked) .jobCompanyGroup h3 > span {
  font-size: 20px;
  font-weight: 950;
}

body:not(.appLocked) .jobCompanyGroup h3 > strong {
  display: none !important;
}

body:not(.appLocked) .jobCompanyGroup h3 > em {
  display: inline-flex;
  font-size: 10px;
  gap: 7px;
  grid-column: auto;
  justify-self: auto;
  opacity: 0.95;
}

body:not(.appLocked) .scanProofBadge {
  display: none !important;
}

body:not(.appLocked) .truckReceiptPanel {
  grid-template-areas:
    "capture history"
    "reminders history";
  grid-template-columns: minmax(300px, 0.84fr) minmax(420px, 1.16fr);
}

body:not(.appLocked) .maintenanceChoices {
  gap: 10px;
  grid-template-columns: repeat(3, minmax(230px, 1fr));
}

body:not(.appLocked) .maintenanceChoices button {
  border-radius: 10px;
  gap: 5px 12px;
  grid-template-columns: 72px minmax(0, 1fr);
  min-height: 132px;
  padding: 10px 12px;
}

body:not(.appLocked) .maintenanceChoices button > span {
  font-size: 42px;
  height: 72px;
  width: 72px;
}

body:not(.appLocked) .maintenanceChoices strong {
  font-size: 20px;
  line-height: 1.05;
}

body:not(.appLocked) .maintenanceChoices small {
  font-size: 13px;
  line-height: 1.3;
}

body:not(.appLocked) .moduleBody,
body:not(.appLocked) .weeklySheet,
body:not(.appLocked) .savedGrid,
body:not(.appLocked) .receiptHistory,
body:not(.appLocked) .officeSection {
  box-shadow: none;
}

@media (max-width: 980px) {
  body:not(.appLocked) .weeklySummaryStrip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    row-gap: 6px;
  }

  body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock:nth-child(odd) {
    border-left: 0;
    padding-left: 4px;
  }

  body:not(.appLocked) .truckReceiptPanel {
    grid-template-areas:
      "capture"
      "history"
      "reminders";
    grid-template-columns: minmax(0, 1fr);
  }

  body:not(.appLocked) .maintenanceChoices {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  body:not(.appLocked) .receiptHistory .moduleSummaryHeader {
    align-items: stretch;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
  }

  body:not(.appLocked) .maintenanceChoices {
    grid-template-columns: minmax(0, 1fr);
  }

  body:not(.appLocked) .maintenanceChoices button {
    min-height: 120px;
  }
}

/* Liquid Glass Template System: shared visual language for all surfaces. */
:root {
  --lg-blur-soft: 10px;
  --lg-blur-strong: 18px;
  --lg-radius-card: 14px;
  --lg-radius-pane: 18px;
  --lg-radius-pill: 999px;
  --lg-border: rgba(255, 255, 255, 0.14);
  --lg-border-strong: rgba(255, 255, 255, 0.22);
  --lg-surface-top: rgba(255, 255, 255, 0.11);
  --lg-surface-mid: rgba(255, 255, 255, 0.06);
  --lg-surface-low: rgba(255, 255, 255, 0.02);
  --lg-shadow-soft: 0 10px 30px rgba(0, 0, 0, 0.22);
  --lg-shadow-deep: 0 18px 48px rgba(0, 0, 0, 0.32);
  --lg-red-glow: rgba(200, 50, 50, 0.24);
}

body:not(.appLocked) .shell {
  background:
    radial-gradient(circle at 12% 8%, rgba(255, 255, 255, 0.07), transparent 40%),
    radial-gradient(circle at 92% 0%, rgba(200, 50, 50, 0.26), transparent 34%),
    linear-gradient(150deg, rgba(9, 12, 16, 0.92), rgba(14, 20, 26, 0.84) 45%, rgba(9, 12, 16, 0.9));
}

body:not(.appLocked) .panel,
body:not(.appLocked) .sheetHeader,
body:not(.appLocked) .moduleHeader,
body:not(.appLocked) .tableHeader,
body:not(.appLocked) .weeklySummaryStrip,
body:not(.appLocked) .jobBreakoutCard,
body:not(.appLocked) .receiptHistory,
body:not(.appLocked) .officeSection,
body:not(.appLocked) .truckReminderPanel,
body:not(.appLocked) .moduleBody > .poSummaryGrid,
body:not(.appLocked) .moduleBody > .receiptList {
  background:
    linear-gradient(180deg, var(--lg-surface-top), var(--lg-surface-mid) 45%, var(--lg-surface-low));
  border: 1px solid var(--lg-border);
  box-shadow: var(--lg-shadow-soft);
  position: relative;
}

body:not(.appLocked) .panel::before,
body:not(.appLocked) .sheetHeader::before,
body:not(.appLocked) .moduleHeader::before,
body:not(.appLocked) .tableHeader::before,
body:not(.appLocked) .weeklySummaryStrip::before,
body:not(.appLocked) .jobBreakoutCard::before,
body:not(.appLocked) .receiptHistory::before,
body:not(.appLocked) .officeSection::before {
  content: "";
  inset: 0;
  pointer-events: none;
  position: absolute;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.02) 32%, transparent 65%);
  mix-blend-mode: screen;
  opacity: 0.55;
}

body:not(.appLocked) .panel,
body:not(.appLocked) .moduleHeader,
body:not(.appLocked) .sheetHeader {
  border-radius: var(--lg-radius-pane);
  backdrop-filter: blur(var(--lg-blur-soft));
}

body:not(.appLocked) .weeklySummaryStrip,
body:not(.appLocked) .jobBreakoutCard,
body:not(.appLocked) .receiptHistory,
body:not(.appLocked) .officeSection,
body:not(.appLocked) .truckReminderPanel {
  border-radius: var(--lg-radius-card);
}

body:not(.appLocked) .moduleHeader,
body:not(.appLocked) .sheetHeader,
body:not(.appLocked) .tableHeader {
  border-color: var(--lg-border-strong);
}

body:not(.appLocked) button,
body:not(.appLocked) .officeAccessButton,
body:not(.appLocked) .scanReviewButton,
body:not(.appLocked) .quickAddButton,
body:not(.appLocked) .primaryModuleAction {
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 12px;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.22);
}

body:not(.appLocked) .quickAddButton,
body:not(.appLocked) .primaryModuleAction,
body:not(.appLocked) .maintenancePrimaryAction {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.14), transparent 38%),
    linear-gradient(180deg, color-mix(in srgb, var(--hm-red) 74%, #3a0f16), color-mix(in srgb, var(--hm-red) 60%, #22070c));
  box-shadow: 0 12px 28px color-mix(in srgb, var(--lg-red-glow) 72%, transparent);
}

body:not(.appLocked) .jobBreakoutHeader {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.08), transparent 42%),
    linear-gradient(180deg, #1b4a3f, #153a32);
}

body:not(.appLocked) .jobBreakoutTotals {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.09), rgba(255, 255, 255, 0.03));
  border-bottom-color: rgba(255, 255, 255, 0.1);
}

body:not(.appLocked) .jobCompanyGroup {
  border-color: rgba(255, 255, 255, 0.14);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
}

body:not(.appLocked) .entryDialog,
body:not(.appLocked) .confirmDialog,
body:not(.appLocked) .receiptPreviewDialog {
  backdrop-filter: blur(var(--lg-blur-strong));
  border: 1px solid var(--lg-border-strong);
  box-shadow: var(--lg-shadow-deep);
}

body:not(.appLocked) .historyRows,
body:not(.appLocked) .receiptDirectory,
body:not(.appLocked) .officeTableWrap {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03));
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 10px;
}

/* Preserve separation and company color identity inside the glass system. */
body:not(.appLocked) .weeklySummaryPill.company-hm {
  background: linear-gradient(180deg, rgba(200, 50, 50, 0.2), rgba(200, 50, 50, 0.08));
  border-color: rgba(235, 105, 105, 0.42);
}

body:not(.appLocked) .weeklySummaryPill.company-alfa {
  background: linear-gradient(180deg, rgba(22, 138, 70, 0.22), rgba(22, 138, 70, 0.09));
  border-color: rgba(88, 201, 132, 0.42);
}

body:not(.appLocked) .weeklySummaryPill.company-sec {
  background: linear-gradient(180deg, rgba(35, 105, 209, 0.22), rgba(35, 105, 209, 0.09));
  border-color: rgba(114, 171, 251, 0.42);
}

body:not(.appLocked) .jobCompanyGroup.company-hm {
  border-color: rgba(225, 92, 92, 0.46);
  box-shadow: inset 0 0 0 1px rgba(214, 58, 58, 0.2);
}

body:not(.appLocked) .jobCompanyGroup.company-alfa {
  border-color: rgba(84, 196, 126, 0.46);
  box-shadow: inset 0 0 0 1px rgba(22, 138, 70, 0.24);
}

body:not(.appLocked) .jobCompanyGroup.company-sec {
  border-color: rgba(108, 164, 243, 0.46);
  box-shadow: inset 0 0 0 1px rgba(35, 105, 209, 0.22);
}

body:not(.appLocked) .jobCompanyGroup.company-hm h3 {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.12), transparent 42%),
    linear-gradient(180deg, #cf4545, #a62b2b);
}

body:not(.appLocked) .jobCompanyGroup.company-alfa h3 {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.12), transparent 42%),
    linear-gradient(180deg, #21a45a, #16763f);
}

body:not(.appLocked) .jobCompanyGroup.company-sec h3 {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.12), transparent 42%),
    linear-gradient(180deg, #2f78d8, #2459a4);
}

body:not(.appLocked) .savedHourMetric em {
  opacity: 0.72;
}

body:not(.appLocked) .modulePage.poDashboard {
  border-top: 2px solid rgba(200, 50, 50, 0.45);
}

body:not(.appLocked) .modulePage.maintenanceDashboard {
  border-top: 2px solid rgba(22, 138, 70, 0.45);
}

body:not(.appLocked) .modulePage.officeDashboard {
  border-top: 2px solid rgba(35, 105, 209, 0.42);
}

/* Office backrooms Liquid Glass hierarchy polish (Teammate 2 scope). */
body:not(.appLocked) #officePage {
  --office-hm-core: #c83232;
  --office-alfa-core: #168a46;
  --office-sec-core: #2369d1;
  --office-glass-line: color-mix(in srgb, #ffffff 20%, var(--unlock-border) 80%);
}

body:not(.appLocked) #officePage .officeContent {
  gap: clamp(10px, 1.1vw, 16px);
}

body:not(.appLocked) #officePage .officeMasterActions,
body:not(.appLocked) #officePage .officeCopyBar {
  align-items: stretch;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02) 60%),
    rgba(28, 33, 41, 0.94);
  border: 1px solid var(--office-glass-line);
  border-radius: 12px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.14),
    0 8px 18px rgba(0, 0, 0, 0.24);
  gap: 8px;
  grid-template-columns: repeat(auto-fit, minmax(168px, 1fr));
  padding: 8px;
}

body:not(.appLocked) #officePage .officeCopyBar button,
body:not(.appLocked) #officePage .officeMasterActions .officeSectionAction,
body:not(.appLocked) #officePage .officeSectionAction {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.03));
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 10px;
  color: #ecf2fb;
  min-height: 38px;
  padding: 7px 10px;
}

body:not(.appLocked) #officePage .officeCopyBar button:disabled,
body:not(.appLocked) #officePage .officeSectionAction:disabled {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.12);
  color: #8a98a9;
}

body:not(.appLocked) #officePage .officeCopyBar .officeActionPrimary,
body:not(.appLocked) #officePage .officeMasterActions .officeActionPrimary {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.16), transparent 42%),
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--office-hm-core) 72%, #3c1018),
      color-mix(in srgb, var(--office-hm-core) 58%, #22080e)
    );
  border-color: color-mix(in srgb, var(--office-hm-core) 46%, rgba(255, 255, 255, 0.28));
  box-shadow: 0 10px 20px rgba(200, 50, 50, 0.28);
  color: #fff;
}

body:not(.appLocked) #officePage .officeSection .officeActionTertiary,
body:not(.appLocked) #officePage .officeDetails .officeActionTertiary {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.025));
  border-color: color-mix(in srgb, #ffffff 24%, var(--unlock-border) 76%);
  color: #d6e1f0;
}

body:not(.appLocked) #officePage .officePriorityCard {
  background: rgba(255, 255, 255, 0.08);
  border-color: color-mix(in srgb, #ffffff 30%, var(--unlock-border) 70%);
  color: #ecf2fb;
}

body:not(.appLocked) #officePage .officePriorityCard strong {
  color: #ffffff;
}

body:not(.appLocked) #officePage .officePriorityCard em,
body:not(.appLocked) #officePage .officePriorityCard span {
  color: #b9c7d6;
}

body:not(.appLocked) #officePage .officePriorityCard.priority {
  border-left-color: color-mix(in srgb, #f0b83f 80%, #8c3f00);
}

body:not(.appLocked) #officePage .officePriorityCard.steady {
  border-left-color: color-mix(in srgb, #9fb0a0 75%, #2f3c4a);
}

body:not(.appLocked) #officePage .officeActionRail .officeCopyBar {
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

body:not(.appLocked) #officePage .officeSummary > .officeSection,
body:not(.appLocked) #officePage .officeContent > .officeSection,
body:not(.appLocked) #officePage .officeDetails {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.018) 58%),
    rgba(31, 36, 44, 0.94);
  border: 1px solid var(--office-glass-line);
  border-radius: 12px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.14),
    0 8px 22px rgba(0, 0, 0, 0.2);
  padding: 10px;
}

body:not(.appLocked) #officePage .officeSectionHeader {
  align-items: baseline;
  gap: 12px;
}

body:not(.appLocked) #officePage .officeSectionHeader > strong {
  opacity: 0.94;
}

body:not(.appLocked) #officePage .officeSection [data-office-company-filter].company-hm,
body:not(.appLocked) #officePage .officeDetails [data-office-company-filter].company-hm {
  border-bottom-color: color-mix(in srgb, var(--office-hm-core) 88%, #f3b1b1);
  color: color-mix(in srgb, var(--office-hm-core) 74%, #ffd6d6);
}

body:not(.appLocked) #officePage .officeSection [data-office-company-filter].company-alfa,
body:not(.appLocked) #officePage .officeDetails [data-office-company-filter].company-alfa {
  border-bottom-color: color-mix(in srgb, var(--office-alfa-core) 86%, #b9f0ca);
  color: color-mix(in srgb, var(--office-alfa-core) 72%, #d9ffe7);
}

body:not(.appLocked) #officePage .officeSection [data-office-company-filter].company-sec,
body:not(.appLocked) #officePage .officeDetails [data-office-company-filter].company-sec {
  border-bottom-color: color-mix(in srgb, var(--office-sec-core) 86%, #bad4ff);
  color: color-mix(in srgb, var(--office-sec-core) 72%, #dde9ff);
}

body:not(.appLocked) #officePage .officeSection [data-office-company-filter].company-hm.active,
body:not(.appLocked) #officePage .officeDetails [data-office-company-filter].company-hm.active {
  box-shadow: 0 0 0 1px rgba(200, 50, 50, 0.48) inset;
}

body:not(.appLocked) #officePage .officeSection [data-office-company-filter].company-alfa.active,
body:not(.appLocked) #officePage .officeDetails [data-office-company-filter].company-alfa.active {
  box-shadow: 0 0 0 1px rgba(22, 138, 70, 0.5) inset;
}

body:not(.appLocked) #officePage .officeSection [data-office-company-filter].company-sec.active,
body:not(.appLocked) #officePage .officeDetails [data-office-company-filter].company-sec.active {
  box-shadow: 0 0 0 1px rgba(35, 105, 209, 0.5) inset;
}

body:not(.appLocked) #officePage .officeSubSection + .officeSubSection,
body:not(.appLocked) #officePage .officeDetails[open] summary {
  border-top-color: color-mix(in srgb, #ffffff 18%, var(--unlock-border) 82%);
  border-bottom-color: color-mix(in srgb, #ffffff 18%, var(--unlock-border) 82%);
}

body:not(.appLocked) #officePage .officeTableWrap {
  background: rgba(24, 29, 37, 0.92);
  border: 1px solid var(--office-glass-line);
  border-radius: 11px;
}

body:not(.appLocked) #officePage .officeTable {
  border-collapse: separate;
  border-spacing: 0;
  font-variant-numeric: tabular-nums;
  min-width: 920px;
}

body:not(.appLocked) #officePage .officeTable th {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.17), rgba(255, 255, 255, 0.06)),
    rgba(26, 33, 43, 0.96);
  border-bottom: 1px solid color-mix(in srgb, #ffffff 18%, var(--unlock-border) 82%);
  color: #eef4fd;
  font-size: 11px;
  letter-spacing: 0.02em;
  padding: 6px 7px;
  position: sticky;
  top: 0;
  z-index: 2;
}

body:not(.appLocked) #officePage .officeTable td {
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  color: #d4dee9;
  font-size: 12px;
  height: 30px;
  line-height: 1.3;
  padding: 5px 7px;
  vertical-align: middle;
}

body:not(.appLocked) #officePage .officeTable tbody tr {
  background: rgba(22, 27, 34, 0.92);
}

body:not(.appLocked) #officePage .officeTable tbody tr:nth-child(even) {
  background: rgba(29, 35, 44, 0.93);
}

body:not(.appLocked) #officePage .officeTable tbody tr:hover {
  background: rgba(45, 57, 72, 0.92);
}

body:not(.appLocked) #officePage .officeTable tbody tr.officeRowDirty {
  background: color-mix(in srgb, #d6a319 22%, rgba(30, 35, 42, 0.96));
}

body:not(.appLocked) #officePage .officeTable td:nth-child(2),
body:not(.appLocked) #officePage .officeTable td:nth-child(3),
body:not(.appLocked) #officePage .officeTable td:nth-child(4) {
  color: #f0f6ff;
}

body:not(.appLocked) #officePage .officeEditField {
  background: rgba(236, 241, 248, 0.96);
  border-color: rgba(255, 255, 255, 0.38);
  height: 28px;
}

body:not(.appLocked) #officePage .officeBoardGrid {
  align-content: start;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(min(320px, 100%), 1fr));
  max-height: clamp(250px, 36vh, 420px);
  padding-right: 2px;
}

body:not(.appLocked) #officePage .officeBoardCard {
  gap: 9px;
  min-height: 218px;
  padding: 10px;
}

body:not(.appLocked) #officePage .officeBoardStats,
body:not(.appLocked) #officePage .officeBoardDays,
body:not(.appLocked) #officePage .officeBoardCompanies {
  gap: 6px;
}

body:not(.appLocked) #officePage .officeBoardCard footer {
  margin-top: 2px;
  padding-top: 7px;
}

body:not(.appLocked) #officePage .officeBoardCompany.company-hm {
  border-left-color: var(--office-hm-core);
}

body:not(.appLocked) #officePage .officeBoardCompany.company-alfa {
  border-left-color: var(--office-alfa-core);
}

body:not(.appLocked) #officePage .officeBoardCompany.company-sec {
  border-left-color: var(--office-sec-core);
}

@media (min-width: 1200px) {
  body:not(.appLocked) #officePage .officeMasterActions,
  body:not(.appLocked) #officePage .officeCopyBar {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  body:not(.appLocked) #officePage .officeMasterActions,
  body:not(.appLocked) #officePage .officeCopyBar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body:not(.appLocked) #officePage .officeBoardGrid {
    grid-template-columns: 1fr;
    max-height: clamp(280px, 44vh, 560px);
  }

  body:not(.appLocked) #officePage .officeTable {
    min-width: 820px;
  }
}

@media (max-width: 680px) {
  body:not(.appLocked) #officePage .officeMasterActions,
  body:not(.appLocked) #officePage .officeCopyBar {
    grid-template-columns: 1fr;
    padding: 7px;
  }

  body:not(.appLocked) #officePage .officeSummary > .officeSection,
  body:not(.appLocked) #officePage .officeContent > .officeSection,
  body:not(.appLocked) #officePage .officeDetails {
    border-radius: 10px;
    padding: 9px;
  }

  body:not(.appLocked) #officePage .officeSectionHeader {
    align-items: stretch;
    flex-direction: column;
    gap: 6px;
  }

  body:not(.appLocked) #officePage .officeSectionAction,
  body:not(.appLocked) #officePage .officeCopyBar button {
    min-height: 40px;
  }

  body:not(.appLocked) #officePage .officeTable {
    min-width: 700px;
  }
}

/* Redline batch: weekly clarity + refresh placement near totals. */
body:not(.appLocked) .weeklySummaryStrip {
  grid-template-columns: 1.18fr 1.08fr 1.14fr 1fr;
  padding: 7px 11px;
}

body:not(.appLocked) .weeklySummaryStrip .weeklySummaryLabel {
  font-size: 12px;
}

body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock {
  min-height: 60px;
}

body:not(.appLocked) .weeklySummaryCompactList {
  display: grid;
  gap: 2px;
  margin-top: 2px;
}

body:not(.appLocked) .weeklySummaryCompactList span {
  color: rgba(229, 236, 248, 0.9);
  font-size: 11px;
  font-style: normal;
  font-weight: 780;
  line-height: 1.2;
}

body:not(.appLocked) .weeklySummaryMissing {
  align-items: center;
  border: 1px solid rgba(173, 186, 210, 0.45);
  border-radius: 999px;
  display: inline-flex;
  font-size: 10px;
  font-style: normal;
  font-weight: 860;
  margin-top: 1px;
  max-width: fit-content;
  padding: 2px 8px;
}

body:not(.appLocked) .weeklySummaryMissing.hasMissing {
  background: rgba(214, 162, 23, 0.18);
  border-color: rgba(226, 188, 82, 0.52);
  color: #f9e8bd;
}

body:not(.appLocked) .weeklySummaryMissing.allSet {
  background: rgba(50, 161, 96, 0.16);
  border-color: rgba(97, 211, 140, 0.5);
  color: #d6f6e2;
}

body:not(.appLocked) .jobBreakoutTotals {
  align-items: center;
  gap: 10px;
}

body:not(.appLocked) .jobBreakoutTotalsRefresh {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(188, 205, 228, 0.28);
  color: #e6edf8;
  display: inline-flex;
  height: 27px;
  margin-left: auto;
  min-width: 31px;
}

/* Boss board polish pass: lighter glass tabs, cleaner geometry, stronger separation. */
body:not(.appLocked) .appHeader {
  border-radius: 6px;
  padding: 10px 12px;
}

body:not(.appLocked) .pageTabs,
body:not(.appLocked) .officeAccessButton {
  border-radius: 6px;
}

body:not(.appLocked) .pageTabs button,
body:not(.appLocked) .officeAccessButton {
  backdrop-filter: blur(9px);
  border-radius: 5px;
  min-height: 34px;
  transition:
    transform 120ms ease,
    border-color 120ms ease,
    box-shadow 120ms ease,
    background-color 120ms ease;
}

body:not(.appLocked) .pageTabs button:hover,
body:not(.appLocked) .officeAccessButton:hover {
  transform: translateY(-1px);
}

body:not(.appLocked) #scanTab {
  background: linear-gradient(180deg, rgba(109, 168, 255, 0.34), rgba(109, 168, 255, 0.12));
  border-color: rgba(153, 193, 255, 0.5);
}

body:not(.appLocked) #weeklyTab {
  background: linear-gradient(180deg, rgba(122, 204, 154, 0.34), rgba(122, 204, 154, 0.12));
  border-color: rgba(164, 229, 186, 0.5);
}

body:not(.appLocked) #poTab {
  background: linear-gradient(180deg, rgba(248, 195, 120, 0.33), rgba(248, 195, 120, 0.11));
  border-color: rgba(252, 218, 164, 0.52);
}

body:not(.appLocked) #maintenanceTab {
  background: linear-gradient(180deg, rgba(178, 160, 255, 0.33), rgba(178, 160, 255, 0.11));
  border-color: rgba(205, 194, 255, 0.5);
}

body:not(.appLocked) #officeTab {
  background: linear-gradient(180deg, rgba(240, 146, 158, 0.34), rgba(240, 146, 158, 0.11));
  border-color: rgba(247, 184, 193, 0.5);
}

body:not(.appLocked) .pageTabs button.active,
body:not(.appLocked) .officeAccessButton.active {
  box-shadow: 0 10px 26px rgba(16, 18, 23, 0.24);
  filter: saturate(1.18);
}

body:not(.appLocked) .sheetHeader,
body:not(.appLocked) .moduleHeader,
body:not(.appLocked) .tableHeader,
body:not(.appLocked) .moduleSummaryHeader {
  border-radius: 4px;
}

body:not(.appLocked) .pugProjectBoard {
  gap: 8px;
}

body:not(.appLocked) .pugProjectLane {
  border-radius: 5px;
  border-top-width: 1px;
  box-shadow:
    inset 3px 0 0 color-mix(in srgb, var(--project-accent) 84%, transparent),
    0 10px 20px rgba(8, 10, 14, 0.15);
  padding: 7px 9px;
}

body:not(.appLocked) .pugProjectLaneHeader {
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  gap: 8px;
  padding-bottom: 6px;
}

body:not(.appLocked) .pugProjectLaneHeader h3 {
  font-size: 20px;
  max-width: min(520px, 56vw);
}

body:not(.appLocked) .pugLaneStats {
  gap: 5px;
}

body:not(.appLocked) .pugLaneStats span {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--project-accent) 17%, rgba(255, 255, 255, 0.1)),
    color-mix(in srgb, var(--project-accent) 7%, rgba(255, 255, 255, 0.03))
  );
  border-color: color-mix(in srgb, var(--project-accent) 42%, rgba(255, 255, 255, 0.21));
  border-radius: 4px;
  min-height: 40px;
}

body:not(.appLocked) .pugJobCard {
  border-radius: 5px;
  border-top-width: 4px;
  gap: 7px;
  min-height: 188px;
  padding: 8px;
}

body:not(.appLocked) .pugJobCard .pugJobTop h4 {
  font-size: 21px;
}

body:not(.appLocked) .pugDayDot,
body:not(.appLocked) .pugJobStats span,
body:not(.appLocked) .pugJobCard footer,
body:not(.appLocked) .pugCompanyChip {
  border-radius: 4px;
}

body:not(.appLocked) .pugJobCard footer {
  border-top-color: color-mix(in srgb, var(--project-accent) 36%, rgba(255, 255, 255, 0.14));
}

@media (max-width: 1200px) {
  body:not(.appLocked) .pugLaneStats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    min-width: 0;
  }
}

/* Alpha polish batch: weekly readability, truck layout consistency, mobile-safe maintenance targets. */
body:not(.appLocked) #weeklySummaryStrip {
  align-items: stretch;
  background: rgba(19, 23, 29, 0.62);
  border: 1px solid rgba(191, 207, 231, 0.24);
  border-radius: 10px;
  gap: 8px;
  grid-template-columns: 1.15fr 1.25fr 1.2fr 1fr;
  padding: 8px 10px;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryBlock {
  background: rgba(255, 255, 255, 0.035);
  border: 1px solid rgba(188, 204, 228, 0.24);
  border-left: 1px solid rgba(188, 204, 228, 0.24);
  border-radius: 8px;
  min-height: 68px;
  padding: 8px 10px;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryBlock:first-child {
  border-left: 1px solid rgba(188, 204, 228, 0.24);
  padding-left: 10px;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryLabel {
  color: rgba(202, 214, 232, 0.84);
  font-size: 11px;
  font-weight: 860;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryBlock strong {
  color: #f4f8ff;
  font-size: 17px;
  line-height: 1.1;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryBlock em {
  color: rgba(195, 211, 232, 0.86);
  font-size: 11px;
  line-height: 1.2;
  white-space: normal;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryCompactList {
  display: grid;
  gap: 3px;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryCompactList span {
  color: rgba(222, 233, 247, 0.92);
  font-size: 11px;
  font-weight: 760;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryMissing {
  margin-top: 4px;
}

body:not(.appLocked) .maintenanceDashboard .moduleHeader {
  align-items: flex-start;
}

body:not(.appLocked) .truckReceiptPanel {
  align-items: stretch;
  grid-template-areas:
    "capture history"
    "reminders history";
  grid-template-columns: minmax(320px, 0.86fr) minmax(0, 1.14fr);
}

body:not(.appLocked) .truckReceiptPanel > .maintenancePrimaryAction {
  grid-area: capture;
  justify-self: stretch;
  min-height: 104px;
}

body:not(.appLocked) .truckReceiptPanel > .receiptHistory {
  grid-area: history;
}

body:not(.appLocked) .truckReceiptPanel > .truckReminderPanel {
  grid-area: reminders;
}

body:not(.appLocked) .maintenanceChoices {
  gap: 12px;
  grid-template-columns: repeat(3, minmax(240px, 1fr));
}

body:not(.appLocked) .maintenanceChoices button {
  min-height: 136px;
}

body:not(.appLocked) .maintenanceChoices button > span {
  font-size: 46px;
  height: 76px;
  width: 76px;
}

@media (max-width: 980px) {
  body:not(.appLocked) #weeklySummaryStrip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body:not(.appLocked) .truckReceiptPanel {
    grid-template-areas:
      "capture"
      "history"
      "reminders";
    grid-template-columns: minmax(0, 1fr);
  }

  body:not(.appLocked) .maintenanceChoices {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  body:not(.appLocked) #weeklySummaryStrip {
    grid-template-columns: minmax(0, 1fr);
  }

  body:not(.appLocked) .maintenanceChoices {
    grid-template-columns: minmax(0, 1fr);
  }

  body:not(.appLocked) .maintenanceChoices button {
    min-height: 126px;
  }
}

/* Alpha polish batch: reduce nested-shell feel and keep section framing consistent. */
body:not(.appLocked) .modulePage,
body:not(.appLocked) .weeklySheet {
  background: transparent;
}

body:not(.appLocked) .modulePage .moduleBody,
body:not(.appLocked) .officeDashboard .officeContent {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding-top: 8px;
}

body:not(.appLocked) .modulePage .moduleSummaryHeader,
body:not(.appLocked) .sheetHeader,
body:not(.appLocked) .moduleHeader {
  background: rgba(27, 32, 40, 0.56);
  border: 1px solid rgba(187, 202, 226, 0.2);
}

body:not(.appLocked) .poDashboard .receiptHistory,
body:not(.appLocked) .poQueuePanel,
body:not(.appLocked) .truckReminderPanel,
body:not(.appLocked) .officeSummary > .officeSection,
body:not(.appLocked) .officeDetails,
body:not(.appLocked) .scanAuditCard {
  border-color: rgba(176, 193, 220, 0.24);
}

/* Alpha polish batch: summary clarity, cleaner breakout headers, and scan-proof badge removal. */
body:not(.appLocked) #weeklySummaryStrip {
  border-radius: 8px;
  gap: 9px;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryBlock {
  border-radius: 6px;
  box-shadow: none;
  min-height: 72px;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryLabel {
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryBlock strong {
  font-size: 18px;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryBlock em {
  font-size: 12px;
}

body:not(.appLocked) .scanProofBadge {
  display: none !important;
}

body:not(.appLocked) .jobBreakoutGrid {
  gap: 8px;
}

body:not(.appLocked) .jobBreakoutCard {
  border-radius: 6px;
}

body:not(.appLocked) .jobBreakoutHeader {
  min-height: 36px;
}

body:not(.appLocked) .jobBreakoutHeader strong {
  font-size: 20px;
}

body:not(.appLocked) .jobBreakoutTotals {
  align-items: center;
}

body:not(.appLocked) .jobBreakoutTotals em {
  font-size: 11px;
}

body:not(.appLocked) .jobBreakoutResizeBar {
  height: 20px;
  padding: 0 8px 6px;
}

body:not(.appLocked) .jobBreakoutResizeBar::before {
  width: min(420px, 86%);
}

body:not(.appLocked) .jobCompanyGroup {
  border-radius: 4px;
  overflow: auto;
}

body:not(.appLocked) .jobCompanyGroup h3 {
  align-items: center;
  border-radius: 0;
  gap: 4px 10px;
  grid-template-columns: minmax(0, 1fr) auto;
  margin: 0;
  min-height: 38px;
  padding: 7px 10px 6px;
  top: 0;
  width: 100%;
}

body:not(.appLocked) .jobCompanyGroup h3 > span {
  font-size: 20px;
  font-weight: 950;
  letter-spacing: 0;
}

body:not(.appLocked) .jobCompanyGroup h3 > em {
  align-items: center;
  display: inline-flex;
  flex-wrap: nowrap;
  font-size: 11px;
  font-weight: 850;
  gap: 9px;
  justify-self: end;
  text-transform: uppercase;
  white-space: nowrap;
}

body:not(.appLocked) .jobEmployeeRow.weeklyPersonRow .savedHourTotal,
body:not(.appLocked) .savedHourMetric.savedHourTotal {
  justify-self: center;
  text-align: center;
}

body:not(.appLocked) .maintenanceChoices button > span {
  font-size: 52px;
  height: 82px;
  width: 82px;
}

/* Alpha polish pass: weekly/truck clarity and less nested visual noise. */
body:not(.appLocked) #weeklySummaryStrip {
  background: rgba(247, 250, 248, 0.92);
  border: 1px solid rgba(183, 197, 189, 0.72);
  border-radius: 8px;
  gap: 8px;
  grid-template-columns: 1.1fr 1.28fr 1.06fr 1fr;
  padding: 8px;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryBlock {
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(190, 203, 195, 0.75);
  border-left: 3px solid #7a9488;
  border-radius: 6px;
  min-height: 76px;
  padding: 8px 10px;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryWeek { border-left-color: #c83232; }
body:not(.appLocked) #weeklySummaryStrip .weeklySummaryCompanies { border-left-color: #168a46; }
body:not(.appLocked) #weeklySummaryStrip .weeklySummaryJobs { border-left-color: #2369d1; }
body:not(.appLocked) #weeklySummaryStrip .weeklySummaryCoverage { border-left-color: #1e5f4d; }

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryCompactList {
  display: grid;
  gap: 2px;
  margin-top: 2px;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryCompactList span {
  color: #5d6d65;
  font-size: 11px;
  font-weight: 820;
  line-height: 1.12;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryMissing {
  font-size: 11px;
  margin-top: 2px;
}

body:not(.appLocked) .truckReceiptPanel {
  align-items: stretch;
  gap: 10px;
  grid-template-areas:
    "capture history"
    "reminders history";
  grid-template-columns: minmax(320px, 0.84fr) minmax(420px, 1.16fr);
}

body:not(.appLocked) .truckReceiptPanel > #newTruckReceiptButton {
  justify-self: stretch;
  text-align: left;
}

body:not(.appLocked) .truckReceiptPanel > .receiptHistory {
  min-height: 210px;
}

body:not(.appLocked) .maintenanceChoices {
  gap: 12px;
  grid-template-columns: repeat(3, minmax(220px, 1fr));
}

body:not(.appLocked) .maintenanceChoices button {
  min-height: 146px;
}

body:not(.appLocked) .officeDashboard .moduleBody {
  padding-top: 6px;
}

body:not(.appLocked) .officeSummary {
  gap: 8px;
}

/* H&M App alpha UI pass: explicit week controls and calmer mobile header. */
body:not(.appLocked) .weekPickerButton {
  min-width: 118px;
  padding-inline: 14px;
  white-space: nowrap;
}

body:not(.appLocked) .weekNavButton:disabled {
  cursor: not-allowed;
  opacity: 0.42;
  transform: none;
}

body:not(.appLocked) #weeklyRange {
  color: rgba(224, 232, 242, 0.86);
  font-size: 13px;
  font-weight: 850;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryBlock {
  color: #23322b;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryLabel {
  color: #6d7f75;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryBlock strong,
body:not(.appLocked) #weeklySummaryStrip .weeklySummaryBlock b {
  color: #1f2a25;
  overflow: visible;
  text-overflow: clip;
  white-space: normal;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryBlock em,
body:not(.appLocked) #weeklySummaryStrip .weeklySummaryEmpty {
  color: #56675f;
  overflow: visible;
  text-overflow: clip;
  white-space: normal;
}

body:not(.appLocked) .scanDayBanner strong,
body:not(.appLocked) .moduleHeader h2,
body:not(.appLocked) .sheetHeader h2 {
  letter-spacing: 0;
}

body:not(.appLocked) .officeAccessButton {
  white-space: nowrap;
}

body:not(.appLocked) .installAppButton {
  border-radius: 5px;
  flex: 0 0 auto;
  min-height: 34px;
  min-width: 82px;
  padding: 6px 12px;
}

@media (max-width: 720px) {
  body:not(.appLocked) .appHeader {
    align-items: stretch;
    gap: 8px;
  }

  body:not(.appLocked) .headerActions {
    gap: 6px;
  }

  body:not(.appLocked) .pageTabs {
    gap: 3px;
    overflow-x: auto;
    padding: 4px;
  }

  body:not(.appLocked) .pageTabs button {
    min-width: 74px;
    padding-inline: 9px;
  }

  body:not(.appLocked) .officeAccessButton {
    min-width: 68px;
    padding-inline: 10px;
  }

  body:not(.appLocked) .installAppButton {
    min-width: 72px;
    padding-inline: 9px;
  }

  body:not(.appLocked) .sheetActions {
    align-items: stretch;
    display: grid;
    gap: 6px;
    grid-template-columns: 34px minmax(110px, 1fr) 34px auto auto;
  }

  body:not(.appLocked) .weekPickerButton {
    min-width: 0;
    padding-inline: 8px;
  }

  body:not(.appLocked) #weeklySummaryStrip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body:not(.appLocked) #weeklySummaryStrip .weeklySummaryBlock {
    min-height: 88px;
  }
}

/* Slice 7 guard: later desktop truck overrides must collapse on phone. */
@media (max-width: 980px) {
  .officeCompanyReadouts {
    grid-template-columns: minmax(0, 1fr);
  }

  .poWorkflowStrip {
    grid-template-columns: minmax(0, 1fr);
  }

  body:not(.appLocked) .truckReceiptPanel {
    grid-template-areas:
      "capture"
      "history"
      "reminders";
    grid-template-columns: minmax(0, 1fr);
  }

  body:not(.appLocked) .truckReceiptPanel > .receiptHistory,
  body:not(.appLocked) .truckReceiptPanel > .truckReminderPanel,
  body:not(.appLocked) .truckReceiptPanel > .maintenancePrimaryAction {
    min-width: 0;
  }

  body:not(.appLocked) .maintenanceChoices {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  body:not(.appLocked) .maintenanceChoices {
    grid-template-columns: minmax(0, 1fr);
  }

  body:not(.appLocked) .miniButtonGroup {
    grid-template-columns: minmax(0, 1fr);
    width: 100%;
  }
}

/* Vision overnight guard: final cascade for phone/1080p stability after Avenger pass. */
.pugEmptyState {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.025));
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-left: 4px solid var(--hm-red);
  border-radius: 8px;
  color: #e7edf5;
  display: grid;
  gap: 8px;
  padding: 16px;
}

.pugEmptyState strong {
  color: #fff;
  font-size: 20px;
  line-height: 1.15;
}

.pugEmptyState p {
  color: rgba(231, 237, 245, 0.78);
  font-weight: 800;
  line-height: 1.35;
  margin: 0;
}

.pugEmptyState button {
  justify-self: start;
  min-height: 36px;
}

body:not(.appLocked) .poDashboard .moduleBody {
  grid-template-columns: minmax(0, 1fr) minmax(300px, 0.4fr);
}

body:not(.appLocked) .poActionGrid {
  grid-template-columns: minmax(240px, 0.85fr) minmax(280px, 1.15fr);
}

body:not(.appLocked) .poWorkflowStrip {
  min-width: 0;
}

body:not(.appLocked) .poDashboard .receiptDirectoryRow {
  align-items: start;
  grid-template-columns: minmax(54px, auto) minmax(0, 1fr);
}

body:not(.appLocked) .poDashboard .receiptDirectoryRow .poStatusChips {
  grid-column: 1 / -1;
  justify-content: flex-start;
}

body:not(.appLocked) .truckReceiptPanel {
  grid-template-columns: minmax(260px, 0.78fr) minmax(0, 1.22fr) minmax(220px, 0.48fr);
}

body:not(.appLocked) .maintenanceDashboard .historyRows {
  max-height: min(34vh, 330px);
}

@media (max-width: 980px) {
  body:not(.appLocked) .poDashboard .moduleBody,
  body:not(.appLocked) .poActionGrid,
  body:not(.appLocked) .poWorkflowStrip,
  body:not(.appLocked) .truckReceiptPanel,
  body:not(.appLocked) #weeklySummaryStrip,
  body:not(.appLocked) .pugWeekRail,
  body:not(.appLocked) .pugHeroStats,
  body:not(.appLocked) .pugSourceSummary,
  body:not(.appLocked) .pugProjectSummary,
  body:not(.appLocked) .pugLaneStats {
    grid-template-columns: minmax(0, 1fr);
  }

  body:not(.appLocked) .poDashboard .receiptList,
  body:not(.appLocked) .poDashboard .moduleSummaryHeader,
  body:not(.appLocked) .poDashboard .poSummaryGrid {
    grid-column: auto;
    grid-row: auto;
  }

  body:not(.appLocked) .pugWeekRail span {
    line-height: 1.35;
  }
}

@media (max-width: 640px) {
  body:not(.appLocked) .pageTabs button,
  body:not(.appLocked) .officeAccessButton,
  body:not(.appLocked) .installAppButton {
    font-size: 12px;
    min-width: 68px;
  }

  body:not(.appLocked) .poWorkflowStrip span {
    min-height: 38px;
  }

  body:not(.appLocked) .pugJobTop h4,
  body:not(.appLocked) .bossHero h4 {
    font-size: 19px;
  }
}

/* McVay HQ inspired action tiles: tactile, dark, and field-app readable. */
body:not(.appLocked) .scanReviewButton,
body:not(.appLocked) .primaryModuleAction,
body:not(.appLocked) .maintenanceChoices button,
body:not(.appLocked) .weeklyStartActions button {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.105), rgba(255, 255, 255, 0.038)),
    radial-gradient(circle at 16% 12%, rgba(255, 255, 255, 0.11), transparent 28%),
    rgba(19, 28, 38, 0.78);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-left: 4px solid rgba(219, 55, 65, 0.86);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 16px 32px rgba(0, 0, 0, 0.2);
  color: #f5f7fb;
  overflow: hidden;
  position: relative;
}

body:not(.appLocked) .scanReviewButton::after,
body:not(.appLocked) .primaryModuleAction::after,
body:not(.appLocked) .maintenanceChoices button::after,
body:not(.appLocked) .weeklyStartActions button::after {
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.13), transparent);
  content: "";
  inset: 0 auto 0 -70%;
  pointer-events: none;
  position: absolute;
  transform: skewX(-18deg);
  transition: left 180ms ease;
  width: 54%;
}

body:not(.appLocked) .scanReviewButton:hover,
body:not(.appLocked) .scanReviewButton:focus-visible,
body:not(.appLocked) .primaryModuleAction:not(:disabled):hover,
body:not(.appLocked) .primaryModuleAction:not(:disabled):focus-visible,
body:not(.appLocked) .maintenanceChoices button:hover,
body:not(.appLocked) .maintenanceChoices button:focus-visible,
body:not(.appLocked) .weeklyStartActions button:hover,
body:not(.appLocked) .weeklyStartActions button:focus-visible {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.05)),
    radial-gradient(circle at 16% 12%, rgba(255, 255, 255, 0.16), transparent 30%),
    rgba(25, 37, 50, 0.9);
  border-color: rgba(255, 255, 255, 0.24);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.16),
    0 20px 38px rgba(0, 0, 0, 0.26);
  transform: translateY(-1px);
}

body:not(.appLocked) .scanReviewButton:hover::after,
body:not(.appLocked) .scanReviewButton:focus-visible::after,
body:not(.appLocked) .primaryModuleAction:not(:disabled):hover::after,
body:not(.appLocked) .primaryModuleAction:not(:disabled):focus-visible::after,
body:not(.appLocked) .maintenanceChoices button:hover::after,
body:not(.appLocked) .maintenanceChoices button:focus-visible::after,
body:not(.appLocked) .weeklyStartActions button:hover::after,
body:not(.appLocked) .weeklyStartActions button:focus-visible::after {
  left: 118%;
}

body:not(.appLocked) .scanReviewButton span[aria-hidden="true"],
body:not(.appLocked) .moduleIcon,
body:not(.appLocked) .maintenanceChoices button > span {
  background:
    linear-gradient(145deg, rgba(219, 55, 65, 0.92), rgba(116, 27, 36, 0.88)),
    rgba(219, 55, 65, 0.8);
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 10px 18px rgba(0, 0, 0, 0.22);
  color: #fff;
}

body:not(.appLocked) .scanReviewButton strong,
body:not(.appLocked) .primaryModuleAction strong,
body:not(.appLocked) .maintenanceChoices strong,
body:not(.appLocked) .weeklyStartActions button {
  color: #fff;
}

body:not(.appLocked) .primaryModuleAction small,
body:not(.appLocked) .maintenanceChoices small {
  color: rgba(232, 238, 246, 0.76);
}

body:not(.appLocked) .poWorkflowStrip span {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.025)),
    rgba(17, 26, 36, 0.7);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 9px;
  color: rgba(238, 243, 249, 0.86);
}

body:not(.appLocked) .poWorkflowStep.is-active,
body:not(.appLocked) .poWorkflowStep.is-complete {
  border-color: rgba(62, 173, 111, 0.34);
  color: #eaf8ef;
}

body:not(.appLocked) .poWorkflowStep.is-active {
  box-shadow: inset 4px 0 0 #3ead6f;
}

body:not(.appLocked) .poWorkflowStep.is-complete strong {
  background: rgba(62, 173, 111, 0.18);
  border-color: rgba(62, 173, 111, 0.32);
  color: #83dda7;
}

body:not(.appLocked) .poDashboard .receiptDirectoryRow .poDirectoryDetails small {
  color: rgba(232, 238, 246, 0.7);
}

body:not(.appLocked) .poWorkflowStrip strong {
  background: rgba(219, 55, 65, 0.18);
  border: 1px solid rgba(219, 55, 65, 0.28);
  border-radius: 999px;
  color: #ffafb7;
  display: inline-grid;
  height: 24px;
  margin-right: 6px;
  place-items: center;
  width: 24px;
}

body:not(.appLocked) .draftJobItem {
  border-style: dashed;
  opacity: 0.88;
}

body:not(.appLocked) .draftJobItem span::after {
  background: rgba(219, 55, 65, 0.14);
  border: 1px solid rgba(219, 55, 65, 0.28);
  border-radius: 999px;
  color: #ffb7bd;
  content: "replace";
  display: inline-block;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: 0.06em;
  margin-left: 6px;
  padding: 2px 6px;
  text-transform: uppercase;
}

body:not(.appLocked) .scanEmptyActionGrid {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: 14px auto 12px;
  max-width: 620px;
  width: 100%;
}

body:not(.appLocked) .scanEmptyActionGrid div {
  align-items: center;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.09), rgba(255, 255, 255, 0.028)),
    rgba(18, 27, 38, 0.72);
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: 9px;
  display: grid;
  gap: 7px;
  grid-template-columns: 28px minmax(0, 1fr);
  min-height: 48px;
  padding: 8px;
  text-align: left;
}

body:not(.appLocked) .scanEmptyActionGrid b {
  align-items: center;
  background: rgba(219, 55, 65, 0.18);
  border: 1px solid rgba(219, 55, 65, 0.3);
  border-radius: 999px;
  color: #ffc6cb;
  display: inline-flex;
  font-size: 12px;
  height: 28px;
  justify-content: center;
  width: 28px;
}

body:not(.appLocked) .scanEmptyActionGrid em {
  color: rgba(239, 244, 250, 0.82);
  font-style: normal;
  font-weight: 850;
  line-height: 1.2;
}

@media (max-width: 760px) {
  body:not(.appLocked) .scanEmptyActionGrid {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (prefers-reduced-motion: reduce) {
  body:not(.appLocked) .scanReviewButton,
  body:not(.appLocked) .primaryModuleAction,
  body:not(.appLocked) .maintenanceChoices button,
  body:not(.appLocked) .weeklyStartActions button {
    transition: none;
  }

  body:not(.appLocked) .scanReviewButton::after,
  body:not(.appLocked) .primaryModuleAction::after,
  body:not(.appLocked) .maintenanceChoices button::after,
  body:not(.appLocked) .weeklyStartActions button::after {
    display: none;
  }
}

/* Trucks page facelift: clearer readout and cleaner category cards. */
.truckHistoryReadout {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 6px;
  display: grid;
  gap: 7px;
  min-height: 58px;
  padding: 7px;
}

.truckReadoutStats {
  display: grid;
  gap: 4px;
  grid-template-columns: repeat(auto-fit, minmax(104px, 1fr));
}

.truckReadoutStats p {
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 6px;
  display: flex;
  flex-wrap: wrap;
  gap: 2px 6px;
  justify-content: space-between;
  margin: 0;
  min-height: 28px;
  padding: 5px 6px;
}

.truckReadoutStats p strong {
  color: var(--ink);
  font-size: 15px;
  line-height: 1.03;
}

.truckReadoutStats p span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
}

.truckReadoutLine {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.25;
  margin: 0;
}

.truckReadoutLine strong {
  color: var(--ink);
  display: inline;
}

.truckReadoutChips {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.truckReadoutChip {
  align-items: center;
  background: #fff;
  border: 1px solid #d8e1dc;
  border-radius: 999px;
  display: inline-flex;
  gap: 7px;
  height: 24px;
  padding: 0 9px;
}

.truckReadoutChip strong {
  color: var(--ink);
  font-size: 11px;
  font-weight: 900;
}

.truckReadoutChip em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
}

.truckHistoryGroupHeader {
  align-items: baseline;
  display: flex;
  justify-content: space-between;
  gap: 6px;
  min-height: 24px;
}

.truckHistoryCount {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.maintenanceChoices .maintenanceChoiceCard {
  align-items: center;
  display: grid;
  gap: 8px;
  grid-template-columns: 56px minmax(0, 1fr);
  justify-items: stretch;
  text-align: left;
}

.maintenanceChoiceIcon {
  align-items: center;
  background: #fff;
  border: 1px solid #dce5df;
  border-radius: 8px;
  color: var(--ink);
  display: inline-flex;
  font-size: 30px;
  height: 52px;
  justify-content: center;
  width: 52px;
}

.maintenanceChoiceText {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.maintenanceChoiceText small {
  line-height: 1.25;
  margin: 0;
}

body:not(.appLocked) .truckHistoryReadout {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.09), rgba(255, 255, 255, 0.03));
  border-color: rgba(255, 255, 255, 0.18);
}

body:not(.appLocked) .truckReadoutStats p {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.06));
  border-color: rgba(255, 255, 255, 0.16);
}

body:not(.appLocked) .truckReadoutChips {
  align-items: center;
}

body:not(.appLocked) .truckReadoutChip {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.2);
}

body:not(.appLocked) .maintenanceChoices .maintenanceChoiceCard {
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.02));
  border-left-width: 4px;
}

body:not(.appLocked) .maintenanceChoices .maintenanceChoiceIcon {
  background:
    linear-gradient(145deg, var(--hm-red) 0%, #ca3f3f 100%);
  border-color: rgba(255, 255, 255, 0.18);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    0 9px 18px rgba(0, 0, 0, 0.16);
  color: #fff;
}

body:not(.appLocked) .maintenanceChoices .maintenanceChoiceCard:hover,
body:not(.appLocked) .maintenanceChoices .maintenanceChoiceCard:focus-visible {
  border-left-color: var(--accent-dark);
}

@media (max-width: 980px) {
  .truckReadoutStats {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 760px) {
  .truckReadoutLine {
    font-size: 11px;
  }

  .maintenanceChoiceIcon {
    border-radius: 7px;
    font-size: 27px;
    height: 48px;
    width: 48px;
  }

  .maintenanceChoiceText strong {
    font-size: 13px;
  }
}

/* Site-wide visual systems pass: shared Apple-style polish without behavior changes */
body:not(.appLocked) {
  --vision-surface-top: rgba(255, 255, 255, 0.12);
  --vision-surface-bottom: rgba(255, 255, 255, 0.04);
  --vision-surface-border: rgba(255, 255, 255, 0.14);
  --vision-shadow-soft: 0 14px 34px rgba(0, 0, 0, 0.22);
  --vision-shadow-lift: 0 22px 48px rgba(0, 0, 0, 0.28);
}

body:not(.appLocked) .pageView {
  padding-bottom: 18px;
}

body:not(.appLocked) .workspace,
body:not(.appLocked) .weeklySheet,
body:not(.appLocked) .saved,
body:not(.appLocked) .moduleBody,
body:not(.appLocked) .officeContent {
  gap: 14px;
}

body:not(.appLocked) .sheetHeader,
body:not(.appLocked) .moduleHeader,
body:not(.appLocked) .weeklySummaryStrip,
body:not(.appLocked) .jobLinkCard,
body:not(.appLocked) .officeLock,
body:not(.appLocked) .officeSection,
body:not(.appLocked) .officeMetricGrid > div,
body:not(.appLocked) .bossHero,
body:not(.appLocked) .bossCompanyTotal,
body:not(.appLocked) .truckHistoryReadout,
body:not(.appLocked) .truckReminderPanel,
body:not(.appLocked) .receiptHistory,
body:not(.appLocked) .poQuickBrief > div,
body:not(.appLocked) .poWorkflowStrip span,
body:not(.appLocked) .saveApprovedWrap,
body:not(.appLocked) .scanDayBanner,
body:not(.appLocked) .reviewActions {
  background:
    linear-gradient(180deg, var(--vision-surface-top), var(--vision-surface-bottom));
  border: 1px solid var(--vision-surface-border);
  box-shadow: var(--vision-shadow-soft);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

body:not(.appLocked) .sheetHeader,
body:not(.appLocked) .moduleHeader {
  border-radius: 20px;
  min-height: 78px;
  padding: 16px 18px;
}

body:not(.appLocked) .sheetHeader h2,
body:not(.appLocked) .moduleHeader h2,
body:not(.appLocked) .moduleHeader h3,
body:not(.appLocked) .bossHero h4,
body:not(.appLocked) .officeSectionHeader h4 {
  line-height: 1.08;
}

body:not(.appLocked) .sheetHeader p,
body:not(.appLocked) .moduleHeader p,
body:not(.appLocked) .jobLinkCard p,
body:not(.appLocked) .officeLock p,
body:not(.appLocked) .maintenanceChoiceText small {
  line-height: 1.42;
}

body:not(.appLocked) .moduleStatus,
body:not(.appLocked) .weeklySummaryLabel,
body:not(.appLocked) .moduleEyebrow {
  letter-spacing: 0.04em;
}

body:not(.appLocked) .tabButton,
body:not(.appLocked) .officeAccessButton,
body:not(.appLocked) .weekNavButton,
body:not(.appLocked) .weekPickerButton,
body:not(.appLocked) .quickAddButton,
body:not(.appLocked) .iconRefreshButton {
  min-height: 38px;
  border-radius: 12px;
}

body:not(.appLocked) .primaryModuleAction,
body:not(.appLocked) .scanReviewButton,
body:not(.appLocked) .officeSectionAction,
body:not(.appLocked) .maintenanceChoiceCard,
body:not(.appLocked) .weekNavButton,
body:not(.appLocked) .weekPickerButton,
body:not(.appLocked) .quickAddButton,
body:not(.appLocked) .iconRefreshButton,
body:not(.appLocked) .miniButtonGroup button,
body:not(.appLocked) .moduleSummaryHeader button,
body:not(.appLocked) #adminLogoutButton {
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.14),
    0 10px 24px rgba(0, 0, 0, 0.18);
  transition:
    transform 160ms ease,
    box-shadow 160ms ease,
    border-color 160ms ease,
    background 160ms ease;
}

body:not(.appLocked) .primaryModuleAction:not(:disabled):hover,
body:not(.appLocked) .primaryModuleAction:not(:disabled):focus-visible,
body:not(.appLocked) .scanReviewButton:hover,
body:not(.appLocked) .scanReviewButton:focus-visible,
body:not(.appLocked) .officeSectionAction:not(:disabled):hover,
body:not(.appLocked) .officeSectionAction:not(:disabled):focus-visible,
body:not(.appLocked) .maintenanceChoiceCard:hover,
body:not(.appLocked) .maintenanceChoiceCard:focus-visible,
body:not(.appLocked) .weekNavButton:hover,
body:not(.appLocked) .weekNavButton:focus-visible,
body:not(.appLocked) .weekPickerButton:hover,
body:not(.appLocked) .weekPickerButton:focus-visible,
body:not(.appLocked) .quickAddButton:hover,
body:not(.appLocked) .quickAddButton:focus-visible,
body:not(.appLocked) .iconRefreshButton:hover,
body:not(.appLocked) .iconRefreshButton:focus-visible,
body:not(.appLocked) .miniButtonGroup button:hover,
body:not(.appLocked) .miniButtonGroup button:focus-visible,
body:not(.appLocked) .moduleSummaryHeader button:hover,
body:not(.appLocked) .moduleSummaryHeader button:focus-visible,
body:not(.appLocked) #adminLogoutButton:hover,
body:not(.appLocked) #adminLogoutButton:focus-visible {
  box-shadow: var(--vision-shadow-lift);
  transform: translateY(-1px);
}

body:not(.appLocked) .primaryModuleAction,
body:not(.appLocked) .scanReviewButton,
body:not(.appLocked) .maintenanceChoiceCard {
  border-radius: 18px;
}

body:not(.appLocked) .jobLinkCard,
body:not(.appLocked) .poQuickBrief > div,
body:not(.appLocked) .receiptHistory,
body:not(.appLocked) .truckReminderPanel,
body:not(.appLocked) .officeSummary > .officeSection,
body:not(.appLocked) .officeContent > .officeSection,
body:not(.appLocked) .bossHero,
body:not(.appLocked) .bossCompanyTotal {
  border-radius: 18px;
}

body:not(.appLocked) .weeklySummaryStrip,
body:not(.appLocked) #weeklySummaryStrip {
  gap: 12px;
  padding: 10px;
}

body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock,
body:not(.appLocked) #weeklySummaryStrip .weeklySummaryBlock {
  min-height: 94px;
  padding: 14px 16px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.16),
    0 10px 26px rgba(0, 0, 0, 0.16);
}

body:not(.appLocked) .poActionGrid,
body:not(.appLocked) .truckReceiptPanel,
body:not(.appLocked) .officeSummary {
  gap: 14px;
}

body:not(.appLocked) .poWorkflowStrip,
body:not(.appLocked) .poQuickBrief {
  gap: 12px;
}

body:not(.appLocked) .poWorkflowStrip span {
  min-height: 54px;
  padding: 10px 14px;
}

body:not(.appLocked) .reviewActions {
  align-items: stretch;
  padding: 12px;
}

body:not(.appLocked) .saveApprovedWrap {
  min-width: min(100%, 280px);
}

body:not(.appLocked) .maintenanceChoices {
  gap: 14px;
}

body:not(.appLocked) .maintenanceChoices .maintenanceChoiceCard {
  min-height: 126px;
  padding: 16px 18px;
}

body:not(.appLocked) .maintenanceChoices .maintenanceChoiceText {
  gap: 4px;
}

body:not(.appLocked) .weeklyScroller,
body:not(.appLocked) .savedGrid,
body:not(.appLocked) .poSummaryGrid,
body:not(.appLocked) .receiptList,
body:not(.appLocked) .historyRows,
body:not(.appLocked) .officeBoardGrid {
  gap: 14px;
}

body:not(.appLocked) .savedGrid > *,
body:not(.appLocked) .poSummaryGrid > *,
body:not(.appLocked) .receiptList > *,
body:not(.appLocked) .historyRows > *,
body:not(.appLocked) .officeBoardGrid > * {
  border-radius: 16px;
}

body:not(.appLocked) .empty,
body:not(.appLocked) .smallEmpty {
  border-radius: 16px;
  line-height: 1.5;
  padding: 18px;
}

body:not(.appLocked) .officeMetricGrid,
body:not(.appLocked) .officeJobStats,
body:not(.appLocked) .officeJobTotalGrid,
body:not(.appLocked) .bossCompanyTotals {
  gap: 12px;
}

body:not(.appLocked) .officeSectionHeader,
body:not(.appLocked) .moduleSummaryHeader,
body:not(.appLocked) .sheetActions {
  align-items: center;
  gap: 10px;
}

body:not(.appLocked) .officeSummary > .officeSection,
body:not(.appLocked) .officeContent > .officeSection {
  padding: 16px;
}

body:not(.appLocked) .bossHero,
body:not(.appLocked) .bossCompanyTotal {
  overflow: hidden;
}

body:not(.appLocked) .bossHero h4,
body:not(.appLocked) .bossCompanyTotal strong {
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.22);
}

body:not(.appLocked) .entryDialog,
body:not(.appLocked) .receiptPreviewDialog,
body:not(.appLocked) .confirmDialog {
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
}

@media (max-width: 980px) {
  body:not(.appLocked) .sheetHeader,
  body:not(.appLocked) .moduleHeader {
    min-height: 72px;
    padding: 14px 15px;
  }

  body:not(.appLocked) .weeklySummaryStrip,
  body:not(.appLocked) #weeklySummaryStrip,
  body:not(.appLocked) .poActionGrid,
  body:not(.appLocked) .truckReceiptPanel,
  body:not(.appLocked) .officeSummary {
    gap: 10px;
  }
}

body:not(.appLocked) #scanPage .reviewActions {
  display: grid;
  align-items: stretch;
  gap: 10px;
  grid-template-columns: minmax(360px, 2.2fr) repeat(4, minmax(116px, 1fr));
  min-height: 96px;
}

body:not(.appLocked) #scanPage .scanCaptureActions {
  display: contents;
}

body:not(.appLocked) #scanPage .scanUtilityActions {
  display: contents;
}

body:not(.appLocked) #scanPage[data-scan-stage="pre"] #scanQualityBar,
body:not(.appLocked) #scanPage[data-scan-stage="pre"] #scanPager,
body:not(.appLocked) #scanPage[data-scan-stage="pre"] .saveRequirements {
  display: none !important;
}

body:not(.appLocked) #scanPage[data-scan-stage="pre"] .saveApprovedWrap {
  opacity: 0.84;
}

body:not(.appLocked) #scanPage[data-scan-stage="ready"] .saveApprovedWrap {
  border-color: rgba(102, 199, 154, 0.42);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 0 0 1px rgba(102, 199, 154, 0.08),
    0 16px 34px rgba(0, 0, 0, 0.16);
}

.scanQuickCompanyLane {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.scanQuickCompanyHeader {
  align-items: start;
  display: grid;
  gap: 3px;
  grid-template-columns: minmax(0, 1fr);
  min-width: 0;
}

.scanQuickCompanyHeader em {
  color: rgba(232, 238, 246, 0.76);
  font-size: 11px;
  font-style: normal;
  font-weight: 800;
  line-height: 1.3;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.scanQuickCompanyHeader .moduleEyebrow {
  grid-column: 1 / -1;
  color: rgba(255, 255, 255, 0.62);
  font-size: 9px;
  letter-spacing: 0.08em;
}

.scanQuickCompanyHeader strong {
  color: #f7f9fc;
  font-size: 14px;
  font-weight: 950;
  line-height: 1.1;
}

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

.scanQuickCompanyButton {
  --company-button-top: #343a44;
  --company-button-bottom: #1f252d;
  --company-button-rim: rgba(255, 255, 255, 0.16);
  --company-button-glow: rgba(255, 255, 255, 0.08);
  align-items: center;
  column-gap: 0;
  color: #f7f7f7;
  font-family: "Avenir Next", "Avenir", "Segoe UI", "Trebuchet MS", sans-serif;
  font-size: 18px;
  font-weight: 840;
  letter-spacing: 0.02em;
  text-transform: none;
  background: none;
  border: 1px solid var(--company-button-rim);
  border-radius: 999px;
  box-sizing: border-box;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.22),
    inset 0 -12px 22px rgba(0, 0, 0, 0.18),
    0 8px 18px var(--company-button-glow);
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  line-height: 1;
  min-height: 34px;
  overflow: hidden;
  padding: 0 12px 0 10px;
  position: relative;
  text-align: center;
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.34);
  text-transform: uppercase;
  transition:
    background-color 160ms ease,
    transform 160ms ease,
    box-shadow 160ms ease,
    border-color 160ms ease,
    filter 160ms ease;
}

.scanQuickCompanyButton .quickCompanyBadge {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    linear-gradient(155deg, color-mix(in srgb, var(--company-button-top) 82%, #ffffff 18%), var(--company-button-bottom)),
    linear-gradient(180deg, color-mix(in srgb, var(--company-accent) 24%, transparent) 0%, transparent 52%);
  z-index: 0;
  border: 0.5px solid color-mix(in srgb, var(--company-accent) 50%, transparent);
}

.scanQuickCompanyButton .quickCompanyBadge::after {
  content: "";
  background: linear-gradient(180deg, transparent, rgba(255, 255, 255, 0.11));
  height: 1px;
  left: 0;
  opacity: 0.85;
  pointer-events: none;
  position: absolute;
  right: 0;
  top: 50%;
  z-index: 1;
}

.scanQuickCompanyButton .quickCompanyLabel {
  position: relative;
  z-index: 1;
  line-height: 1.05;
  overflow: visible;
  text-overflow: clip;
  white-space: nowrap;
  width: 100%;
  cursor: default;
  padding: 0;
  user-select: none;
  font-size: inherit;
  font-weight: 860;
  letter-spacing: 0.02em;
}

@media (pointer: coarse) {
  .scanQuickCompanyButton {
    font-size: 16px;
  }
}

.scanQuickCompanyButton.company-hm {
  --company-accent: #8f1525;
  --company-button-top: #9f2231;
  --company-button-bottom: #321018;
  --company-button-rim: rgba(211, 149, 151, 0.38);
  --company-button-glow: rgba(75, 11, 20, 0.22);
  border-color: rgba(221, 170, 168, 0.34);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.13),
    inset 0 0 0 1px rgba(255, 255, 255, 0.045),
    inset 0 -14px 24px rgba(13, 6, 8, 0.42),
    0 9px 20px rgba(46, 9, 15, 0.22);
}

.scanQuickCompanyButton.company-hm .quickCompanyBadge {
  background:
    radial-gradient(circle at 20% 24%, rgba(177, 42, 53, 0.24), transparent 28%),
    radial-gradient(circle at 82% 74%, rgba(8, 7, 8, 0.46), transparent 34%),
    linear-gradient(120deg, transparent 0 15%, rgba(168, 172, 171, 0.055) 15% 17%, transparent 17% 42%, rgba(8, 8, 9, 0.2) 42% 44%, transparent 44% 100%),
    repeating-linear-gradient(26deg, rgba(205, 210, 208, 0.038) 0 1px, transparent 1px 6px),
    repeating-linear-gradient(116deg, rgba(0, 0, 0, 0.16) 0 1px, transparent 1px 7px),
    linear-gradient(155deg, rgba(143, 21, 37, 0.92) 0%, rgba(111, 19, 31, 0.96) 40%, rgba(42, 39, 40, 0.98) 100%),
    linear-gradient(90deg, #4b4d4c, #222426);
  border: 1px solid rgba(196, 169, 166, 0.28);
  box-shadow:
    inset 0 1px 0 rgba(238, 236, 232, 0.1),
    inset 0 -1px 0 rgba(10, 8, 9, 0.5),
    inset 7px 0 18px rgba(168, 31, 45, 0.09),
    inset -10px 0 22px rgba(16, 14, 15, 0.34);
}

.scanQuickCompanyButton.company-hm .quickCompanyBadge::after {
  background:
    linear-gradient(180deg, rgba(239, 236, 230, 0.14), transparent 24%),
    linear-gradient(90deg, rgba(239, 236, 230, 0.18), transparent 12%, transparent 88%, rgba(239, 236, 230, 0.12));
  height: auto;
  inset: 1px;
  opacity: 0.62;
  top: 1px;
}

.scanQuickCompanyButton.company-hm .quickCompanyLabel {
  color: #fff7f4;
  font-weight: 900;
  text-shadow:
    0 1px 0 rgba(48, 0, 3, 0.72),
    0 2px 7px rgba(42, 0, 4, 0.22);
}

.scanQuickCompanyButton.company-alfa {
  --company-accent: #146f3b;
  --company-button-top: #1f884f;
  --company-button-bottom: #102e20;
  --company-button-rim: rgba(151, 215, 177, 0.38);
  --company-button-glow: rgba(16, 84, 49, 0.22);
  border-color: rgba(165, 219, 187, 0.34);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.13),
    inset 0 0 0 1px rgba(255, 255, 255, 0.045),
    inset 0 -14px 24px rgba(6, 15, 10, 0.42),
    0 9px 20px rgba(10, 47, 30, 0.22);
}

.scanQuickCompanyButton.company-alfa .quickCompanyBadge {
  background:
    radial-gradient(circle at 20% 24%, rgba(43, 151, 89, 0.24), transparent 28%),
    radial-gradient(circle at 82% 74%, rgba(5, 13, 9, 0.46), transparent 34%),
    linear-gradient(120deg, transparent 0 15%, rgba(170, 184, 176, 0.055) 15% 17%, transparent 17% 42%, rgba(7, 9, 8, 0.2) 42% 44%, transparent 44% 100%),
    repeating-linear-gradient(26deg, rgba(208, 216, 211, 0.038) 0 1px, transparent 1px 6px),
    repeating-linear-gradient(116deg, rgba(0, 0, 0, 0.16) 0 1px, transparent 1px 7px),
    linear-gradient(155deg, rgba(20, 111, 59, 0.92) 0%, rgba(26, 92, 56, 0.96) 40%, rgba(37, 43, 39, 0.98) 100%),
    linear-gradient(90deg, #4b4d4c, #222426);
  border: 1px solid rgba(172, 200, 181, 0.28);
  box-shadow:
    inset 0 1px 0 rgba(238, 236, 232, 0.1),
    inset 0 -1px 0 rgba(7, 12, 9, 0.5),
    inset 7px 0 18px rgba(32, 132, 77, 0.09),
    inset -10px 0 22px rgba(14, 18, 15, 0.34);
}

.scanQuickCompanyButton.company-alfa .quickCompanyBadge::after {
  background:
    linear-gradient(180deg, rgba(239, 236, 230, 0.14), transparent 24%),
    linear-gradient(90deg, rgba(204, 238, 217, 0.18), transparent 12%, transparent 88%, rgba(219, 243, 228, 0.12));
  height: auto;
  inset: 1px;
  opacity: 0.62;
  top: 1px;
}

.scanQuickCompanyButton.company-alfa .quickCompanyLabel {
  color: #f4fff8;
  font-weight: 900;
  text-shadow:
    0 1px 0 rgba(0, 25, 11, 0.72),
    0 2px 7px rgba(0, 20, 8, 0.22);
}

.scanQuickCompanyButton.company-sec {
  --company-accent: #1f5aa7;
  --company-button-top: #2c6ab6;
  --company-button-bottom: #102945;
  --company-button-rim: rgba(143, 186, 226, 0.4);
  --company-button-glow: rgba(23, 75, 134, 0.22);
  border-color: rgba(151, 193, 231, 0.34);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.13),
    inset 0 0 0 1px rgba(255, 255, 255, 0.045),
    inset 0 -14px 24px rgba(5, 11, 18, 0.42),
    0 9px 20px rgba(9, 36, 68, 0.22);
}

.scanQuickCompanyButton.company-sec .quickCompanyBadge {
  background:
    radial-gradient(circle at 20% 24%, rgba(49, 112, 182, 0.25), transparent 28%),
    radial-gradient(circle at 82% 74%, rgba(4, 9, 16, 0.46), transparent 34%),
    linear-gradient(120deg, transparent 0 15%, rgba(170, 180, 190, 0.055) 15% 17%, transparent 17% 42%, rgba(5, 7, 10, 0.2) 42% 44%, transparent 44% 100%),
    repeating-linear-gradient(26deg, rgba(208, 214, 219, 0.038) 0 1px, transparent 1px 6px),
    repeating-linear-gradient(116deg, rgba(0, 0, 0, 0.16) 0 1px, transparent 1px 7px),
    linear-gradient(155deg, rgba(31, 90, 167, 0.92) 0%, rgba(28, 72, 124, 0.96) 40%, rgba(35, 40, 45, 0.98) 100%),
    linear-gradient(90deg, #4b4d4c, #222426);
  border: 1px solid rgba(164, 185, 204, 0.28);
  box-shadow:
    inset 0 1px 0 rgba(238, 236, 232, 0.1),
    inset 0 -1px 0 rgba(5, 9, 14, 0.5),
    inset 7px 0 18px rgba(40, 99, 168, 0.09),
    inset -10px 0 22px rgba(12, 16, 20, 0.34);
}

.scanQuickCompanyButton.company-sec .quickCompanyBadge::after {
  background:
    linear-gradient(180deg, rgba(239, 236, 230, 0.14), transparent 24%),
    linear-gradient(90deg, rgba(204, 225, 244, 0.18), transparent 12%, transparent 88%, rgba(219, 233, 247, 0.12));
  height: auto;
  inset: 1px;
  opacity: 0.62;
  top: 1px;
}

.scanQuickCompanyButton.company-sec .quickCompanyLabel {
  color: #f4f9ff;
  font-weight: 900;
  text-shadow:
    0 1px 0 rgba(0, 11, 26, 0.72),
    0 2px 7px rgba(0, 10, 22, 0.22);
}

.scanQuickCompanyButton:hover,
.scanQuickCompanyButton:focus-visible {
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.28),
    inset 0 -12px 22px rgba(0, 0, 0, 0.14),
    0 16px 30px var(--company-button-glow),
    0 0 0 3px color-mix(in srgb, var(--company-button-rim) 42%, transparent);
  filter: saturate(1.12);
  outline: none;
  transform: translateY(-1px);
}

.scanQuickCompanyButton.active {
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--company-button-top) 92%, #ffffff 8%), var(--company-button-bottom));
  border-color: color-mix(in srgb, var(--company-button-rim) 82%, #ffffff);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.26),
    inset 0 -3px 0 color-mix(in srgb, var(--company-accent) 72%, #ffffff),
    0 16px 32px var(--company-button-glow);
  color: #fff;
}

body:not(.appLocked) #scanPage .scanReviewButton,
body:not(.appLocked) #scanPage .clearScanButton,
body:not(.appLocked) #scanPage .saveScanButton,
body:not(.appLocked) #scanPage .scanQuickCompanyButton {
  height: 100%;
  min-height: 58px;
  min-width: 0;
  width: 100%;
}

body:not(.appLocked) #scanPage .saveApprovedWrap {
  align-items: stretch;
  align-self: stretch;
  background: transparent;
  border: 0;
  display: flex;
  box-shadow: none;
  justify-content: center;
  justify-items: stretch;
  margin-left: 0;
  min-width: 0;
  padding: 0;
}

body:not(.appLocked) .scanQuickCompanyLane {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.13), rgba(255, 255, 255, 0.045)),
    radial-gradient(circle at 8% 0, rgba(200, 50, 50, 0.12), transparent 38%);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 16px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 12px 26px rgba(0, 0, 0, 0.2);
  padding: 10px 12px;
}

body:not(.appLocked) #scanPage .scanPrimaryButton {
  justify-content: center;
}

body:not(.appLocked) #scanPage .compactScanButton {
  min-width: 0;
}

body:not(.appLocked) #scanPage .clearScanButton.compactScanButton {
  padding-inline: 12px;
}

body:not(.appLocked) #scanPage .scanReviewButton,
body:not(.appLocked) #scanPage .clearScanButton,
body:not(.appLocked) #scanPage .scanQuickCompanyButton,
body:not(.appLocked) #scanPage .saveScanButton {
  border-radius: 12px;
  font-size: 12px;
  font-weight: 950;
  justify-content: center;
  padding: 0 12px;
  white-space: nowrap;
}

body:not(.appLocked) #scanPage .scanQuickCompanyButton {
  color: #fff;
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.28);
}

body:not(.appLocked) #scanPage .scanReviewButton span,
body:not(.appLocked) #scanPage .clearScanButton span {
  font-size: 16px;
}

body:not(.appLocked) #scanPage .saveApprovedWrap span,
body:not(.appLocked) #scanPage .saveApprovedWrap .saveRequirements {
  display: none;
}

body:not(.appLocked) #scanPage .saveScanButton {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.2), rgba(0, 0, 0, 0.08)),
    #2f7d63;
  border-color: rgba(144, 223, 196, 0.36);
  color: #f8fbfa;
  display: inline-flex;
  flex: 1 1 auto;
  height: 100%;
  min-height: 58px;
  min-width: 0;
  width: 100%;
}

body:not(.appLocked) #scanPage .saveScanButton:not(:disabled) {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.22), rgba(0, 0, 0, 0.1)),
    #2f9f78;
  border-color: rgba(150, 238, 207, 0.54);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.22),
    0 12px 28px rgba(33, 121, 88, 0.3);
}

body:not(.appLocked) #scanPage .saveScanButton:disabled {
  opacity: 0.78;
}

body:not(.appLocked) #scanPage .emptyScanPrompt {
  align-content: center;
  background:
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.025) 0 1px, transparent 1px 9px),
    linear-gradient(180deg, rgba(71, 82, 94, 0.28), rgba(36, 44, 54, 0.18));
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  border: 2px dashed rgba(177, 190, 204, 0.5);
  border-radius: 16px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    inset 0 -18px 42px rgba(0, 0, 0, 0.08),
    0 18px 44px rgba(0, 0, 0, 0.14);
  gap: 22px;
  justify-items: center;
  left: auto;
  margin: 0 auto;
  min-height: min(61vh, 560px);
  padding: clamp(34px, 5.5vh, 64px) clamp(34px, 4vw, 64px);
  position: relative;
  width: calc(100% - clamp(56px, 7vw, 96px));
}

body:not(.appLocked) #scanPage .emptyScanPrompt strong {
  color: #f7f9fc;
  font-size: clamp(54px, 5.4vw, 86px);
  letter-spacing: 0;
  line-height: 1;
}

body:not(.appLocked) #scanPage .emptyScanPrompt span,
body:not(.appLocked) #scanPage .emptyScanPrompt li {
  font-size: clamp(22px, 1.9vw, 30px);
  line-height: 1.4;
}

body:not(.appLocked) #scanPage .emptyScanPrompt > span {
  color: rgba(239, 244, 250, 0.82);
  font-weight: 850;
  max-width: 880px;
}

body:not(.appLocked) #scanPage .emptyScanPrompt ol {
  gap: 8px;
  max-width: 1040px;
  width: min(100%, 1040px);
}

body:not(.appLocked) #scanPage .emptyScanPrompt li {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.14);
  color: rgba(244, 248, 252, 0.9);
  padding: 14px 18px;
}

body:not(.appLocked) .scanEmptyActionGrid {
  gap: 14px;
  max-width: 980px;
}

body:not(.appLocked) .scanEmptyActionGrid div {
  border-radius: 12px;
  grid-template-columns: 48px minmax(0, 1fr);
  min-height: 72px;
  padding: 14px;
}

body:not(.appLocked) .scanEmptyActionGrid b {
  font-size: 19px;
  height: 42px;
  width: 42px;
}

body:not(.appLocked) .scanEmptyActionGrid em {
  font-size: clamp(17px, 1.25vw, 22px);
}

body:not(.appLocked) #scanPage .scanBannerMeta {
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

body:not(.appLocked) #scanPage #rowCount {
  white-space: nowrap;
}

body:not(.appLocked) .sheetHeader > div,
body:not(.appLocked) .moduleHeader > div {
  max-width: min(100%, 760px);
}

body:not(.appLocked) #weeklyRange,
body:not(.appLocked) .moduleHeader p,
body:not(.appLocked) #officeSubtitle {
  line-height: 1.35;
  max-width: 64ch;
  overflow-wrap: anywhere;
}

body:not(.appLocked) .sheetActions {
  flex-wrap: wrap;
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryBlock strong,
body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock strong {
  font-size: clamp(20px, 2vw, 26px);
}

body:not(.appLocked) #weeklySummaryStrip .weeklySummaryBlock em,
body:not(.appLocked) .weeklySummaryStrip .weeklySummaryBlock em {
  line-height: 1.35;
}

body:not(.appLocked) .poQueueList > .sourcePoButton {
  min-height: 54px;
  padding: 10px 12px;
}

body:not(.appLocked) .poWorkflowStrip span {
  align-items: center;
  display: flex;
  gap: 8px;
}

body:not(.appLocked) .poWorkflowStrip strong {
  font-size: 15px;
}

body:not(.appLocked) .truckReceiptPanel {
  align-items: start;
}

body:not(.appLocked) .truckReceiptPanel > .maintenancePrimaryAction {
  align-self: start;
}

body:not(.appLocked) .truckReceiptPanel > .receiptHistory {
  padding: 14px;
}

body:not(.appLocked) .receiptHistory .moduleSummaryHeader {
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  margin-bottom: 12px;
  padding-bottom: 10px;
}

body:not(.appLocked) .historyRows {
  gap: 10px;
}

body:not(.appLocked) .historyRows > * {
  border-radius: 14px;
}

body:not(.appLocked) .truckReminderPanel {
  min-height: 118px;
  padding: 16px;
}

body:not(.appLocked) .truckReminderPanel.urgent {
  background: linear-gradient(180deg, rgba(130, 62, 38, 0.44), rgba(91, 36, 30, 0.32));
  border-color: rgba(231, 145, 106, 0.42);
}

body:not(.appLocked) .truckReminderPanel.clear {
  background: linear-gradient(180deg, rgba(29, 95, 71, 0.38), rgba(24, 64, 54, 0.26));
  border-color: rgba(102, 199, 154, 0.32);
}

body:not(.appLocked) #officePage .moduleHeader,
body:not(.appLocked) #officePage.bossMode .moduleHeader {
  flex-wrap: wrap;
  gap: 12px;
}

body:not(.appLocked) .bossHero,
body:not(.appLocked) #officePage.bossMode .bossHero {
  align-items: flex-start;
  gap: 18px;
}

body:not(.appLocked) .bossHero > strong,
body:not(.appLocked) #officePage.bossMode .bossHero > strong {
  font-size: clamp(24px, 4.2vw, 44px);
}

body:not(.appLocked) .officeMetricGrid span,
body:not(.appLocked) .bossBigStats span,
body:not(.appLocked) .bossCompanyTotal em,
body:not(.appLocked) .officeBoardCard footer em {
  line-height: 1.35;
}

body:not(.appLocked) .officeMetricGrid strong,
body:not(.appLocked) .officeQuickBrief strong,
body:not(.appLocked) .officeCompanyReadout strong,
body:not(.appLocked) .bossBigStats strong,
body:not(.appLocked) .bossCompanyTotal strong {
  font-size: clamp(18px, 1.9vw, 24px);
}

body:not(.appLocked) .officeBoardGrid {
  gap: 16px;
}

body:not(.appLocked) .officeBoardCard {
  padding: 14px;
}

body:not(.appLocked) .officeBoardStatus {
  min-height: 28px;
}

body:not(.appLocked) #officePage .officeCopyBar,
body:not(.appLocked) #officePage .officeSectionAction {
  gap: 10px;
}

body:not(.appLocked) #officePage .officeCopyBar button,
body:not(.appLocked) #officePage .officeSectionAction,
body:not(.appLocked) #officePage .officeActionPrimary,
body:not(.appLocked) .officeLogin button {
  border-radius: 14px;
  font-size: 13px;
  min-height: 42px;
}

@media (max-width: 980px) {
  body:not(.appLocked) #scanPage .reviewActions {
    grid-template-columns: minmax(0, 1fr);
  }

  .scanQuickCompanyButtons {
    grid-template-columns: minmax(0, 1fr);
  }
}

/* Job texture system: stable gray tones that can travel from Scan to PUG/Office. */
.jobTone-1 { --job-tone-top: #3d424a; --job-tone-bottom: #242931; --job-tone-line: #5a616b; --job-tone-glow: rgba(120, 130, 142, 0.18); }
.jobTone-2 { --job-tone-top: #484a4f; --job-tone-bottom: #2c2f34; --job-tone-line: #666a72; --job-tone-glow: rgba(136, 138, 145, 0.18); }
.jobTone-3 { --job-tone-top: #353b42; --job-tone-bottom: #20262d; --job-tone-line: #515a64; --job-tone-glow: rgba(104, 118, 132, 0.18); }
.jobTone-4 { --job-tone-top: #505057; --job-tone-bottom: #303036; --job-tone-line: #71717a; --job-tone-glow: rgba(150, 150, 160, 0.18); }
.jobTone-5 { --job-tone-top: #3a3f3f; --job-tone-bottom: #232828; --job-tone-line: #596161; --job-tone-glow: rgba(119, 133, 130, 0.18); }
.jobTone-6 { --job-tone-top: #45434a; --job-tone-bottom: #2a2830; --job-tone-line: #66626e; --job-tone-glow: rgba(140, 132, 150, 0.18); }
.jobTone-7 { --job-tone-top: #42483f; --job-tone-bottom: #282e26; --job-tone-line: #626a5f; --job-tone-glow: rgba(132, 146, 124, 0.18); }
.jobTone-8 { --job-tone-top: #3e3e45; --job-tone-bottom: #25252d; --job-tone-line: #5e5e69; --job-tone-glow: rgba(126, 126, 145, 0.18); }
.jobTone-9 { --job-tone-top: #4b4644; --job-tone-bottom: #2e2a29; --job-tone-line: #6b6461; --job-tone-glow: rgba(146, 134, 128, 0.18); }
.jobTone-10 { --job-tone-top: #394148; --job-tone-bottom: #222a31; --job-tone-line: #56636d; --job-tone-glow: rgba(112, 130, 144, 0.18); }
.jobTone-11 { --job-tone-top: #484c46; --job-tone-bottom: #2b302a; --job-tone-line: #697066; --job-tone-glow: rgba(140, 150, 134, 0.18); }
.jobTone-12 { --job-tone-top: #3f444d; --job-tone-bottom: #252a34; --job-tone-line: #5f6774; --job-tone-glow: rgba(126, 140, 158, 0.18); }

body:not(.appLocked) .jobSetupItem {
  background:
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.035) 0 1px, transparent 1px 7px),
    linear-gradient(180deg, var(--job-tone-top, #3e434a), var(--job-tone-bottom, #252a30));
  border-color: color-mix(in srgb, var(--job-tone-line, #5e6570) 78%, transparent);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    inset 4px 0 0 var(--job-tone-line, #5e6570),
    0 10px 22px rgba(0, 0, 0, 0.18);
  gap: 4px 8px;
  grid-template-columns: minmax(0, 1fr) 34px;
  padding: 8px 7px 8px 10px;
  position: relative;
}

body:not(.appLocked) .jobSetupItem:hover,
body:not(.appLocked) .jobSetupItem:focus-within {
  background:
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.055) 0 1px, transparent 1px 7px),
    linear-gradient(180deg, color-mix(in srgb, var(--job-tone-top, #3e434a) 92%, #ffffff 8%), var(--job-tone-bottom, #252a30));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.16),
    inset 4px 0 0 var(--job-tone-line, #5e6570),
    0 14px 28px rgba(0, 0, 0, 0.22),
    0 0 0 2px var(--job-tone-glow, rgba(120, 130, 142, 0.16));
}

body:not(.appLocked) .jobSetupItem span {
  color: rgba(239, 244, 250, 0.7);
  grid-column: 1;
}

body:not(.appLocked) .jobSetupItem input {
  background:
    linear-gradient(180deg, #c8d0ce, #aeb8b5);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  color: #172025;
  grid-column: 1;
  grid-row: 2;
  height: 29px;
  padding: 0 9px;
}

body:not(.appLocked) .jobSetupItem input::placeholder {
  color: rgba(41, 48, 54, 0.62);
}

body:not(.appLocked) .draftJobItem {
  border-style: solid;
  opacity: 1;
}

body:not(.appLocked) .draftJobItem span::after {
  content: "";
  display: none;
}

.jobSettingsButton {
  align-items: center;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.13), rgba(255, 255, 255, 0.04));
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 999px;
  color: rgba(240, 245, 250, 0.88);
  display: inline-flex;
  font-size: 13px;
  align-self: center;
  grid-column: 2;
  grid-row: 2;
  height: 28px;
  justify-content: center;
  min-height: 0;
  min-width: 28px;
  padding: 0;
  position: static;
  width: 28px;
  z-index: 2;
}

.jobSettingsButton:hover,
.jobSettingsButton:focus-visible {
  background: rgba(255, 255, 255, 0.18);
  border-color: rgba(255, 255, 255, 0.28);
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.22);
}

body:not(.appLocked) .jobSetupItem .jobRemoveMenuButton {
  /* Single-pane Office red glass: one slab plus a matte danger glyph. */
  -webkit-backdrop-filter: blur(8px) saturate(1.25);
  backdrop-filter: blur(8px) saturate(1.25);
  background:
    radial-gradient(circle at 22% 10%, rgba(255, 255, 255, 0.14), transparent 30%),
    linear-gradient(145deg, rgba(67, 39, 48, 0.72), rgba(39, 24, 32, 0.74));
  border: 1px solid rgba(255, 151, 170, 0.34);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.16),
    inset 0 -10px 18px rgba(0, 0, 0, 0.16),
    0 9px 18px rgba(0, 0, 0, 0.22);
  color: #d84d66;
  font-size: 21px;
  font-weight: 900;
  line-height: 1;
  text-shadow:
    0 1px 0 rgba(28, 0, 7, 0.62),
    0 0 8px rgba(216, 77, 102, 0.08);
}

body:not(.appLocked) .jobSetupItem .jobRemoveMenuButton:hover,
body:not(.appLocked) .jobSetupItem .jobRemoveMenuButton:focus-visible {
  background:
    radial-gradient(circle at 22% 10%, rgba(255, 255, 255, 0.18), transparent 30%),
    linear-gradient(145deg, rgba(80, 45, 56, 0.78), rgba(45, 27, 36, 0.8));
  border-color: rgba(255, 151, 170, 0.48);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    inset 0 -10px 18px rgba(0, 0, 0, 0.14),
    0 12px 20px rgba(0, 0, 0, 0.26),
    0 0 0 3px rgba(216, 77, 102, 0.12),
    0 0 16px rgba(216, 77, 102, 0.16);
  color: #ff5b72;
  text-shadow:
    0 1px 0 rgba(28, 0, 7, 0.62),
    0 0 10px rgba(255, 91, 114, 0.2);
}

.jobSettingsMenu {
  background:
    linear-gradient(180deg, rgba(48, 52, 58, 0.98), rgba(27, 30, 35, 0.98));
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 14px;
  box-shadow: 0 22px 50px rgba(0, 0, 0, 0.36);
  display: grid;
  gap: 5px;
  min-width: 146px;
  padding: 7px;
  position: absolute;
  right: -8px;
  top: 36px;
  z-index: 20;
}

.jobSettingsMenu[hidden] {
  display: none;
}

.jobSettingsMenu button {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.1);
  color: rgba(245, 248, 252, 0.92);
  font-size: 12px;
  font-weight: 900;
  height: 32px;
  justify-content: flex-start;
  min-height: 0;
  min-width: 0;
  padding: 0 10px;
  width: 100%;
}

.jobSettingsMenu button:hover,
.jobSettingsMenu button:focus-visible {
  background: rgba(255, 255, 255, 0.12);
  border-color: var(--job-tone-line, rgba(255, 255, 255, 0.24));
}

body:not(.appLocked) .officeBoardCard[class*="jobTone-"],
body:not(.appLocked) .pugJobCard[class*="jobTone-"] {
  background:
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.035) 0 1px, transparent 1px 7px),
    linear-gradient(180deg, var(--job-tone-top, #3e434a), var(--job-tone-bottom, #252a30));
  border-color: color-mix(in srgb, var(--job-tone-line, #5e6570) 72%, transparent);
  box-shadow:
    inset 0 3px 0 var(--job-tone-line, #5e6570),
    inset 4px 0 0 var(--job-tone-line, #5e6570),
    0 14px 34px rgba(0, 0, 0, 0.2);
}

.boardCardActions {
  align-items: center;
  display: flex;
  flex: 0 0 auto;
  gap: 6px;
  justify-content: flex-end;
  min-width: max-content;
}

.boardJobSettingsButton {
  align-self: center;
  flex: 0 0 28px;
  grid-column: auto;
  grid-row: auto;
  height: 28px;
  position: static;
  width: 28px;
}

body:not(.appLocked) #scanPage .reviewActions {
  min-height: 82px;
}

body:not(.appLocked) #scanPage .scanReviewButton,
body:not(.appLocked) #scanPage .clearScanButton,
body:not(.appLocked) #scanPage .saveScanButton,
body:not(.appLocked) #scanPage .scanQuickCompanyButton {
  min-height: 46px;
}

body:not(.appLocked) #scanPage .saveScanButton {
  background:
    linear-gradient(180deg, rgba(47, 159, 120, 0.08), rgba(47, 159, 120, 0.04));
  border: 1px solid rgba(89, 202, 162, 0.54);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 10px 22px rgba(0, 0, 0, 0.18);
  color: #9de8ca;
}

body:not(.appLocked) #scanPage .saveScanButton:not(:disabled) {
  background:
    linear-gradient(90deg, rgba(47, 159, 120, 0.92) 0 50%, rgba(47, 159, 120, 0.1) 50% 100%);
  background-size: 205% 100%;
  background-position: 100% 0;
  border-color: rgba(125, 237, 197, 0.72);
  color: #dcfff2;
  transition:
    background-position 260ms ease,
    color 160ms ease,
    transform 120ms ease,
    box-shadow 160ms ease;
}

body:not(.appLocked) #scanPage .saveScanButton:not(:disabled):hover,
body:not(.appLocked) #scanPage .saveScanButton:not(:disabled):focus-visible {
  background-position: 70% 0;
}

body:not(.appLocked) #scanPage .saveScanButton:not(:disabled):active,
body:not(.appLocked) #scanPage .saveScanButton.isSubmitting {
  background-position: 0 0;
  color: #ffffff;
  transform: translateY(1px);
}

body:not(.appLocked) #scanPage .saveScanButton {
  align-items: center;
  background:
    linear-gradient(180deg, rgba(44, 82, 66, 0.18), rgba(18, 29, 25, 0.72)),
    #17231f;
  border: 1px solid rgba(77, 176, 130, 0.58);
  border-radius: 12px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 10px 22px rgba(0, 0, 0, 0.18);
  color: #9de8bf;
  display: inline-flex;
  gap: 9px;
  justify-content: center;
  text-shadow: none;
}

body:not(.appLocked) #scanPage .saveScanButton .saveButtonIcon {
  color: currentColor;
  flex: 0 0 auto;
  height: 18px;
  width: 18px;
}

body:not(.appLocked) #scanPage .saveScanButton .saveButtonIcon path {
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 3;
}

body:not(.appLocked) #scanPage .saveScanButton strong {
  color: currentColor;
  font-size: 15px;
  font-weight: 950;
  letter-spacing: 0;
  line-height: 1;
}

body:not(.appLocked) #scanPage .saveScanButton:disabled {
  cursor: default;
  opacity: 0.58;
}

body:not(.appLocked) #scanPage .saveScanButton:not(:disabled) {
  background:
    linear-gradient(90deg, rgba(44, 153, 95, 0.92) 0 50%, rgba(44, 153, 95, 0.08) 50% 100%),
    linear-gradient(180deg, rgba(44, 82, 66, 0.2), rgba(18, 29, 25, 0.72)),
    #17231f;
  background-size: 205% 100%, 100% 100%, 100% 100%;
  background-position: 100% 0, 0 0, 0 0;
  border-color: rgba(106, 218, 159, 0.76);
  color: #b8f3d0;
  transition:
    background-position 260ms ease,
    color 160ms ease,
    transform 120ms ease,
    box-shadow 160ms ease,
    border-color 160ms ease;
}

body:not(.appLocked) #scanPage .saveScanButton:not(:disabled):hover,
body:not(.appLocked) #scanPage .saveScanButton:not(:disabled):focus-visible {
  background-position: 72% 0, 0 0, 0 0;
  border-color: rgba(140, 238, 183, 0.88);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 13px 28px rgba(0, 0, 0, 0.24),
    0 0 0 3px rgba(74, 180, 124, 0.14);
  color: #d9ffe8;
  outline: none;
}

body:not(.appLocked) #scanPage .saveScanButton:not(:disabled):active,
body:not(.appLocked) #scanPage .saveScanButton.isSubmitting {
  background-position: 0 0, 0 0, 0 0;
  border-color: rgba(151, 244, 190, 0.92);
  color: #ffffff;
  transform: translateY(1px);
}

body:not(.appLocked) #scanPage[data-scan-stage="pre"] .review .tableWrap,
body:not(.appLocked) #scanPage[data-scan-stage="pre"] .review .emptyScanRow td {
  background:
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.032) 0 1px, transparent 1px 9px),
    radial-gradient(circle at 20% 10%, rgba(96, 150, 205, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(35, 47, 60, 0.9), rgba(25, 31, 39, 0.96));
}

body:not(.appLocked) #scanPage[data-scan-stage="pre"] .emptyScanPrompt {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.018), rgba(255, 255, 255, 0.006));
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-color: rgba(190, 205, 221, 0.46);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.045),
    0 18px 44px rgba(0, 0, 0, 0.08);
}

/* Weekly focused polish: state hooks, proof readability, and table empty states. */
#weeklyPage[data-weekly-state="empty"] .weeklyScroller,
#weeklyPage[data-weekly-state="pending"] .weeklyScroller {
  align-items: center;
  display: grid;
  max-height: none;
  min-height: 220px;
  overflow: visible;
}

#weeklyPage[data-weekly-state="empty"] .weeklyStartPanel,
#weeklyPage[data-weekly-state="pending"] .weeklyStartPanel {
  margin: 0;
  width: 100%;
}

#weeklyPage.weeklyStateReady .weeklyTable {
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
}

#weeklyPage.weeklyStateReady .weeklyRowSheet:last-child {
  border-bottom: 0;
}

#weeklyPage .weeklyRowSheet.company-hm > .employeeName {
  box-shadow: inset 4px 0 0 var(--hm-red);
}

#weeklyPage .weeklyRowSheet.company-alfa > .employeeName {
  box-shadow: inset 4px 0 0 var(--accent);
}

#weeklyPage .weeklyRowSheet.company-sec > .employeeName {
  box-shadow: inset 4px 0 0 #2369d1;
}

#weeklyPage .dayCell:has(.scanProofBadge),
#weeklyPage .dayCell:has(.dayProofBadge),
#weeklyPage .dayCell:has(.manualProofBadge),
#weeklyPage .dayCell.filledCell:has(.dayCellAction):has(.scanProofBadge),
#weeklyPage .dayCell.filledCell:has(.dayCellAction):has(.dayProofBadge),
#weeklyPage .dayCell.filledCell:has(.dayCellAction):has(.manualProofBadge) {
  padding-top: 30px;
}

#weeklyPage .scanProofBadge,
#weeklyPage .dayProofBadge,
#weeklyPage .manualProofBadge {
  display: inline-flex !important;
  max-width: calc(100% - 34px);
}

#weeklyPage .scanProofBadge {
  background: #e8f6ee;
  border-color: #acd8bf;
  color: #17663a;
}

#weeklyPage .dayProofBadge {
  background: #eef4ff;
  border-color: #b9ccef;
  color: #24569b;
}

#weeklyPage .manualProofBadge {
  background: #fff6d8;
  border-color: #e5ca70;
  color: #705315;
}

body:not(.appLocked) #weeklyPage.weeklyStateReady .weeklyTable {
  border-color: #3a414b;
}

body:not(.appLocked) #weeklyPage[data-weekly-state="empty"] .weeklyStartPanel,
body:not(.appLocked) #weeklyPage[data-weekly-state="pending"] .weeklyStartPanel {
  background: linear-gradient(180deg, #252a32 0, #1f232a 100%);
  border-color: #414852;
  color: #c5ceda;
}

body:not(.appLocked) #weeklyPage[data-weekly-state="empty"] .weeklyStartPanel p,
body:not(.appLocked) #weeklyPage[data-weekly-state="pending"] .weeklyStartPanel p,
body:not(.appLocked) #weeklyPage[data-weekly-state="empty"] .weeklyStartChecklist span,
body:not(.appLocked) #weeklyPage[data-weekly-state="pending"] .weeklyStartChecklist span {
  color: #d9e0ea;
}

body:not(.appLocked) #weeklyPage[data-weekly-state="empty"] .weeklyStartChecklist div,
body:not(.appLocked) #weeklyPage[data-weekly-state="pending"] .weeklyStartChecklist div {
  background: #1b1f25;
  border-color: #3f4650;
}

body:not(.appLocked) #weeklyPage .scanProofBadge {
  background: rgba(62, 173, 111, 0.16);
  border-color: rgba(62, 173, 111, 0.38);
  color: #92e1b2;
}

body:not(.appLocked) #weeklyPage .dayProofBadge {
  background: rgba(77, 145, 240, 0.16);
  border-color: rgba(77, 145, 240, 0.38);
  color: #a9c8ff;
}

body:not(.appLocked) #weeklyPage .manualProofBadge {
  background: rgba(249, 211, 107, 0.16);
  border-color: rgba(249, 211, 107, 0.4);
  color: #f5db86;
}

/* Trucks focused polish: live stats, clearer receipt grouping, and stronger category cards. */
.truckHeroStats {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  width: 100%;
}

.truckHeroStats div {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  gap: 4px;
  min-height: 66px;
  padding: 11px 12px;
}

.truckHeroStats span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  line-height: 1.2;
  text-transform: uppercase;
}

.truckHeroStats strong {
  color: var(--ink);
  font-size: 20px;
  font-weight: 950;
  line-height: 1.05;
  overflow-wrap: anywhere;
}

.truckHistoryGroup {
  display: grid;
  gap: 8px;
}

.truckHistoryGroup .historyRow {
  grid-template-columns: auto minmax(0, 1fr);
}

.truckHistoryGroup .historyRow em {
  grid-column: 2;
}

.truckReadoutStats p strong {
  min-width: 0;
  overflow-wrap: anywhere;
}

.truckReminderPanel {
  position: relative;
}

.truckReminderPanel::before {
  background: var(--accent);
  border-radius: 999px;
  content: "";
  height: calc(100% - 24px);
  left: 10px;
  opacity: 0.45;
  position: absolute;
  top: 12px;
  width: 4px;
}

.truckReminderPanel > * {
  margin-left: 10px;
  position: relative;
  z-index: 1;
}

.truckReminderPanel.overdue::before,
.truckReminderPanel.urgent::before {
  background: #f2a15f;
  opacity: 0.85;
}

.truckReminderPanel.clear::before {
  background: #3ead6f;
  opacity: 0.8;
}

.truckReminderPanel p strong {
  color: inherit;
  display: inline;
}

.maintenanceChoices .maintenanceChoiceCard {
  grid-template-columns: 56px minmax(0, 1fr) auto;
  isolation: isolate;
}

.maintenanceChoices .maintenanceChoiceText {
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  grid-row: auto;
  height: auto;
  width: auto;
}

.maintenanceChoiceCount {
  align-self: start;
  align-items: center;
  background: #f4f7f8;
  border: 1px solid #d8e1dc;
  border-radius: 999px;
  color: var(--muted);
  display: inline-flex;
  font-size: 11px;
  font-weight: 950;
  grid-row: auto;
  height: auto;
  justify-content: center;
  justify-self: end;
  line-height: 1;
  min-width: 54px;
  padding: 7px 9px;
  text-align: center;
  white-space: nowrap;
  width: auto;
}

.maintenanceChoiceCard[data-receipt-count]:not([data-receipt-count="0"]) .maintenanceChoiceCount {
  background: #eaf6ef;
  border-color: #b9dfc8;
  color: #21683d;
}

body:not(.appLocked) .truckHeroStats div {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.035));
  border-color: rgba(255, 255, 255, 0.14);
  box-shadow: var(--vision-shadow-soft);
}

body:not(.appLocked) .truckHeroStats span {
  color: rgba(219, 229, 240, 0.72);
}

body:not(.appLocked) .truckHeroStats strong {
  color: #fff;
}

body:not(.appLocked) .truckReadoutStats p {
  min-height: 42px;
  padding: 8px 9px;
}

body:not(.appLocked) .truckHistoryGroup {
  background: rgba(255, 255, 255, 0.035);
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 14px;
  padding: 10px;
}

body:not(.appLocked) .truckHistoryGroup .historyRow {
  background: rgba(255, 255, 255, 0.055);
  border-color: rgba(255, 255, 255, 0.11);
}

body:not(.appLocked) .truckReminderPanel.overdue {
  background: linear-gradient(180deg, rgba(133, 45, 35, 0.5), rgba(80, 31, 31, 0.36));
  border-color: rgba(244, 142, 107, 0.5);
}

body:not(.appLocked) .maintenanceChoices .maintenanceChoiceText,
body:not(.appLocked) .maintenanceChoices .maintenanceChoiceCount {
  box-shadow: none;
}

body:not(.appLocked) .maintenanceChoices .maintenanceChoiceText {
  background: transparent;
  border: 0;
  color: inherit;
}

body:not(.appLocked) .maintenanceChoices .maintenanceChoiceCount {
  background: rgba(255, 255, 255, 0.11);
  border-color: rgba(255, 255, 255, 0.18);
  color: rgba(238, 243, 249, 0.78);
}

body:not(.appLocked) .maintenanceChoiceCard[data-receipt-count]:not([data-receipt-count="0"]) .maintenanceChoiceCount {
  background: rgba(62, 173, 111, 0.18);
  border-color: rgba(62, 173, 111, 0.36);
  color: #a6e8bf;
}

/* PUG presentation palette: project lanes get their own texture packet, separate from job cards. */
:root {
  --project-tone-1-top: #24313c;
  --project-tone-1-bottom: #172027;
  --project-tone-1-line: rgba(105, 139, 166, 0.48);
  --project-tone-1-glow: rgba(68, 125, 168, 0.22);
  --project-tone-2-top: #352a2d;
  --project-tone-2-bottom: #20191d;
  --project-tone-2-line: rgba(176, 99, 102, 0.48);
  --project-tone-2-glow: rgba(170, 68, 76, 0.22);
  --project-tone-3-top: #2d342b;
  --project-tone-3-bottom: #1b221b;
  --project-tone-3-line: rgba(124, 163, 118, 0.46);
  --project-tone-3-glow: rgba(89, 143, 82, 0.2);
  --project-tone-4-top: #343028;
  --project-tone-4-bottom: #211d18;
  --project-tone-4-line: rgba(181, 147, 91, 0.44);
  --project-tone-4-glow: rgba(164, 121, 51, 0.19);
  --project-tone-5-top: #302b38;
  --project-tone-5-bottom: #1e1a25;
  --project-tone-5-line: rgba(150, 119, 179, 0.44);
  --project-tone-5-glow: rgba(126, 81, 170, 0.19);
  --project-tone-6-top: #253638;
  --project-tone-6-bottom: #172324;
  --project-tone-6-line: rgba(93, 162, 167, 0.43);
  --project-tone-6-glow: rgba(57, 143, 151, 0.18);
  --project-tone-7-top: #382c26;
  --project-tone-7-bottom: #241b17;
  --project-tone-7-line: rgba(179, 118, 82, 0.44);
  --project-tone-7-glow: rgba(167, 88, 47, 0.18);
  --project-tone-8-top: #2a3140;
  --project-tone-8-bottom: #191f29;
  --project-tone-8-line: rgba(112, 136, 190, 0.43);
  --project-tone-8-glow: rgba(80, 104, 177, 0.18);
  --project-tone-9-top: #30342f;
  --project-tone-9-bottom: #1d211c;
  --project-tone-9-line: rgba(151, 162, 117, 0.42);
  --project-tone-9-glow: rgba(130, 146, 77, 0.17);
  --project-tone-10-top: #372b34;
  --project-tone-10-bottom: #211a20;
  --project-tone-10-line: rgba(174, 111, 157, 0.42);
  --project-tone-10-glow: rgba(161, 74, 135, 0.17);
  --project-tone-11-top: #283538;
  --project-tone-11-bottom: #182123;
  --project-tone-11-line: rgba(117, 167, 178, 0.42);
  --project-tone-11-glow: rgba(78, 143, 157, 0.17);
  --project-tone-12-top: #343232;
  --project-tone-12-bottom: #202020;
  --project-tone-12-line: rgba(163, 151, 140, 0.42);
  --project-tone-12-glow: rgba(139, 121, 105, 0.16);
  --project-tone-13-top: #293537;
  --project-tone-13-bottom: #192223;
  --project-tone-13-line: rgba(106, 173, 147, 0.42);
  --project-tone-13-glow: rgba(67, 151, 118, 0.17);
  --project-tone-14-top: #332d39;
  --project-tone-14-bottom: #201b26;
  --project-tone-14-line: rgba(143, 126, 185, 0.42);
  --project-tone-14-glow: rgba(105, 88, 171, 0.17);
  --project-tone-15-top: #373027;
  --project-tone-15-bottom: #211d18;
  --project-tone-15-line: rgba(179, 139, 96, 0.42);
  --project-tone-15-glow: rgba(156, 111, 58, 0.17);
}

body:not(.appLocked) .pugProjectLane[class*="projectTone-"] {
  --project-lane-top: #2a3038;
  --project-lane-bottom: #1a1e24;
  --project-lane-line: rgba(138, 152, 166, 0.4);
  --project-lane-glow: rgba(101, 132, 158, 0.18);
  background:
    radial-gradient(circle at 4% 0, var(--project-lane-glow), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.055), transparent 34%),
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.034) 0 1px, transparent 1px 9px),
    linear-gradient(180deg, var(--project-lane-top), var(--project-lane-bottom));
  border: 1px solid color-mix(in srgb, var(--project-lane-line) 86%, transparent);
  border-radius: 10px;
  box-shadow:
    0 16px 44px rgba(0, 0, 0, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    inset 4px 0 0 color-mix(in srgb, var(--project-lane-line) 72%, transparent);
  padding: 10px 12px 12px;
  position: relative;
  overflow: hidden;
}

body:not(.appLocked) .pugProjectLane[class*="projectTone-"]::before {
  background:
    linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.14), transparent),
    linear-gradient(90deg, var(--project-lane-line), transparent 36%, var(--project-lane-glow) 68%, transparent);
  content: "";
  height: 1px;
  inset: 0 0 auto;
  opacity: 0.75;
  position: absolute;
}

body:not(.appLocked) .pugProjectLane[class*="projectTone-"]::after {
  background: radial-gradient(circle at 100% 0, var(--project-lane-glow), transparent 28%);
  content: "";
  inset: 0;
  opacity: 0.8;
  pointer-events: none;
  position: absolute;
}

body:not(.appLocked) .pugProjectLane[class*="projectTone-"] > * {
  position: relative;
  z-index: 1;
}

body:not(.appLocked) .pugProjectLane[class*="projectTone-"] .pugProjectLaneHeader {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.025)),
    linear-gradient(90deg, var(--project-lane-glow), transparent 48%);
  border: 1px solid color-mix(in srgb, var(--project-lane-line) 68%, transparent);
  border-radius: 8px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 10px 24px rgba(0, 0, 0, 0.16);
  margin-bottom: 10px;
  padding: 8px 10px;
}

body:not(.appLocked) .pugProjectLane[class*="projectTone-"] .pugProjectLaneHeader h3 {
  color: color-mix(in srgb, var(--project-lane-line) 62%, #f8fbff);
  text-shadow: 0 1px 12px var(--project-lane-glow);
}

body:not(.appLocked) .pugProjectLane[class*="projectTone-"] .pugLaneStats span {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.025));
  border-color: color-mix(in srgb, var(--project-lane-line) 55%, transparent);
}

body:not(.appLocked) .pugProjectLane.projectTone-1 {
  --project-lane-top: var(--project-tone-1-top);
  --project-lane-bottom: var(--project-tone-1-bottom);
  --project-lane-line: var(--project-tone-1-line);
  --project-lane-glow: var(--project-tone-1-glow);
}

body:not(.appLocked) .pugProjectLane.projectTone-2 {
  --project-lane-top: var(--project-tone-2-top);
  --project-lane-bottom: var(--project-tone-2-bottom);
  --project-lane-line: var(--project-tone-2-line);
  --project-lane-glow: var(--project-tone-2-glow);
}

body:not(.appLocked) .pugProjectLane.projectTone-3 {
  --project-lane-top: var(--project-tone-3-top);
  --project-lane-bottom: var(--project-tone-3-bottom);
  --project-lane-line: var(--project-tone-3-line);
  --project-lane-glow: var(--project-tone-3-glow);
}

body:not(.appLocked) .pugProjectLane.projectTone-4 {
  --project-lane-top: var(--project-tone-4-top);
  --project-lane-bottom: var(--project-tone-4-bottom);
  --project-lane-line: var(--project-tone-4-line);
  --project-lane-glow: var(--project-tone-4-glow);
}

body:not(.appLocked) .pugProjectLane.projectTone-5 {
  --project-lane-top: var(--project-tone-5-top);
  --project-lane-bottom: var(--project-tone-5-bottom);
  --project-lane-line: var(--project-tone-5-line);
  --project-lane-glow: var(--project-tone-5-glow);
}

body:not(.appLocked) .pugProjectLane.projectTone-6 {
  --project-lane-top: var(--project-tone-6-top);
  --project-lane-bottom: var(--project-tone-6-bottom);
  --project-lane-line: var(--project-tone-6-line);
  --project-lane-glow: var(--project-tone-6-glow);
}

body:not(.appLocked) .pugProjectLane.projectTone-7 {
  --project-lane-top: var(--project-tone-7-top);
  --project-lane-bottom: var(--project-tone-7-bottom);
  --project-lane-line: var(--project-tone-7-line);
  --project-lane-glow: var(--project-tone-7-glow);
}

body:not(.appLocked) .pugProjectLane.projectTone-8 {
  --project-lane-top: var(--project-tone-8-top);
  --project-lane-bottom: var(--project-tone-8-bottom);
  --project-lane-line: var(--project-tone-8-line);
  --project-lane-glow: var(--project-tone-8-glow);
}

body:not(.appLocked) .pugProjectLane.projectTone-9 {
  --project-lane-top: var(--project-tone-9-top);
  --project-lane-bottom: var(--project-tone-9-bottom);
  --project-lane-line: var(--project-tone-9-line);
  --project-lane-glow: var(--project-tone-9-glow);
}

body:not(.appLocked) .pugProjectLane.projectTone-10 {
  --project-lane-top: var(--project-tone-10-top);
  --project-lane-bottom: var(--project-tone-10-bottom);
  --project-lane-line: var(--project-tone-10-line);
  --project-lane-glow: var(--project-tone-10-glow);
}

body:not(.appLocked) .pugProjectLane.projectTone-11 {
  --project-lane-top: var(--project-tone-11-top);
  --project-lane-bottom: var(--project-tone-11-bottom);
  --project-lane-line: var(--project-tone-11-line);
  --project-lane-glow: var(--project-tone-11-glow);
}

body:not(.appLocked) .pugProjectLane.projectTone-12 {
  --project-lane-top: var(--project-tone-12-top);
  --project-lane-bottom: var(--project-tone-12-bottom);
  --project-lane-line: var(--project-tone-12-line);
  --project-lane-glow: var(--project-tone-12-glow);
}

body:not(.appLocked) .pugProjectLane.projectTone-13 {
  --project-lane-top: var(--project-tone-13-top);
  --project-lane-bottom: var(--project-tone-13-bottom);
  --project-lane-line: var(--project-tone-13-line);
  --project-lane-glow: var(--project-tone-13-glow);
}

body:not(.appLocked) .pugProjectLane.projectTone-14 {
  --project-lane-top: var(--project-tone-14-top);
  --project-lane-bottom: var(--project-tone-14-bottom);
  --project-lane-line: var(--project-tone-14-line);
  --project-lane-glow: var(--project-tone-14-glow);
}

body:not(.appLocked) .pugProjectLane.projectTone-15 {
  --project-lane-top: var(--project-tone-15-top);
  --project-lane-bottom: var(--project-tone-15-bottom);
  --project-lane-line: var(--project-tone-15-line);
  --project-lane-glow: var(--project-tone-15-glow);
}

/* McVay HQ-inspired compact app section tiles. */
body:not(.appLocked) .appHeader .headerActions {
  align-items: center;
  display: flex;
  gap: 7px;
}

body:not(.appLocked) .appHeader .pageTabs {
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  display: inline-flex;
  gap: 7px;
  padding: 0;
}

body:not(.appLocked) .appHeader .pageTabs button,
body:not(.appLocked) .appHeader .officeAccessButton {
  --nav-tile-top: #303743;
  --nav-tile-bottom: #1d222b;
  --nav-tile-core-a: #66758a;
  --nav-tile-core-b: #283342;
  --nav-tile-rim: rgba(178, 194, 213, 0.34);
  --nav-tile-glow: rgba(124, 153, 190, 0.22);
  align-items: center;
  appearance: none;
  background:
    radial-gradient(circle at 22% 10%, rgba(255, 255, 255, 0.18), transparent 30%),
    linear-gradient(145deg, color-mix(in srgb, var(--nav-tile-top) 84%, #ffffff 16%), var(--nav-tile-bottom));
  border: 1px solid var(--nav-tile-rim);
  border-radius: 10px;
  box-shadow:
    0 9px 18px rgba(0, 0, 0, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.16),
    inset 0 -10px 20px rgba(0, 0, 0, 0.16);
  color: rgba(248, 251, 255, 0.94);
  display: inline-grid;
  font-size: 12px;
  font-weight: 950;
  grid-template-columns: 31px minmax(0, 1fr);
  gap: 8px;
  justify-content: stretch;
  letter-spacing: 0;
  line-height: 1;
  min-height: 41px;
  min-width: 96px;
  overflow: hidden;
  padding: 6px 10px 6px 7px;
  position: relative;
  text-shadow: 0 1px 12px rgba(0, 0, 0, 0.24);
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease,
    filter 160ms ease;
}

body:not(.appLocked) .appHeader .pageTabs button::before,
body:not(.appLocked) .appHeader .officeAccessButton::before {
  background:
    radial-gradient(circle at 74% 18%, rgba(255, 255, 255, 0.34), transparent 34%),
    repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.055) 0 1px, rgba(0, 0, 0, 0.045) 1px 3px),
    linear-gradient(145deg, var(--nav-tile-core-a), var(--nav-tile-core-b));
  border: 1px solid color-mix(in srgb, var(--nav-tile-rim) 72%, rgba(255, 255, 255, 0.16));
  border-radius: 8px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.22),
    0 8px 16px var(--nav-tile-glow);
  content: "";
  height: 29px;
  left: 7px;
  opacity: 0.96;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 31px;
  z-index: 0;
}

body:not(.appLocked) .appHeader .pageTabs button::after,
body:not(.appLocked) .appHeader .officeAccessButton::after {
  background:
    linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.24), transparent),
    linear-gradient(90deg, var(--nav-tile-rim), transparent);
  content: "";
  height: 1px;
  inset: 0 8px auto;
  opacity: 0.62;
  position: absolute;
}

body:not(.appLocked) .appHeader .tabIcon {
  align-items: center;
  align-self: center;
  display: grid;
  font-size: 15px;
  grid-column: 1;
  height: 29px;
  justify-content: center;
  line-height: 1;
  place-items: center;
  position: relative;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.32);
  transform: translateY(-0.5px);
  width: 31px;
  z-index: 1;
}

body:not(.appLocked) .appHeader .tabLabel {
  align-self: center;
  display: block;
  grid-column: 2;
  justify-self: stretch;
  min-width: 0;
  overflow: hidden;
  position: relative;
  text-align: center;
  text-overflow: ellipsis;
  white-space: nowrap;
  z-index: 1;
}

body:not(.appLocked) .appHeader .pageTabs button:hover,
body:not(.appLocked) .appHeader .pageTabs button:focus-visible,
body:not(.appLocked) .appHeader .officeAccessButton:hover,
body:not(.appLocked) .appHeader .officeAccessButton:focus-visible {
  border-color: color-mix(in srgb, var(--nav-tile-rim) 76%, #ffffff);
  box-shadow:
    0 13px 26px rgba(0, 0, 0, 0.28),
    0 0 0 3px color-mix(in srgb, var(--nav-tile-glow) 72%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    inset 0 -10px 20px rgba(0, 0, 0, 0.14);
  filter: saturate(1.12);
  transform: translateY(-2px);
}

body:not(.appLocked) .appHeader .pageTabs button:active,
body:not(.appLocked) .appHeader .officeAccessButton:active {
  box-shadow:
    0 6px 12px rgba(0, 0, 0, 0.22),
    inset 0 1px 8px rgba(0, 0, 0, 0.18);
  transform: translateY(1px) scale(0.985);
}

body:not(.appLocked) .appHeader .pageTabs button.active,
body:not(.appLocked) .appHeader .officeAccessButton.active {
  background:
    radial-gradient(circle at 18% 0, rgba(255, 255, 255, 0.24), transparent 32%),
    linear-gradient(145deg, color-mix(in srgb, var(--nav-tile-core-a) 36%, var(--nav-tile-top)), color-mix(in srgb, var(--nav-tile-core-b) 42%, var(--nav-tile-bottom)));
  border-color: color-mix(in srgb, var(--nav-tile-rim) 88%, #ffffff);
  box-shadow:
    0 14px 28px color-mix(in srgb, var(--nav-tile-glow) 64%, rgba(0, 0, 0, 0.22)),
    inset 0 1px 0 rgba(255, 255, 255, 0.22),
    inset 0 -3px 0 color-mix(in srgb, var(--nav-tile-core-a) 74%, #ffffff);
  filter: saturate(1.22);
}

body:not(.appLocked) .appHeader #scanTab {
  --nav-tile-top: #253449;
  --nav-tile-bottom: #152235;
  --nav-tile-core-a: #0a84ff;
  --nav-tile-core-b: #064a91;
  --nav-tile-rim: rgba(127, 198, 255, 0.56);
  --nav-tile-glow: rgba(10, 132, 255, 0.28);
}

body:not(.appLocked) .appHeader #weeklyTab {
  --nav-tile-top: #253b31;
  --nav-tile-bottom: #17261f;
  --nav-tile-core-a: #22a66d;
  --nav-tile-core-b: #0d6642;
  --nav-tile-rim: rgba(108, 245, 175, 0.48);
  --nav-tile-glow: rgba(34, 166, 109, 0.25);
}

body:not(.appLocked) .appHeader #poTab {
  --nav-tile-top: #413625;
  --nav-tile-bottom: #251f16;
  --nav-tile-core-a: #ff9f0a;
  --nav-tile-core-b: #9f5d08;
  --nav-tile-rim: rgba(255, 211, 112, 0.52);
  --nav-tile-glow: rgba(255, 159, 10, 0.23);
}

body:not(.appLocked) .appHeader #maintenanceTab {
  --nav-tile-top: #302a45;
  --nav-tile-bottom: #1d1930;
  --nav-tile-core-a: #8a5cf6;
  --nav-tile-core-b: #4d2e91;
  --nav-tile-rim: rgba(195, 154, 255, 0.52);
  --nav-tile-glow: rgba(138, 92, 246, 0.24);
}

body:not(.appLocked) .appHeader #officeTab {
  --nav-tile-top: #432730;
  --nav-tile-bottom: #271820;
  --nav-tile-core-a: #d84d66;
  --nav-tile-core-b: #8d2a3b;
  --nav-tile-rim: rgba(255, 151, 170, 0.5);
  --nav-tile-glow: rgba(216, 77, 102, 0.24);
}

body:not(.appLocked) .appHeader #weeklyTab,
body:not(.appLocked) .appHeader #maintenanceTab {
  min-width: 105px;
}

body:not(.appLocked) .appHeader #poTab {
  min-width: 88px;
}

@media (max-width: 860px) {
  body:not(.appLocked) .appHeader .headerActions {
    align-items: stretch;
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
  }

  body:not(.appLocked) .appHeader .pageTabs {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  body:not(.appLocked) .appHeader .pageTabs button,
  body:not(.appLocked) .appHeader .officeAccessButton {
    min-width: 0;
    width: 100%;
  }
}

@media (max-width: 980px) {
  .truckHeroStats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .truckHeroStats div:last-child {
    grid-column: 1 / -1;
  }
}

@media (max-width: 640px) {
  .truckHeroStats {
    grid-template-columns: minmax(0, 1fr);
  }

  .truckHeroStats div:last-child {
    grid-column: auto;
  }

  .maintenanceChoices .maintenanceChoiceCard {
    grid-template-columns: 48px minmax(0, 1fr);
  }

  .maintenanceChoiceCount {
    grid-column: 2;
    justify-self: start;
  }
}

/* Scan page material facelift - 2026-05-27
   CSS-only pass based on the H&M UI reference boards. Keeps scan/upload/save logic intact. */
body:not(.appLocked) #scanPage {
  --scan-bg-deep: #080a0d;
  --scan-graphite: #12171d;
  --scan-worksite: #1b222a;
  --scan-slate: #252c35;
  --scan-slate-2: #303741;
  --scan-text: #f4f7fb;
  --scan-muted: rgba(221, 229, 238, 0.72);
  --scan-faint: rgba(221, 229, 238, 0.52);
  --scan-line: rgba(197, 211, 226, 0.18);
  --scan-line-strong: rgba(221, 232, 242, 0.32);
  --scan-blue: #2fa7ff;
  --scan-blue-deep: #0f3d69;
  --scan-hm-maroon: #7a1e2c;
  --scan-hm-red: #a52635;
  --scan-alfa: #1e7b4c;
  --scan-alfa-bright: #22c55e;
  --scan-sec: #1e4c7a;
  --scan-sec-bright: #2f8fe8;
  --scan-submit: #2d9a66;
  --scan-danger: #ff3b30;
  --scan-rim: rgba(255, 255, 255, 0.2);
  --scan-shadow: 0 18px 42px rgba(0, 0, 0, 0.32);
  --scan-shadow-tight: 0 10px 24px rgba(0, 0, 0, 0.24);
  --scan-metal-noise:
    repeating-linear-gradient(105deg, rgba(255, 255, 255, 0.035) 0 1px, transparent 1px 7px),
    repeating-linear-gradient(18deg, rgba(0, 0, 0, 0.1) 0 1px, transparent 1px 9px);
  --scan-graphite-surface:
    radial-gradient(circle at 14% 0, rgba(89, 113, 136, 0.18), transparent 36%),
    radial-gradient(circle at 86% 12%, rgba(122, 30, 44, 0.12), transparent 32%),
    var(--scan-metal-noise),
    linear-gradient(180deg, rgba(34, 41, 50, 0.96), rgba(15, 19, 25, 0.98));
}

body:not(.appLocked) #scanPage .workspace {
  align-items: stretch;
  gap: 14px;
  grid-template-columns: minmax(280px, 350px) minmax(0, 1fr);
  margin-bottom: 0;
  min-height: calc(100vh - 108px);
}

body:not(.appLocked) #scanPage .panel {
  background: var(--scan-graphite-surface);
  border: 1px solid var(--scan-line);
  border-radius: 18px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    var(--scan-shadow);
  color: var(--scan-text);
  overflow: hidden;
}

body:not(.appLocked) #scanPage .panel.side {
  align-self: stretch;
  display: grid;
  gap: 12px;
  grid-template-rows: auto auto auto auto minmax(230px, 1fr);
  padding: 14px;
}

body:not(.appLocked) #scanPage .panel.side .field,
body:not(.appLocked) #scanPage .panel.side .totals {
  background:
    radial-gradient(circle at 12% 0, rgba(255, 255, 255, 0.06), transparent 40%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.018));
  border: 1px solid rgba(255, 255, 255, 0.095);
  border-radius: 14px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  margin: 0;
  padding: 11px;
}

body:not(.appLocked) #scanPage label,
body:not(.appLocked) #scanPage .moduleEyebrow {
  color: var(--scan-faint);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.08em;
}

body:not(.appLocked) #scanPage .hint {
  color: var(--scan-muted);
  font-size: 12px;
  line-height: 1.38;
}

body:not(.appLocked) #scanPage select,
body:not(.appLocked) #scanPage .scanDateControl,
body:not(.appLocked) #scanPage .jobNumberInput {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.025)),
    linear-gradient(180deg, #c4ceca, #aeb9b5);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 10px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.32),
    0 8px 18px rgba(0, 0, 0, 0.18);
  color: #172025;
  font-weight: 850;
}

body:not(.appLocked) #scanPage select {
  background:
    linear-gradient(45deg, transparent 50%, rgba(239, 244, 250, 0.82) 50%) calc(100% - 18px) 15px / 6px 6px no-repeat,
    linear-gradient(135deg, rgba(239, 244, 250, 0.82) 50%, transparent 50%) calc(100% - 13px) 15px / 6px 6px no-repeat,
    linear-gradient(135deg, rgba(255, 255, 255, 0.09), rgba(255, 255, 255, 0.025)),
    linear-gradient(180deg, #232a32, #151a20);
  color: var(--scan-text);
}

body:not(.appLocked) #scanPage .addJobButton {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.035)),
    linear-gradient(145deg, #222932, #14191f);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 12px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 10px 22px rgba(0, 0, 0, 0.18);
  color: #edf3f8;
  font-weight: 950;
  min-height: 40px;
}

body:not(.appLocked) #scanPage .panel.review {
  display: grid;
  grid-template-rows: auto auto minmax(440px, 1fr) auto;
  min-width: 0;
  position: relative;
}

body:not(.appLocked) #scanPage .scanDayBanner {
  background:
    linear-gradient(90deg, rgba(47, 167, 255, 0.12), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.028));
  border: 0;
  border-bottom: 1px solid var(--scan-line);
  border-radius: 0;
  box-shadow: none;
  min-height: 80px;
  padding: 15px 18px;
}

body:not(.appLocked) #scanPage .scanDayBanner [data-scan-title] {
  color: var(--scan-text);
  font-size: clamp(21px, 1.55vw, 30px);
  letter-spacing: 0;
  line-height: 1.04;
}

body:not(.appLocked) #scanPage .scanBannerMeta small,
body:not(.appLocked) #scanPage #rowCount {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 999px;
  color: var(--scan-muted);
  padding: 5px 9px;
}

body:not(.appLocked) #scanPage .review .tableWrap {
  align-content: stretch;
  background:
    radial-gradient(circle at 18% 6%, rgba(47, 167, 255, 0.16), transparent 34%),
    radial-gradient(circle at 80% 100%, rgba(122, 30, 44, 0.14), transparent 34%),
    repeating-linear-gradient(145deg, rgba(255, 255, 255, 0.032) 0 1px, transparent 1px 10px),
    linear-gradient(180deg, rgba(37, 45, 55, 0.94), rgba(16, 20, 26, 0.98));
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 0;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.09),
    inset 0 -24px 50px rgba(0, 0, 0, 0.16);
  display: grid;
  min-height: clamp(440px, 55vh, 680px);
  overflow: auto;
  padding: clamp(18px, 2vw, 28px);
}

body:not(.appLocked) #scanPage #reviewTable {
  min-height: 100%;
  width: 100%;
}

body:not(.appLocked) #scanPage[data-scan-stage="pre"] .review .tableWrap,
body:not(.appLocked) #scanPage[data-scan-stage="pre"] .review .emptyScanRow td {
  background:
    radial-gradient(circle at 18% 6%, rgba(47, 167, 255, 0.14), transparent 34%),
    radial-gradient(circle at 80% 100%, rgba(122, 30, 44, 0.12), transparent 34%),
    repeating-linear-gradient(145deg, rgba(255, 255, 255, 0.03) 0 1px, transparent 1px 10px),
    linear-gradient(180deg, rgba(38, 46, 55, 0.96), rgba(16, 20, 25, 0.99));
}

body:not(.appLocked) #scanPage .emptyScanRow td {
  border: 0;
  height: 100%;
  padding: 0;
}

body:not(.appLocked) #scanPage[data-scan-stage="pre"] .emptyScanPrompt {
  align-content: center;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.018), rgba(255, 255, 255, 0.004));
  border: 1.5px dashed rgba(206, 220, 234, 0.46);
  border-radius: 18px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.07),
    inset 0 0 0 1px rgba(255, 255, 255, 0.025),
    0 18px 44px rgba(0, 0, 0, 0.08);
  box-sizing: border-box;
  display: grid;
  gap: clamp(12px, 1.5vw, 18px);
  height: 100%;
  justify-items: center;
  margin: 0;
  min-height: clamp(360px, 44vh, 560px);
  padding: clamp(32px, 4.8vw, 64px);
  position: relative;
  text-align: center;
  width: 100%;
}

body:not(.appLocked) #scanPage[data-scan-stage="pre"] .emptyScanPrompt::before {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.03)),
    linear-gradient(145deg, rgba(47, 167, 255, 0.09), rgba(255, 255, 255, 0.01));
  border: 1px solid rgba(221, 232, 242, 0.36);
  border-radius: 14px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 12px 26px rgba(0, 0, 0, 0.22);
  content: "";
  height: clamp(56px, 5.4vw, 78px);
  margin-bottom: 2px;
  position: relative;
  width: clamp(50px, 4.8vw, 70px);
}

body:not(.appLocked) #scanPage .emptyScanPrompt strong {
  color: #f7f9fc;
  font-family: "Avenir Next", "SF Pro Display", "Segoe UI", sans-serif;
  font-size: clamp(36px, 4.1vw, 60px);
  font-weight: 920;
  letter-spacing: 0;
  line-height: 1.02;
  text-shadow: 0 3px 18px rgba(0, 0, 0, 0.34);
}

body:not(.appLocked) #scanPage .emptyScanPrompt > span {
  color: rgba(240, 245, 250, 0.82);
  font-size: clamp(16px, 1.35vw, 22px);
  font-weight: 750;
  line-height: 1.42;
  max-width: 720px;
}

body:not(.appLocked) #scanPage .scanEmptyActionGrid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  max-width: 760px;
  width: min(100%, 760px);
}

body:not(.appLocked) #scanPage .scanEmptyActionGrid div {
  align-items: center;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.024)),
    linear-gradient(145deg, rgba(34, 41, 50, 0.96), rgba(16, 20, 25, 0.96));
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 10px 20px rgba(0, 0, 0, 0.18);
  display: grid;
  gap: 10px;
  grid-template-columns: 40px minmax(0, 1fr);
  min-height: 60px;
  padding: 10px 12px;
  text-align: left;
}

body:not(.appLocked) #scanPage .scanEmptyActionGrid b {
  align-items: center;
  background:
    radial-gradient(circle at 36% 22%, rgba(255, 255, 255, 0.2), transparent 32%),
    linear-gradient(145deg, rgba(47, 167, 255, 0.36), rgba(13, 45, 74, 0.92));
  border: 1px solid rgba(127, 198, 255, 0.38);
  border-radius: 10px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 8px 16px rgba(47, 167, 255, 0.14);
  color: #eef8ff;
  display: grid;
  font-size: 17px;
  height: 38px;
  justify-content: center;
  place-items: center;
  width: 38px;
}

body:not(.appLocked) #scanPage .scanEmptyActionGrid em {
  color: rgba(244, 248, 252, 0.9);
  font-size: clamp(13px, 1vw, 16px);
  font-style: normal;
  font-weight: 850;
  line-height: 1.25;
}

body:not(.appLocked) #scanPage .emptyScanPrompt ol {
  display: grid;
  gap: 7px;
  list-style: none;
  margin: 0;
  max-width: 820px;
  padding: 0;
  width: min(100%, 820px);
}

body:not(.appLocked) #scanPage .emptyScanPrompt li {
  background: rgba(255, 255, 255, 0.055);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 999px;
  color: rgba(229, 238, 247, 0.8);
  font-size: clamp(12px, 0.95vw, 15px);
  font-weight: 720;
  line-height: 1.3;
  padding: 9px 14px;
}

body:not(.appLocked) #scanPage .reviewActions {
  background:
    radial-gradient(circle at 7% 0, rgba(47, 167, 255, 0.16), transparent 35%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.105), rgba(255, 255, 255, 0.035)),
    linear-gradient(145deg, rgba(27, 33, 41, 0.96), rgba(13, 16, 21, 0.98));
  border: 0;
  border-top: 1px solid var(--scan-line);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.11),
    0 -12px 28px rgba(0, 0, 0, 0.18);
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(300px, 1.25fr) minmax(190px, 0.85fr) minmax(150px, 0.66fr) minmax(140px, 0.56fr) minmax(140px, 0.56fr);
  min-height: 104px;
  padding: 12px;
}

body:not(.appLocked) #scanPage .scanQuickCompanyLane {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.025)),
    linear-gradient(145deg, rgba(30, 36, 44, 0.94), rgba(14, 17, 22, 0.96));
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: 15px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 10px 24px rgba(0, 0, 0, 0.22);
  gap: 9px;
  padding: 11px;
}

body:not(.appLocked) #scanPage .scanQuickCompanyHeader {
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 3px 10px;
}

body:not(.appLocked) #scanPage .scanQuickCompanyHeader .moduleEyebrow {
  color: rgba(239, 245, 250, 0.58);
}

body:not(.appLocked) #scanPage .scanQuickCompanyHeader strong {
  color: var(--scan-text);
  font-size: 15px;
  font-weight: 950;
}

body:not(.appLocked) #scanPage .scanQuickCompanyHeader em {
  color: rgba(223, 232, 241, 0.68);
  font-size: 11px;
  line-height: 1.28;
  white-space: normal;
}

body:not(.appLocked) #scanPage .scanQuickCompanyButtons {
  gap: 8px;
}

body:not(.appLocked) #scanPage .scanQuickCompanyButton {
  border-radius: 12px;
  font-family: "Avenir Next", "SF Pro Display", "Segoe UI", sans-serif;
  font-size: clamp(18px, 1.35vw, 24px);
  font-weight: 930;
  letter-spacing: 0.02em;
  min-height: 52px;
  padding: 0 12px;
  text-transform: uppercase;
}

body:not(.appLocked) #scanPage .scanQuickCompanyButton .quickCompanyBadge {
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    inset 0 -1px 0 rgba(0, 0, 0, 0.48),
    inset 8px 0 18px rgba(255, 255, 255, 0.035),
    inset -12px 0 22px rgba(0, 0, 0, 0.28);
}

body:not(.appLocked) #scanPage .scanQuickCompanyButton .quickCompanyBadge::before {
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.16), transparent 14%, transparent 86%, rgba(255, 255, 255, 0.1)),
    linear-gradient(180deg, rgba(255, 255, 255, 0.14), transparent 26%);
  border-radius: inherit;
  content: "";
  inset: 1px;
  opacity: 0.52;
  position: absolute;
}

body:not(.appLocked) #scanPage .scanQuickCompanyButton .quickCompanyLabel {
  color: #fff;
  font-size: inherit;
  letter-spacing: 0.025em;
  text-shadow:
    0 1px 0 rgba(0, 0, 0, 0.78),
    0 3px 12px rgba(0, 0, 0, 0.28);
}

body:not(.appLocked) #scanPage .scanQuickCompanyButton.company-hm .quickCompanyBadge {
  background:
    radial-gradient(circle at 18% 12%, rgba(221, 77, 88, 0.22), transparent 32%),
    radial-gradient(circle at 84% 80%, rgba(5, 4, 5, 0.52), transparent 34%),
    repeating-linear-gradient(105deg, rgba(255, 255, 255, 0.035) 0 1px, transparent 1px 8px),
    repeating-linear-gradient(18deg, rgba(0, 0, 0, 0.16) 0 1px, transparent 1px 10px),
    linear-gradient(145deg, #8d2230, #641824 46%, #242022);
  border-color: rgba(233, 172, 172, 0.34);
}

body:not(.appLocked) #scanPage .scanQuickCompanyButton.company-alfa .quickCompanyBadge {
  background:
    radial-gradient(circle at 18% 12%, rgba(78, 214, 132, 0.2), transparent 32%),
    radial-gradient(circle at 84% 80%, rgba(4, 12, 8, 0.52), transparent 34%),
    repeating-linear-gradient(105deg, rgba(255, 255, 255, 0.034) 0 1px, transparent 1px 8px),
    repeating-linear-gradient(18deg, rgba(0, 0, 0, 0.16) 0 1px, transparent 1px 10px),
    linear-gradient(145deg, #21804f, #155939 48%, #202823);
  border-color: rgba(164, 232, 190, 0.32);
}

body:not(.appLocked) #scanPage .scanQuickCompanyButton.company-sec .quickCompanyBadge {
  background:
    radial-gradient(circle at 18% 12%, rgba(81, 167, 240, 0.2), transparent 32%),
    radial-gradient(circle at 84% 80%, rgba(4, 9, 15, 0.52), transparent 34%),
    repeating-linear-gradient(105deg, rgba(255, 255, 255, 0.034) 0 1px, transparent 1px 8px),
    repeating-linear-gradient(18deg, rgba(0, 0, 0, 0.16) 0 1px, transparent 1px 10px),
    linear-gradient(145deg, #235f9d, #173d66 48%, #1f252d);
  border-color: rgba(156, 202, 240, 0.34);
}

body:not(.appLocked) #scanPage .scanQuickCompanyButton:hover,
body:not(.appLocked) #scanPage .scanQuickCompanyButton:focus-visible,
body:not(.appLocked) #scanPage .scanQuickCompanyButton.active {
  filter: saturate(1.12) contrast(1.02);
  transform: translateY(-1px);
}

body:not(.appLocked) #scanPage .scanReviewButton,
body:not(.appLocked) #scanPage .clearScanButton,
body:not(.appLocked) #scanPage .saveScanButton {
  -webkit-backdrop-filter: blur(18px) saturate(1.25);
  align-items: center;
  backdrop-filter: blur(18px) saturate(1.25);
  border-radius: 14px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.16),
    inset 0 -10px 18px rgba(0, 0, 0, 0.16),
    0 10px 22px rgba(0, 0, 0, 0.22);
  font-size: 14px;
  font-weight: 920;
  min-height: 58px;
  overflow: hidden;
  position: relative;
}

body:not(.appLocked) #scanPage .scanReviewButton span,
body:not(.appLocked) #scanPage .clearScanButton span {
  align-items: center;
  border-radius: 10px;
  display: grid;
  font-size: 17px;
  height: 38px;
  justify-content: center;
  place-items: center;
  width: 38px;
}

body:not(.appLocked) #scanPage .scanPrimaryButton {
  background:
    radial-gradient(circle at 18% 0, rgba(47, 167, 255, 0.18), transparent 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.105), rgba(255, 255, 255, 0.028)),
    linear-gradient(145deg, rgba(30, 38, 48, 0.96), rgba(13, 17, 22, 0.98));
  border: 1px solid rgba(127, 198, 255, 0.34);
  color: #f4f9ff;
  display: grid;
  gap: 10px;
  grid-template-columns: 42px minmax(0, 1fr) 14px;
  justify-content: stretch;
}

body:not(.appLocked) #scanPage .scanPrimaryButton span {
  background:
    radial-gradient(circle at 35% 18%, rgba(255, 255, 255, 0.3), transparent 34%),
    linear-gradient(145deg, #2fa7ff, #0a4d83);
  border: 1px solid rgba(164, 217, 255, 0.44);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.22),
    0 10px 20px rgba(47, 167, 255, 0.18);
}

body:not(.appLocked) #scanPage .scanPrimaryButton::after {
  color: rgba(244, 249, 255, 0.88);
  content: "\203A";
  font-size: 29px;
  font-weight: 300;
  line-height: 1;
}

body:not(.appLocked) #scanPage .secondaryScanButton {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.026)),
    linear-gradient(145deg, rgba(33, 39, 47, 0.96), rgba(14, 17, 22, 0.98));
  border: 1px solid rgba(255, 255, 255, 0.16);
  color: rgba(239, 245, 250, 0.9);
}

body:not(.appLocked) #scanPage .secondaryScanButton span,
body:not(.appLocked) #scanPage .clearScanButton span {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.035));
  border: 1px solid rgba(255, 255, 255, 0.13);
}

body:not(.appLocked) #scanPage .clearScanButton {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.085), rgba(255, 255, 255, 0.025)),
    linear-gradient(145deg, rgba(33, 38, 45, 0.96), rgba(14, 17, 22, 0.98));
  border: 1px solid rgba(255, 255, 255, 0.16);
  color: rgba(239, 245, 250, 0.9);
}

body:not(.appLocked) #scanPage .saveApprovedWrap {
  background: transparent;
  border: 0;
  box-shadow: none;
  min-width: 0;
  padding: 0;
}

body:not(.appLocked) #scanPage .saveScanButton {
  background:
    linear-gradient(180deg, rgba(42, 93, 68, 0.18), rgba(17, 29, 23, 0.76)),
    linear-gradient(145deg, #17241f, #101613);
  border: 1px solid rgba(95, 216, 151, 0.58);
  color: #baf3d1;
  gap: 10px;
  text-shadow: none;
}

body:not(.appLocked) #scanPage .saveScanButton strong {
  color: currentColor;
  font-size: 17px;
  font-weight: 950;
  letter-spacing: 0;
}

body:not(.appLocked) #scanPage .saveScanButton:not(:disabled) {
  background:
    linear-gradient(90deg, rgba(45, 154, 102, 0.95) 0 50%, rgba(45, 154, 102, 0.08) 50% 100%),
    linear-gradient(180deg, rgba(42, 93, 68, 0.22), rgba(17, 29, 23, 0.76)),
    linear-gradient(145deg, #17241f, #101613);
  background-position: 100% 0, 0 0, 0 0;
  background-size: 205% 100%, 100% 100%, 100% 100%;
  border-color: rgba(138, 238, 184, 0.82);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 10px 22px rgba(0, 0, 0, 0.22),
    0 0 0 1px rgba(45, 154, 102, 0.12);
  color: #d8ffe8;
}

body:not(.appLocked) #scanPage .saveScanButton:not(:disabled):hover,
body:not(.appLocked) #scanPage .saveScanButton:not(:disabled):focus-visible {
  background-position: 70% 0, 0 0, 0 0;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.16),
    0 14px 28px rgba(0, 0, 0, 0.26),
    0 0 0 3px rgba(45, 154, 102, 0.16),
    0 0 20px rgba(45, 154, 102, 0.18);
  outline: none;
}

body:not(.appLocked) #scanPage .recentScansPanel {
  align-self: stretch;
  background:
    radial-gradient(circle at 18% 0, rgba(47, 167, 255, 0.14), transparent 38%),
    var(--scan-metal-noise),
    linear-gradient(180deg, rgba(39, 47, 56, 0.9), rgba(16, 20, 26, 0.96));
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: 16px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 14px 32px rgba(0, 0, 0, 0.24);
  min-height: 100%;
  padding: 12px;
}

body:not(.appLocked) #scanPage .recentScansHeader strong {
  color: var(--scan-text);
  font-size: 24px;
  font-weight: 950;
  letter-spacing: 0;
}

body:not(.appLocked) #scanPage .recentScansList {
  gap: 9px;
}

body:not(.appLocked) #scanPage .recentScanCard,
body:not(.appLocked) #scanPage .recentScansEmpty {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.022)),
    linear-gradient(145deg, rgba(29, 35, 43, 0.96), rgba(13, 16, 21, 0.98));
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 13px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 10px 20px rgba(0, 0, 0, 0.18);
}

body:not(.appLocked) #scanPage .recentScanOpen {
  color: var(--scan-text);
}

body:not(.appLocked) #scanPage .recentScanThumb {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(204, 214, 220, 0.86)),
    repeating-linear-gradient(0deg, transparent 0 5px, rgba(20, 25, 31, 0.18) 5px 6px);
  border: 1px solid rgba(255, 255, 255, 0.22);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.42),
    0 8px 16px rgba(0, 0, 0, 0.2);
}

body:not(.appLocked) #scanPage .recentScanActions button {
  background: rgba(255, 255, 255, 0.055);
  border-color: rgba(255, 255, 255, 0.12);
  border-radius: 10px;
  color: rgba(239, 245, 250, 0.82);
}

body:not(.appLocked) #scanPage .recentScanActions button:hover,
body:not(.appLocked) #scanPage .recentScanActions button:focus-visible {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.24);
  color: #fff;
}

body:not(.appLocked) #scanPage .jobSetupItem .jobRemoveMenuButton {
  background:
    radial-gradient(circle at 28% 14%, rgba(255, 255, 255, 0.18), transparent 31%),
    linear-gradient(145deg, rgba(133, 34, 48, 0.74), rgba(58, 19, 27, 0.82));
  border-color: rgba(255, 136, 154, 0.44);
  border-radius: 9px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    inset 0 -9px 16px rgba(0, 0, 0, 0.18),
    0 8px 18px rgba(0, 0, 0, 0.22);
  color: #ff6478;
  height: 30px;
  text-shadow:
    0 1px 0 rgba(28, 0, 7, 0.7),
    0 0 9px rgba(255, 100, 120, 0.16);
  width: 30px;
}

body:not(.appLocked) #scanPage .jobSetupItem .jobRemoveMenuButton:hover,
body:not(.appLocked) #scanPage .jobSetupItem .jobRemoveMenuButton:focus-visible {
  border-color: rgba(255, 159, 176, 0.62);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.22),
    inset 0 -9px 16px rgba(0, 0, 0, 0.16),
    0 11px 22px rgba(0, 0, 0, 0.26),
    0 0 0 3px rgba(255, 59, 48, 0.13),
    0 0 18px rgba(255, 59, 48, 0.18);
  color: #ff7b8c;
}

@media (max-width: 1180px) {
  body:not(.appLocked) #scanPage .workspace {
    grid-template-columns: minmax(240px, 310px) minmax(0, 1fr);
  }

  body:not(.appLocked) #scanPage .reviewActions {
    grid-template-columns: minmax(260px, 1.35fr) repeat(4, minmax(118px, 1fr));
  }
}

@media (max-width: 980px) {
  body:not(.appLocked) #scanPage .workspace {
    grid-template-columns: minmax(0, 1fr);
    min-height: 0;
  }

  body:not(.appLocked) #scanPage .panel.side {
    grid-template-rows: none;
  }

  body:not(.appLocked) #scanPage .reviewActions {
    grid-template-columns: minmax(0, 1fr);
  }

  body:not(.appLocked) #scanPage .scanQuickCompanyButtons,
  body:not(.appLocked) #scanPage .scanEmptyActionGrid {
    grid-template-columns: minmax(0, 1fr);
  }

  body:not(.appLocked) #scanPage .review .tableWrap {
    min-height: 420px;
    padding: 14px;
  }

  body:not(.appLocked) #scanPage .emptyScanPrompt {
    padding: 26px 18px;
  }
}

@media (max-height: 780px) and (min-width: 981px) {
  body:not(.appLocked) #scanPage .workspace {
    min-height: calc(100vh - 86px);
  }

  body:not(.appLocked) #scanPage .panel.side {
    gap: 9px;
    padding: 11px;
  }

  body:not(.appLocked) #scanPage .panel.side .field,
  body:not(.appLocked) #scanPage .panel.side .totals {
    padding: 9px;
  }

  body:not(.appLocked) #scanPage .panel.review {
    grid-template-rows: auto auto minmax(300px, 1fr) auto;
  }

  body:not(.appLocked) #scanPage .scanDayBanner {
    min-height: 64px;
    padding: 10px 14px;
  }

  body:not(.appLocked) #scanPage .review .tableWrap {
    min-height: clamp(300px, 39vh, 430px);
    padding: 14px;
  }

  body:not(.appLocked) #scanPage[data-scan-stage="pre"] .emptyScanPrompt {
    min-height: clamp(260px, 34vh, 380px);
    padding: 22px 28px;
  }

  body:not(.appLocked) #scanPage .emptyScanPrompt strong {
    font-size: clamp(30px, 3.15vw, 44px);
  }

  body:not(.appLocked) #scanPage .emptyScanPrompt > span {
    font-size: clamp(14px, 1.08vw, 18px);
  }

  body:not(.appLocked) #scanPage .scanEmptyActionGrid div {
    min-height: 52px;
    padding: 8px 10px;
  }

  body:not(.appLocked) #scanPage .emptyScanPrompt ol {
    display: none;
  }

  body:not(.appLocked) #scanPage .reviewActions {
    gap: 8px;
    min-height: 84px;
    padding: 9px;
  }

  body:not(.appLocked) #scanPage .scanReviewButton,
  body:not(.appLocked) #scanPage .clearScanButton,
  body:not(.appLocked) #scanPage .saveScanButton,
  body:not(.appLocked) #scanPage .scanQuickCompanyButton {
    min-height: 46px;
  }

  body:not(.appLocked) #scanPage .scanQuickCompanyButton {
    font-size: clamp(16px, 1.18vw, 20px);
  }
}

@media (max-width: 640px) {
  body:not(.appLocked) #scanPage .scanDayBanner {
    min-height: 0;
    padding: 12px;
  }

  body:not(.appLocked) #scanPage .review .tableWrap {
    min-height: 360px;
    padding: 12px;
  }

  body:not(.appLocked) #scanPage[data-scan-stage="pre"] .emptyScanPrompt {
    gap: 11px;
    min-height: 320px;
    padding: 22px 14px;
  }

  body:not(.appLocked) #scanPage[data-scan-stage="pre"] .emptyScanPrompt::before {
    height: 48px;
    width: 44px;
  }

  body:not(.appLocked) #scanPage .emptyScanPrompt strong {
    font-size: clamp(25px, 8vw, 34px);
    max-width: 100%;
    overflow-wrap: anywhere;
  }

  body:not(.appLocked) #scanPage .emptyScanPrompt > span {
    font-size: 14px;
    max-width: 100%;
  }

  body:not(.appLocked) #scanPage .scanEmptyActionGrid {
    gap: 7px;
  }

  body:not(.appLocked) #scanPage .scanEmptyActionGrid div {
    grid-template-columns: 34px minmax(0, 1fr);
    min-height: 48px;
    padding: 8px 10px;
  }

  body:not(.appLocked) #scanPage .scanEmptyActionGrid b {
    border-radius: 8px;
    font-size: 14px;
    height: 30px;
    width: 30px;
  }

  body:not(.appLocked) #scanPage .scanEmptyActionGrid em,
  body:not(.appLocked) #scanPage .emptyScanPrompt li {
    font-size: 12px;
  }

  body:not(.appLocked) #scanPage .emptyScanPrompt li {
    border-radius: 12px;
    padding: 7px 9px;
  }

  body:not(.appLocked) #scanPage .reviewActions {
    min-height: 0;
  }
}
