:root {
  --navy: #173b5a;
  --deep: #08283d;
  --blue: #12a8d8;
  --teal: #11c7bd;
  --ink: #111827;
  --muted: #5b6675;
  --line: #d8e0e8;
  --paper: #ffffff;
  --soft: #f4f8fb;
  --open: #2563eb;
  --danger: #d71946;
  --success: #07958f;
  --warning: #f59e0b;
  --warning-ink: #5f3300;
  --shadow: 0 22px 70px rgba(5, 24, 44, 0.18);
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-right: env(safe-area-inset-right, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left: env(safe-area-inset-left, 0px);
}

* {
  box-sizing: border-box;
}

html {
  min-height: 100%;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

[hidden] {
  display: none !important;
}

body {
  margin: 0;
  min-height: 100vh;
  min-height: 100dvh;
  color: var(--ink);
  background:
    linear-gradient(34deg, transparent 0 68%, rgba(17, 199, 189, 0.95) 68% 100%),
    linear-gradient(28deg, var(--teal) 0 29%, var(--blue) 29% 69%, var(--navy) 69% 100%);
  font-family: Arial, Helvetica, sans-serif;
  overscroll-behavior-y: none;
}

button,
input,
textarea,
select {
  font: inherit;
}

button,
.button,
a,
summary,
input,
textarea,
select {
  touch-action: manipulation;
}

button,
.button,
input,
select {
  min-height: 44px;
}

button,
a,
input,
textarea,
select {
  min-width: 0;
}

.app-shell {
  min-height: 100vh;
  min-height: 100dvh;
  display: grid;
  grid-template-columns: 268px 1fr;
}

.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  height: 100dvh;
  overflow-y: auto;
  padding: max(22px, calc(var(--safe-top) + 14px)) 18px max(22px, calc(var(--safe-bottom) + 14px));
  background: rgba(8, 40, 61, 0.96);
  color: #fff;
  box-shadow: 12px 0 36px rgba(5, 24, 44, 0.2);
  -webkit-overflow-scrolling: touch;
}

.brand-lockup {
  display: block;
  padding: 14px 10px 20px;
}

.brand-lockup img {
  width: 100%;
  height: auto;
  filter: drop-shadow(0 8px 12px rgba(0, 0, 0, 0.28));
}

.nav-list {
  display: grid;
  gap: 10px;
}

.nav-list a {
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  color: rgba(255, 255, 255, 0.82);
  text-decoration: none;
  border-radius: 7px;
  padding: 10px 12px;
  font-weight: 800;
}

.nav-list a svg {
  width: 17px;
  height: 17px;
  opacity: 0.84;
}

.nav-list a span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.nav-list a.active,
.nav-list a:hover {
  color: #062d3d;
  background: var(--teal);
}

.nav-section {
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  padding: 6px;
  background: rgba(255, 255, 255, 0.035);
}

.nav-section[hidden] {
  display: none;
}

.nav-section summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 34px;
  border-radius: 6px;
  padding: 0 8px;
  color: rgba(255, 255, 255, 0.68);
  cursor: pointer;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.1em;
  list-style: none;
  text-transform: uppercase;
}

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

.nav-section summary::after {
  content: "+";
  color: rgba(255, 255, 255, 0.64);
  font-size: 18px;
  line-height: 1;
}

.nav-section[open] summary {
  color: #dffefa;
}

.nav-section[open] summary::after {
  content: "-";
}

.nav-section-links {
  display: grid;
  gap: 5px;
  margin-top: 6px;
}

.workspace {
  min-width: 0;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: max(18px, calc(var(--safe-top) + 10px)) max(28px, calc(var(--safe-right) + 24px)) 18px max(28px, calc(var(--safe-left) + 24px));
  color: #fff;
  background: rgba(23, 59, 90, 0.94);
  border-bottom: 1px solid rgba(255, 255, 255, 0.16);
  backdrop-filter: blur(10px);
}

.menu-button {
  display: none;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: 6px;
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
  cursor: pointer;
}

.menu-button svg {
  width: 20px;
  height: 20px;
}

.eyebrow {
  margin: 0 0 4px;
  color: rgba(255, 255, 255, 0.74);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

#page-title {
  margin: 0;
  font-size: 28px;
  line-height: 1.05;
  letter-spacing: 0;
}

.status-pill,
.clock-status-pill,
.pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  border: 0;
  border-radius: 999px;
  padding: 6px 12px;
  background: rgba(17, 199, 189, 0.18);
  color: #dffefa;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  white-space: nowrap;
}

.clock-status-pill {
  min-width: 112px;
  min-height: 36px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
  cursor: pointer;
}

.clock-status-pill.is-on {
  color: #062d3d;
  background: var(--teal);
}

.clock-status-pill.is-off {
  color: #fff;
  background: rgba(255, 255, 255, 0.14);
}

.topbar-actions {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
}

.global-search {
  flex: 1 1 360px;
  max-width: 520px;
  min-width: 240px;
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 8px;
  padding: 6px 7px 6px 10px;
  background: rgba(255, 255, 255, 0.1);
}

.global-search svg {
  width: 17px;
  height: 17px;
  color: rgba(255, 255, 255, 0.72);
}

.global-search input {
  width: 100%;
  border: 0;
  outline: 0;
  color: #fff;
  background: transparent;
  font-size: 13px;
  font-weight: 800;
}

.global-search input::placeholder {
  color: rgba(255, 255, 255, 0.62);
}

.global-search button {
  min-height: 28px;
  border: 0;
  border-radius: 6px;
  padding: 5px 9px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.92);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  cursor: pointer;
}

.create-menu-wrap {
  position: relative;
}

.create-button {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 36px;
  border: 0;
  border-radius: 7px;
  padding: 8px 12px;
  color: #06343d;
  background: var(--teal);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: 0 10px 20px rgba(5, 24, 44, 0.16);
}

.create-button-icon {
  display: inline-grid;
  place-items: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  color: #fff;
  background: var(--navy);
  font-size: 16px;
  line-height: 1;
}

.create-button-icon svg {
  display: none;
  width: 14px;
  height: 14px;
}

.create-button-icon::before,
.create-icon::before {
  content: attr(data-fallback);
}

body.icons-ready .create-button-icon::before,
body.icons-ready .create-icon::before {
  display: none;
}

body.icons-ready .create-button-icon svg,
body.icons-ready .create-icon svg {
  display: block;
}

.create-button:hover,
.create-button[aria-expanded="true"] {
  background: #4bf0e5;
}

.create-menu {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 30;
  width: min(350px, calc(100vw - 24px));
  display: grid;
  gap: 6px;
  border: 1px solid rgba(216, 224, 232, 0.9);
  border-radius: 8px;
  padding: 8px;
  color: var(--ink);
  background: #fff;
  box-shadow: 0 22px 48px rgba(5, 24, 44, 0.22);
}

.create-menu-heading {
  display: grid;
  gap: 2px;
  border-bottom: 1px solid var(--line);
  padding: 7px 8px 10px;
}

.create-menu-heading strong {
  color: var(--navy);
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
}

.create-menu-heading span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.create-menu-item {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) auto;
  gap: 3px;
  align-items: center;
  border: 1px solid transparent;
  border-radius: 7px;
  padding: 10px;
  color: inherit;
  text-decoration: none;
}

.create-menu-item::after {
  content: ">";
  color: var(--muted);
  font-size: 14px;
  font-weight: 900;
}

.create-menu-item:hover {
  border-color: rgba(17, 199, 189, 0.42);
  background: rgba(17, 199, 189, 0.1);
}

.create-menu-item.featured {
  border-color: rgba(17, 199, 189, 0.38);
  background: rgba(17, 199, 189, 0.14);
}

.create-icon {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 1px solid rgba(17, 199, 189, 0.36);
  border-radius: 8px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.18);
  font-size: 13px;
  font-weight: 900;
}

.create-icon svg {
  display: none;
  width: 18px;
  height: 18px;
}

.create-item-copy {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.create-item-copy strong {
  color: var(--navy);
  font-size: 14px;
  line-height: 1.2;
}

.create-item-copy small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.25;
}

.create-menu-item em {
  border-radius: 999px;
  padding: 4px 7px;
  color: #06343d;
  background: var(--teal);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}

.create-menu-item.featured::after {
  content: "";
}

.logout-button {
  min-height: 34px;
  border: 1px solid rgba(255, 255, 255, 0.32);
  border-radius: 6px;
  padding: 7px 11px;
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  cursor: pointer;
}

.logout-button:hover {
  background: rgba(255, 255, 255, 0.18);
}

.is-login .sidebar {
  display: none;
}

.is-login .app-shell {
  grid-template-columns: 1fr;
}

.is-login .menu-button,
.is-login .status-pill,
.is-login .clock-status-pill,
.is-login .global-search,
.is-login .mobile-tabbar {
  display: none;
}

#app {
  max-width: 1180px;
  margin: 0 auto;
  padding: 28px max(28px, var(--safe-right)) max(28px, calc(var(--safe-bottom) + 28px)) max(28px, var(--safe-left));
}

.mobile-tabbar {
  display: none;
}

.login-screen {
  width: 100%;
  min-width: 0;
  min-height: calc(100vh - 124px);
  display: grid;
  place-items: center;
}

.login-panel {
  width: min(100%, 460px);
  max-width: calc(100vw - 24px);
  min-width: 0;
  display: grid;
  gap: 18px;
  border: 1px solid rgba(216, 224, 232, 0.95);
  border-radius: 8px;
  padding: 26px;
  background: #fff;
  box-shadow: var(--shadow);
}

.login-panel img {
  width: min(260px, 78%);
  justify-self: center;
}

.login-panel h2 {
  margin: 0 0 8px;
  font-size: 30px;
  letter-spacing: 0;
}

.login-panel p {
  overflow-wrap: anywhere;
}

.login-form {
  display: grid;
  gap: 12px;
}

.login-form label {
  display: grid;
  gap: 6px;
  font-weight: 900;
}

.login-form input {
  width: 100%;
  min-height: 46px;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 10px 12px;
  background: var(--soft);
}

.login-form input:focus {
  outline: 3px solid rgba(18, 168, 216, 0.18);
  border-color: var(--blue);
}

.password-input-row {
  width: 100%;
  min-width: 0;
  display: flex;
  gap: 8px;
}

.password-input-row input {
  flex: 1 1 0;
  width: 0;
  min-width: 0;
}

.password-toggle {
  flex: 0 0 70px;
  min-width: 70px;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 0 12px;
  color: var(--navy);
  background: #fff;
  font-weight: 900;
  cursor: pointer;
}

.password-toggle:hover {
  border-color: var(--teal);
  background: rgba(17, 199, 189, 0.12);
}

.form-alert {
  margin: 0;
  border: 1px solid rgba(215, 25, 70, 0.22);
  border-radius: 6px;
  padding: 10px 12px;
  color: #8c1131;
  background: rgba(215, 25, 70, 0.08);
  font-weight: 800;
}

.time-clock-view .section-body {
  display: grid;
  gap: 16px;
}

.time-clock-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  gap: 14px;
}

.time-clock-card {
  display: grid;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 18px;
  background: #fff;
}

.time-clock-card.is-on {
  border-color: rgba(7, 149, 143, 0.42);
  background: rgba(17, 199, 189, 0.08);
}

.time-clock-card h3 {
  margin: 0;
  color: var(--navy);
  font-size: 28px;
  letter-spacing: 0;
}

.time-clock-card .clock-digital {
  font-size: clamp(48px, 10vw, 96px);
  line-height: 0.95;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0;
}

.time-clock-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.time-clock-actions .button:only-child {
  grid-column: 1 / -1;
}

.danger-button {
  background: var(--danger) !important;
}

.time-detail-list {
  display: grid;
  gap: 10px;
}

.time-review {
  display: grid;
  gap: 12px;
}

.section-heading.compact {
  padding: 0;
  background: transparent;
  color: var(--ink);
}

.time-entry-card.is-open {
  border-color: rgba(7, 149, 143, 0.36);
  box-shadow: 0 12px 32px rgba(7, 149, 143, 0.12);
}

.simple-time-list {
  display: grid;
  gap: 8px;
}

.time-entry-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: #fff;
}

.time-entry-row div {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.time-entry-row strong {
  color: var(--navy);
}

.time-entry-row span {
  color: var(--muted);
  font-size: 14px;
}

.time-entry-row em {
  flex: 0 0 auto;
  border-radius: 999px;
  padding: 5px 9px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.18);
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
}

.time-entry-row.is-open {
  border-color: rgba(7, 149, 143, 0.36);
  background: rgba(17, 199, 189, 0.08);
}

.hero {
  position: relative;
  overflow: hidden;
  min-height: 238px;
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: 26px;
  align-items: center;
  border-radius: 8px;
  padding: 30px;
  color: #fff;
  background: var(--deep);
  box-shadow: var(--shadow);
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 46%;
  background: linear-gradient(135deg, var(--blue), var(--teal));
  clip-path: polygon(0 0, 72% 0, 100% 100%, 0 100%);
}

.hero > * {
  position: relative;
}

.hero h2 {
  margin: 0 0 12px;
  font-size: 44px;
  line-height: 1;
  letter-spacing: 0;
}

.hero p {
  max-width: 650px;
  margin: 0;
  color: rgba(255, 255, 255, 0.84);
  font-size: 17px;
  line-height: 1.48;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.hero img {
  width: 100%;
  filter: drop-shadow(0 12px 18px rgba(0, 0, 0, 0.28));
}

.ops-dashboard,
.crew-dashboard {
  display: grid;
  gap: 16px;
}

.ops-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 0.36fr);
  gap: 18px;
  align-items: center;
  border: 1.5px solid rgba(23, 59, 90, 0.14);
  border-radius: 8px;
  padding: 20px;
  color: #fff;
  background:
    linear-gradient(135deg, rgba(17, 199, 189, 0.2), rgba(17, 199, 189, 0) 44%),
    var(--deep);
  box-shadow: var(--shadow);
}

.ops-hero.crew {
  background:
    linear-gradient(135deg, rgba(23, 180, 234, 0.24), rgba(23, 180, 234, 0) 48%),
    var(--deep);
}

.ops-hero h2 {
  margin: 0 0 8px;
  font-size: 34px;
  line-height: 1.04;
  letter-spacing: 0;
}

.ops-hero p {
  max-width: 720px;
  margin: 0;
  color: rgba(255, 255, 255, 0.84);
  line-height: 1.45;
}

.ops-actions {
  display: grid;
  gap: 8px;
}

.ops-actions .button {
  justify-content: center;
  width: 100%;
}

.dashboard-status {
  margin: -4px 2px 0;
  font-size: 13px;
}

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

.ops-focus-card {
  position: relative;
  display: grid;
  gap: 7px;
  min-height: 140px;
  border: 1px solid rgba(17, 199, 189, 0.34);
  border-radius: 8px;
  padding: 14px 14px 14px 58px;
  color: var(--ink);
  background: linear-gradient(180deg, rgba(17, 199, 189, 0.1), #fff 70%);
  text-decoration: none;
  box-shadow: 0 10px 22px rgba(5, 24, 44, 0.06);
}

.ops-focus-card:hover {
  border-color: rgba(17, 199, 189, 0.68);
  transform: translateY(-1px);
}

.ops-focus-icon {
  position: absolute;
  top: 14px;
  left: 14px;
  display: inline-grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.22);
}

.ops-focus-icon svg {
  width: 18px;
  height: 18px;
}

.ops-focus-card > span:not(.ops-focus-icon) {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.ops-focus-card strong {
  color: var(--navy);
  font-size: 28px;
  line-height: 1;
}

.ops-focus-card em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  font-weight: 800;
  line-height: 1.25;
}

.cloud-setup-card {
  padding-left: 14px;
}

.cloud-setup-card h3 {
  margin: 7px 0 0;
  color: var(--navy);
  font-size: 21px;
  line-height: 1.05;
}

.cloud-check-list {
  display: grid;
  gap: 7px;
  margin: 6px 0 0;
  padding-left: 18px;
  color: var(--ink);
  line-height: 1.35;
}

.cloud-check-list li::marker {
  color: var(--teal);
}

.cloud-live-status {
  margin-bottom: 16px;
}

.cloud-live-status .section-heading {
  align-items: flex-start;
}

.dashboard-stat-grid.compact {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 9px;
  margin-top: 12px;
}

.dashboard-stat-grid.compact div {
  display: grid;
  gap: 4px;
  border: 1px solid rgba(17, 199, 189, 0.28);
  border-radius: 8px;
  padding: 10px;
  background: rgba(17, 199, 189, 0.08);
}

.dashboard-stat-grid.compact span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.dashboard-stat-grid.compact strong {
  color: var(--navy);
  font-size: 22px;
  line-height: 1;
}

.cloud-warning-list {
  margin-top: 12px;
}

.payment-setup-panel {
  display: grid;
  gap: 12px;
  border: 1px solid rgba(229, 75, 75, 0.24);
  border-radius: 8px;
  padding: 14px;
  margin-top: 12px;
  background: rgba(229, 75, 75, 0.06);
}

.payment-setup-panel.is-ready {
  border-color: rgba(17, 199, 189, 0.34);
  background: rgba(17, 199, 189, 0.08);
}

.payment-setup-head {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  justify-content: space-between;
}

.payment-setup-head h3 {
  margin: 3px 0 3px;
  color: var(--navy);
  font-size: 20px;
  line-height: 1.1;
}

.payment-setup-head p {
  margin: 0;
  color: var(--muted);
  font-weight: 800;
}

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

.payment-setup-grid div,
.cloud-copy-row {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: #fff;
}

.payment-setup-grid span,
.cloud-copy-row span,
.payment-setup-events > span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.payment-setup-grid strong,
.cloud-copy-row strong {
  color: var(--navy);
  font-size: 14px;
  overflow-wrap: anywhere;
}

.payment-copy-list {
  display: grid;
  gap: 8px;
}

.cloud-copy-row {
  grid-template-columns: 155px minmax(0, 1fr) auto;
  align-items: center;
}

.cloud-copy-row .button {
  min-height: 36px;
  padding: 8px 12px;
}

.payment-setup-events {
  display: grid;
  gap: 7px;
}

.payment-setup-events div {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.payment-setup-events code {
  border: 1px solid rgba(17, 199, 189, 0.28);
  border-radius: 8px;
  padding: 7px 9px;
  color: var(--navy);
  background: #fff;
  font-size: 12px;
  font-weight: 900;
}

.import-key-values {
  display: grid;
  gap: 9px;
}

.import-key-values div {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: var(--soft);
}

.import-key-values span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.import-key-values strong {
  color: var(--navy);
  font-size: 14px;
  overflow-wrap: anywhere;
}

.ops-stat {
  display: grid;
  gap: 7px;
  min-height: 116px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
  color: var(--ink);
  background: #fff;
  text-decoration: none;
  box-shadow: 0 10px 22px rgba(5, 24, 44, 0.06);
}

.ops-stat:hover {
  border-color: rgba(17, 199, 189, 0.54);
  transform: translateY(-1px);
}

.ops-stat span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.ops-stat strong {
  color: var(--navy);
  font-size: 30px;
  line-height: 1;
}

.ops-stat em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  font-weight: 800;
  line-height: 1.25;
}

.ops-stat.is-loading {
  opacity: 0.64;
}

.jobber-workflow-rail {
  display: grid;
  gap: 12px;
  border: 1px solid rgba(216, 224, 232, 0.9);
  border-radius: 8px;
  padding: 14px;
  background: #fff;
  box-shadow: 0 10px 22px rgba(5, 24, 44, 0.06);
}

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

.workflow-head div {
  display: grid;
  gap: 3px;
}

.workflow-head span,
.workflow-stage span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.workflow-head strong {
  color: var(--navy);
  font-size: 18px;
  line-height: 1.2;
}

.workflow-head a {
  color: var(--navy);
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

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

.workflow-stage {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 2px 9px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  color: var(--ink);
  background: var(--soft);
  text-decoration: none;
}

.workflow-stage:hover {
  border-color: rgba(17, 199, 189, 0.54);
  background: rgba(17, 199, 189, 0.1);
}

.workflow-stage-icon {
  grid-row: span 3;
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 8px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.2);
}

.workflow-stage-icon svg {
  width: 18px;
  height: 18px;
}

.workflow-stage strong {
  color: var(--navy);
  font-size: 24px;
  line-height: 1;
}

.workflow-stage em {
  min-width: 0;
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
  line-height: 1.2;
}

.ops-layout {
  display: grid;
  grid-template-columns: minmax(320px, 0.95fr) minmax(0, 1.25fr);
  gap: 16px;
  align-items: start;
}

.dashboard-lower-grid {
  align-items: start;
}

.attention-list,
.dashboard-job-list {
  display: grid;
  gap: 10px;
}

.attention-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  border-left: 5px solid var(--blue);
  border-radius: 8px;
  padding: 11px;
  background: #fff;
}

.attention-item.is-hot {
  border-left-color: #d94855;
  background: #fff9f9;
}

.attention-item > span {
  border-radius: 999px;
  padding: 6px 8px;
  color: #062d3d;
  background: rgba(17, 199, 189, 0.18);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.attention-item div {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.attention-item strong {
  color: var(--navy);
  line-height: 1.15;
}

.attention-item em {
  overflow-wrap: anywhere;
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  line-height: 1.28;
}

.attention-actions {
  display: flex !important;
  gap: 8px;
  justify-content: flex-end;
}

.attention-actions .button {
  white-space: nowrap;
}

.dashboard-job-row {
  display: grid;
  grid-template-columns: 112px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  border: 1px solid var(--line);
  border-left: 5px solid var(--open);
  border-radius: 8px;
  padding: 12px;
  background: #fff;
}

.dashboard-job-row.is-complete,
.dashboard-job-row.is-submitted {
  border-left-color: var(--success);
  background: rgba(17, 199, 189, 0.07);
}

.dashboard-job-time {
  display: grid;
  gap: 5px;
  border-right: 1px solid var(--line);
  padding-right: 10px;
}

.dashboard-job-time strong {
  color: var(--navy);
  font-size: 15px;
}

.dashboard-job-time span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.dashboard-job-main {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.dashboard-job-main > strong {
  color: var(--navy);
  font-size: 17px;
}

.dashboard-job-main em {
  overflow-wrap: anywhere;
  color: var(--muted);
  font-style: normal;
  line-height: 1.3;
}

.dashboard-job-actions {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, minmax(74px, 1fr));
  gap: 7px;
  justify-content: stretch;
}

.dashboard-job-actions .button,
.attention-item .button {
  min-height: 36px;
  padding: 0 10px;
}

.import-panel {
  display: grid;
  gap: 12px;
}

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

.import-count {
  display: grid;
  gap: 5px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: var(--soft);
}

.import-count span {
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.import-count strong {
  color: var(--navy);
  font-size: 24px;
}

.import-live-status {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid rgba(23, 59, 90, 0.16);
  border-radius: 8px;
  padding: 12px;
  color: var(--navy);
  background: #eef7fb;
}

.import-live-status.is-running {
  border-color: rgba(17, 199, 189, 0.55);
  background: #dcfbf8;
}

.import-live-status strong {
  font-size: 16px;
}

.import-live-status span {
  color: var(--muted);
  font-weight: 800;
}

.import-mini-progress {
  display: grid;
  gap: 6px;
}

.import-mini-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 8px;
  align-items: center;
  border-top: 1px solid var(--line);
  padding-top: 7px;
  font-size: 12px;
}

.import-mini-row span {
  min-width: 0;
  overflow: hidden;
  color: var(--navy);
  font-weight: 900;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.import-mini-row em {
  color: var(--muted);
  font-style: normal;
}

.import-status-page .section-heading {
  align-items: start;
}

.section-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.import-detail-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
  gap: 16px;
  align-items: start;
}

.import-card {
  display: grid;
  gap: 12px;
  margin-top: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  background: var(--paper);
}

.import-card > .section-heading {
  border-radius: 0;
}

.import-card > :not(.section-heading) {
  padding: 0 14px 14px;
}

.import-progress-list,
.import-event-list {
  display: grid;
  gap: 9px;
}

.import-progress-row,
.import-event {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: var(--soft);
}

.import-progress-row.has-error,
.import-event.has-error {
  border-color: rgba(215, 25, 70, 0.35);
  background: #fff1f4;
}

.import-event.has-warning {
  border-color: rgba(245, 158, 11, 0.42);
  background: #fff8eb;
}

.import-progress-row > div:first-child {
  display: grid;
  gap: 3px;
}

.import-progress-row strong,
.import-event strong {
  color: var(--navy);
}

.import-progress-row span,
.import-event span,
.import-event p {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.import-progress-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.import-progress-meta span {
  border-radius: 999px;
  padding: 4px 8px;
  color: var(--navy);
  font-weight: 900;
  background: #e6f3f7;
}

.import-progress-bar {
  height: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: #dfe8ef;
}

.import-progress-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--teal);
}

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

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

.verification-notes {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.grid {
  display: grid;
  gap: 16px;
}

.grid.two {
  grid-template-columns: minmax(0, 1.3fr) minmax(280px, 0.7fr);
  align-items: start;
}

.sop-form > aside {
  min-width: 0;
}

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

.section,
.card,
.panel {
  min-width: 0;
  border: 1.5px solid var(--line);
  border-radius: 8px;
  background: var(--paper);
  box-shadow: 0 12px 30px rgba(5, 24, 44, 0.08);
}

.section {
  overflow: hidden;
}

.section-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px 16px;
  color: #fff;
  background: var(--navy);
}

.section-heading.teal {
  color: #062d3d;
  background: var(--teal);
}

.section-heading h2,
.section-heading h3 {
  margin: 0;
  font-size: 20px;
  line-height: 1;
  letter-spacing: 0;
  text-transform: uppercase;
}

.section-body,
.card {
  padding: 16px;
}

.sop-card {
  display: grid;
  gap: 12px;
  align-content: start;
  min-height: 206px;
  text-decoration: none;
  color: var(--ink);
  transition: transform 0.16s ease, box-shadow 0.16s ease;
}

.sop-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}

.sop-card h3 {
  margin: 0;
  color: var(--navy);
  font-size: 22px;
}

.sop-card p,
.muted {
  color: var(--muted);
  line-height: 1.45;
}

.sop-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
}

.sop-meta span {
  border-radius: 999px;
  padding: 6px 9px;
  background: var(--soft);
  color: var(--navy);
  font-size: 12px;
  font-weight: 900;
}

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

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

.field span,
.field label,
.label {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.field input,
.field textarea,
.field select {
  width: 100%;
  border: 1.5px solid var(--line);
  border-radius: 6px;
  padding: 11px 12px;
  color: var(--ink);
  background: var(--soft);
  outline: none;
}

.field textarea {
  min-height: 118px;
  resize: vertical;
  line-height: 1.45;
}

.field input:focus,
.field textarea:focus,
.field select:focus {
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(17, 199, 189, 0.18);
}

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

.address-lookup-field {
  position: relative;
}

.address-lookup-panel {
  position: absolute;
  top: calc(100% - 2px);
  left: 0;
  right: 0;
  z-index: 20;
  display: grid;
  gap: 6px;
  max-height: 260px;
  overflow-y: auto;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px;
  background: #fff;
  box-shadow: 0 18px 36px rgba(5, 24, 44, 0.16);
}

.address-suggestion {
  display: grid;
  gap: 3px;
  width: 100%;
  border: 1px solid transparent;
  border-radius: 7px;
  padding: 9px 10px;
  color: var(--ink);
  background: #fff;
  text-align: left;
  cursor: pointer;
}

.address-suggestion:hover,
.address-suggestion:focus {
  border-color: rgba(17, 199, 189, 0.5);
  background: rgba(17, 199, 189, 0.1);
}

.address-suggestion strong {
  color: var(--navy);
  font-size: 14px;
  line-height: 1.25;
}

.address-suggestion span,
.address-lookup-empty {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.3;
}

.address-suggestion em {
  display: inline-flex;
  margin-left: 6px;
  border-radius: 999px;
  padding: 2px 6px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.18);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}

.address-lookup-empty {
  padding: 10px;
}

.task-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.task-row {
  display: grid;
  grid-template-columns: 30px 1fr;
  gap: 12px;
  padding: 13px 16px;
  border-top: 1px solid var(--line);
}

.task-row.is-overdue {
  background: #fff7f7;
}

.task-row:first-child {
  border-top: 0;
}

.task-row strong {
  display: block;
  margin-bottom: 3px;
  font-size: 16px;
  line-height: 1.25;
}

.overdue-badge {
  display: inline-flex;
  margin-left: 8px;
  border-radius: 999px;
  padding: 3px 7px;
  transform: translateY(-1px);
  background: var(--danger);
  color: #fff;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  white-space: nowrap;
}

.task-row small {
  display: block;
  color: var(--muted);
  line-height: 1.35;
}

.jobsite-guide .section-heading {
  align-items: start;
}

.guide-heading-note {
  margin: 6px 0 0;
  color: rgba(6, 45, 61, 0.78);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.35;
  text-transform: none;
}

.jobsite-sop-form {
  align-items: start;
}

.jobsite-sop-form .hero {
  min-height: 0;
  padding: 16px 18px;
}

.jobsite-sop-form .hero h2 {
  font-size: 30px;
}

.jobsite-sop-form .hero img {
  width: 128px;
  max-height: 82px;
  object-fit: contain;
}

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

.actions.compact .button {
  min-height: 34px;
  padding: 7px 10px;
}

.jobsite-guide-shell {
  display: grid;
  gap: 14px;
}

.guide-now {
  display: grid;
  gap: 3px;
  border: 1px solid rgba(6, 45, 61, 0.12);
  border-left: 5px solid var(--teal);
  border-radius: 8px;
  padding: 12px 14px;
  background: #fff;
}

.guide-now span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.guide-now strong {
  color: var(--navy);
  font-size: 22px;
  line-height: 1.1;
}

.guide-now p {
  margin: 0;
  color: var(--ink);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.35;
}

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

.guide-step-button {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 4px 8px;
  align-items: center;
  border: 1.5px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  color: var(--ink);
  background: #fff;
  text-align: left;
  cursor: pointer;
}

.guide-step-button span {
  width: 25px;
  height: 25px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.24);
  font-size: 12px;
  font-weight: 900;
}

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

.guide-step-button em {
  grid-column: 2;
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
}

.guide-step-button.is-active {
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(17, 199, 189, 0.16);
}

.guide-step-button.is-done span {
  color: #fff;
  background: var(--success);
}

.guide-step-button.is-started span {
  color: #fff;
  background: var(--open);
}

.guide-mobile-status {
  border: 1px solid rgba(17, 199, 189, 0.35);
  border-radius: 8px;
  padding: 10px 12px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.12);
  font-size: 13px;
  font-weight: 900;
  line-height: 1.3;
}

.guided-phases {
  display: grid;
  gap: 12px;
}

.guided-phase {
  display: none;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

.guided-phase.is-active,
.jobsite-guide.show-all .guided-phase {
  display: grid;
}

.guided-phase-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 14px 16px;
  color: #fff;
  background: var(--navy);
}

.guided-phase-head.teal {
  color: #06343d;
  background: var(--teal);
}

.guided-phase-head span {
  display: block;
  margin-bottom: 4px;
  color: currentColor;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  opacity: 0.75;
  text-transform: uppercase;
}

.guided-phase-head h3 {
  margin: 0;
  font-size: 22px;
  line-height: 1.1;
  letter-spacing: 0;
  text-transform: uppercase;
}

.guided-phase-head strong {
  border-radius: 999px;
  padding: 7px 10px;
  color: #06343d;
  background: #fff;
  font-size: 12px;
  white-space: nowrap;
}

.guided-phase-body {
  display: grid;
  gap: 12px;
}

.guided-support {
  display: grid;
  gap: 0;
  border-bottom: 1px solid var(--line);
  background: #fff;
}

.guided-support-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 16px;
  background: var(--soft);
}

.guided-support-heading.teal {
  background: rgba(17, 199, 189, 0.14);
}

.guided-support-heading h3 {
  margin: 0;
  color: var(--navy);
  font-size: 16px;
  line-height: 1.1;
  text-transform: uppercase;
}

.guided-support-body {
  display: grid;
  gap: 12px;
  padding: 14px 16px;
}

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

.inline-media-prompt {
  display: grid;
  gap: 10px;
  margin-top: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: var(--soft);
}

.inline-media-head {
  display: grid;
  gap: 4px;
}

.inline-media-head strong {
  margin: 0;
  color: var(--navy);
}

.inline-media-head span {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}

.match-list {
  display: grid;
  gap: 8px;
}

.match-card {
  display: grid;
  grid-template-columns: 58px 1fr auto;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px;
  background: #fff;
}

.match-card.is-matched {
  border-color: rgba(7, 149, 143, 0.36);
  background: rgba(17, 199, 189, 0.08);
}

.match-card img {
  width: 58px;
  height: 58px;
  border-radius: 6px;
  object-fit: cover;
}

.match-card strong {
  margin: 0;
  color: var(--ink);
  font-size: 14px;
}

.match-card span {
  display: block;
  overflow: hidden;
  color: var(--muted);
  font-size: 12px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.match-card .button {
  min-height: 36px;
  padding: 0 10px;
  font-size: 13px;
}

.before-after-tools {
  display: grid;
  gap: 10px;
  border: 1px solid rgba(17, 199, 189, 0.38);
  border-radius: 8px;
  padding: 12px;
  background: #fff;
}

.inline-media-prompt.is-collage-ready > .inline-media-head,
.inline-media-prompt.is-collage-ready > .match-list,
.inline-media-prompt.is-collage-ready > .media-grid,
.inline-media-prompt.is-collage-ready > .media-status {
  display: none;
}

.inline-media-prompt.is-collage-ready .before-after-tools {
  border: 0;
  padding: 0;
  background: transparent;
}

.inline-media-prompt.is-collage-ready .before-after-tools > .inline-media-head,
.inline-media-prompt.is-collage-ready .before-after-tools > .media-actions {
  display: none;
}

.generated-post-grid {
  display: grid;
  gap: 10px;
}

.generated-post-grid:empty {
  display: none;
}

.generated-post-card {
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px;
  background: var(--soft);
}

.generated-post-card img {
  width: 92px;
  aspect-ratio: 1;
  border-radius: 6px;
  object-fit: cover;
}

.generated-post-card strong {
  margin: 0 0 8px;
  color: var(--navy);
  font-size: 14px;
}

.generated-post-card .button {
  width: 100%;
  min-height: 36px;
  font-size: 13px;
}

.generated-collage {
  display: block;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(5, 24, 44, 0.14);
}

.generated-collage img {
  width: 100%;
  display: block;
}

.service-prep .section-body {
  display: grid;
  gap: 12px;
}

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

.service-tags span {
  border-radius: 999px;
  padding: 7px 10px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.22);
  font-size: 12px;
  font-weight: 900;
}

.service-list {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
  list-style: none;
}

.service-list li {
  border-left: 4px solid var(--teal);
  border-radius: 6px;
  padding: 10px 12px;
  color: var(--ink);
  background: var(--soft);
  line-height: 1.35;
}

.service-list:empty,
.service-line-items:empty {
  display: none;
}

.service-line-items {
  display: grid;
  gap: 10px;
}

.service-line-card {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  border-left: 4px solid var(--teal);
  border-radius: 8px;
  padding: 12px;
  background: #fff;
}

.service-line-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
}

.service-line-head strong {
  display: block;
  color: var(--navy);
  font-size: 15px;
  line-height: 1.25;
}

.service-line-head span:not(.pill) {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.service-line-card .pill {
  justify-self: end;
  max-width: 180px;
  text-align: right;
  white-space: normal;
}

.service-line-note {
  margin: 0;
  border-radius: 6px;
  padding: 9px 10px;
  color: var(--ink);
  background: var(--soft);
  font-size: 13px;
  line-height: 1.35;
}

.job-specific-checklist .section-body {
  display: grid;
  gap: 12px;
}

.job-scope-card {
  display: grid;
  gap: 5px;
  border: 1px solid rgba(17, 199, 189, 0.34);
  border-radius: 8px;
  padding: 12px;
  background: rgba(17, 199, 189, 0.08);
}

.job-scope-card strong {
  color: var(--navy);
  font-size: 15px;
}

.job-scope-card span {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.schedule-view .section-body {
  display: grid;
  gap: 10px;
}

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

.schedule-range {
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 7px;
  color: var(--navy);
  background: var(--soft);
  font-weight: 900;
  cursor: pointer;
}

.schedule-range.active,
.schedule-range:hover {
  color: #06343d;
  border-color: var(--teal);
  background: rgba(17, 199, 189, 0.22);
}

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

.schedule-display {
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 7px;
  color: var(--navy);
  background: var(--soft);
  font-weight: 900;
  cursor: pointer;
}

.schedule-display.active,
.schedule-display:hover {
  color: #06343d;
  border-color: var(--teal);
  background: rgba(17, 199, 189, 0.22);
}

.schedule-map-toggle {
  display: flex;
  align-items: center;
  gap: 9px;
  border: 1px solid rgba(245, 158, 11, 0.35);
  border-radius: 7px;
  padding: 10px 12px;
  color: var(--warning-ink);
  background: rgba(245, 158, 11, 0.12);
  font-weight: 900;
  cursor: pointer;
}

.schedule-map-toggle input {
  width: 20px;
  height: 20px;
  margin: 0;
  accent-color: var(--warning);
}

.schedule-assignee-filter {
  display: grid;
  gap: 6px;
}

.schedule-assignee-filter span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.schedule-assignee-filter select {
  width: 100%;
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 0 12px;
  color: var(--navy);
  background: var(--soft);
  font-weight: 900;
}

.schedule-assignee-filter select:focus {
  border-color: var(--teal);
  outline: none;
  box-shadow: 0 0 0 3px rgba(17, 199, 189, 0.18);
}

.schedule-user-scope {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 34px;
  border: 1px solid rgba(7, 149, 143, 0.24);
  border-radius: 999px;
  padding: 7px 12px;
  color: #075e59;
  background: rgba(17, 199, 189, 0.12);
  font-size: 12px;
  font-weight: 900;
}

.schedule-list {
  display: grid;
  gap: 12px;
}

.schedule-nav {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) 44px;
  gap: 10px;
  align-items: center;
}

.schedule-arrow,
.schedule-current {
  min-height: 46px;
  border: 1px solid var(--line);
  border-radius: 7px;
  color: var(--navy);
  background: #fff;
  font-weight: 900;
  cursor: pointer;
}

.schedule-arrow {
  font-size: 30px;
  line-height: 1;
}

.schedule-current {
  padding: 0 14px;
  font-size: 17px;
}

.schedule-arrow:hover,
.schedule-current:hover {
  border-color: var(--teal);
  background: rgba(17, 199, 189, 0.12);
}

.schedule-week-board {
  display: grid;
  grid-template-columns: repeat(7, minmax(160px, 1fr));
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 6px;
}

.schedule-day-column {
  min-width: 160px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--soft);
  overflow: hidden;
}

.schedule-day-column.is-today {
  border-color: var(--danger);
  box-shadow: 0 0 0 2px rgba(215, 25, 70, 0.16);
}

.schedule-day-column.is-today .schedule-day-head {
  background: var(--danger);
}

.schedule-day-head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 2px 8px;
  padding: 10px;
  color: #fff;
  background: var(--navy);
}

.schedule-day-head strong {
  font-size: 15px;
}

.schedule-day-head span {
  color: rgba(255, 255, 255, 0.78);
  font-size: 12px;
  font-weight: 800;
}

.schedule-day-head em {
  grid-row: 1 / span 2;
  grid-column: 2;
  align-self: center;
  min-width: 26px;
  border-radius: 999px;
  padding: 5px 7px;
  color: #06343d;
  background: var(--teal);
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
  text-align: center;
}

.schedule-day-jobs {
  display: grid;
  gap: 8px;
  padding: 8px;
}

.schedule-day-jobs > .muted {
  margin: 0;
  padding: 10px 4px;
  text-align: center;
  font-size: 13px;
}

.schedule-mobile-agenda {
  display: none;
  gap: 12px;
}

.schedule-mobile-summary {
  display: none;
  gap: 12px;
}

.mobile-week-strip {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 6px;
}

.mobile-day-chip,
.mobile-month-cell {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 3px;
  min-height: 62px;
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 6px 4px;
  color: var(--navy);
  background: #fff;
  text-decoration: none;
}

.mobile-day-chip.active,
.mobile-month-cell.active {
  border-color: var(--teal);
  background: rgba(17, 199, 189, 0.18);
  box-shadow: inset 0 0 0 1px rgba(17, 199, 189, 0.4);
}

.mobile-day-chip.is-today,
.mobile-month-cell.is-today {
  border-color: var(--open);
}

.mobile-day-chip strong,
.mobile-month-cell strong {
  font-size: 12px;
  line-height: 1;
}

.mobile-day-chip span {
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
}

.mobile-day-chip em,
.mobile-month-cell em {
  min-width: 22px;
  border-radius: 999px;
  padding: 3px 6px;
  color: #06343d;
  background: var(--teal);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-align: center;
}

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

.mobile-month-cell {
  min-height: 44px;
  padding: 5px 3px;
}

.mobile-month-cell.is-outside-month {
  opacity: 0.45;
  background: var(--soft);
}

.mobile-selected-day {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

.mobile-selected-day.is-today {
  border-color: var(--open);
}

.mobile-selected-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 11px 12px;
  color: #fff;
  background: var(--navy);
}

.mobile-selected-day.is-today .mobile-selected-head {
  background: var(--open);
}

.mobile-selected-head strong {
  font-size: 14px;
}

.mobile-selected-head span {
  border-radius: 999px;
  padding: 4px 8px;
  color: #06343d;
  background: var(--teal);
  font-size: 11px;
  font-weight: 900;
}

.mobile-selected-jobs {
  display: grid;
  gap: 10px;
  padding: 10px;
}

.mobile-selected-jobs > .muted {
  margin: 0;
  text-align: center;
}

.schedule-agenda-day {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

.schedule-agenda-day.is-today {
  border-color: var(--open);
  box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.14);
}

.schedule-agenda-head {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 8px;
  align-items: center;
  padding: 10px 12px;
  color: #fff;
  background: var(--navy);
}

.schedule-agenda-day.is-today .schedule-agenda-head {
  background: var(--open);
}

.schedule-agenda-head strong {
  font-size: 14px;
}

.schedule-agenda-head span {
  color: rgba(255, 255, 255, 0.82);
  font-size: 12px;
  font-weight: 800;
}

.schedule-agenda-head em {
  min-width: 26px;
  border-radius: 999px;
  padding: 5px 7px;
  color: #06343d;
  background: var(--teal);
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
  text-align: center;
}

.schedule-agenda-jobs {
  display: grid;
  gap: 10px;
  padding: 10px;
}

.schedule-agenda-jobs > .muted {
  margin: 0;
  color: var(--muted);
  text-align: center;
}

.schedule-mini-card {
  display: grid;
  gap: 5px;
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 9px;
  background: #fff;
}

.schedule-mini-card.is-open {
  border-left: 5px solid var(--open);
}

.schedule-mini-card.is-complete {
  border-left: 5px solid var(--success);
  background: rgba(17, 199, 189, 0.08);
}

.schedule-mini-card.is-submitted {
  border-color: rgba(7, 149, 143, 0.34);
  background: rgba(17, 199, 189, 0.07);
}

.schedule-status-chip {
  display: inline-flex;
  justify-self: start;
  border-radius: 999px;
  padding: 4px 8px;
  color: #fff;
  background: var(--open);
  font-size: 10px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.is-complete .schedule-status-chip,
.is-submitted .schedule-status-chip {
  color: #06343d;
  background: var(--teal);
}

.schedule-mini-time {
  color: var(--success);
  font-size: 12px;
  font-weight: 900;
}

.schedule-mini-card strong {
  color: var(--navy);
  font-size: 14px;
  line-height: 1.2;
}

.schedule-mini-card span,
.schedule-mini-card small {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.schedule-mini-card .button {
  min-height: 34px;
  margin-top: 3px;
  padding: 0 8px;
  font-size: 12px;
}

.schedule-date-groups {
  display: grid;
  gap: 14px;
}

.schedule-date-group {
  display: grid;
  gap: 10px;
}

.schedule-date-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 8px;
}

.schedule-date-head h3 {
  margin: 0;
  color: var(--navy);
  font-size: 18px;
}

.schedule-group-list {
  display: grid;
  gap: 10px;
}

.schedule-month-calendar {
  display: grid;
  grid-template-columns: repeat(7, minmax(112px, 1fr));
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow-x: auto;
  background: var(--line);
}

.schedule-month-weekday {
  min-width: 112px;
  padding: 10px;
  color: #fff;
  background: var(--navy);
  font-size: 12px;
  font-weight: 900;
  text-align: center;
}

.schedule-month-cell {
  min-width: 112px;
  min-height: 118px;
  display: grid;
  align-content: start;
  gap: 7px;
  padding: 8px;
  background: #fff;
}

.schedule-month-cell.is-today {
  outline: 3px solid rgba(215, 25, 70, 0.48);
  outline-offset: -3px;
  background: #fff7f9;
}

.schedule-month-cell.is-outside-month {
  background: #eef4f8;
}

.schedule-month-cell.is-outside-month .schedule-month-date {
  opacity: 0.48;
}

.schedule-month-date {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}

.schedule-month-date strong {
  color: var(--navy);
  font-size: 14px;
}

.schedule-month-date span {
  min-width: 22px;
  border-radius: 999px;
  padding: 3px 6px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.28);
  font-size: 11px;
  font-weight: 900;
  text-align: center;
}

.schedule-month-jobs {
  display: grid;
  gap: 5px;
}

.month-job-pill {
  display: grid;
  gap: 3px;
  width: 100%;
  border: 1px solid var(--line);
  border-left: 5px solid var(--open);
  border-radius: 6px;
  padding: 6px;
  color: var(--ink);
  background: #fff;
  text-align: left;
  cursor: pointer;
}

.month-job-pill.is-complete {
  border-left-color: var(--success);
  background: rgba(17, 199, 189, 0.09);
}

.month-job-pill.is-submitted {
  border-color: rgba(7, 149, 143, 0.5);
  background: rgba(7, 149, 143, 0.13);
}

.month-job-pill span {
  color: var(--success);
  font-size: 10px;
  font-weight: 900;
  line-height: 1.15;
}

.month-job-pill strong {
  overflow: hidden;
  color: var(--navy);
  font-size: 11px;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.month-job-pill em {
  justify-self: start;
  border-radius: 999px;
  padding: 3px 6px;
  color: #fff;
  background: var(--open);
  font-size: 9px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.month-job-pill.is-complete em,
.month-job-pill.is-submitted em {
  color: #06343d;
  background: var(--teal);
}

.schedule-map-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(320px, 0.55fr);
  gap: 12px;
}

.schedule-map-canvas {
  min-height: 620px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--soft);
}

.reports-view .section-body {
  display: grid;
  gap: 16px;
}

.jobber-reports-view {
  color: #012939;
}

.jobber-reports-view > .section-heading {
  align-items: center;
  border: 0;
  padding: 0;
  background: transparent;
}

.jobber-reports-view > .section-heading h2 {
  color: #012939;
  font-size: 34px;
  letter-spacing: 0;
}

.jobber-report-toolbar {
  border: 1px solid #d7dde2;
  border-radius: 8px;
  padding: 14px 16px;
  background: #fff;
}

.jobber-insights {
  display: grid;
  gap: 18px;
}

.jobber-section-title {
  margin: 18px 0 0;
  color: #012939;
  font-size: 25px;
  line-height: 1.1;
}

.jobber-report-card {
  border: 1px solid #d7dde2;
  border-radius: 8px;
  background: #fff;
}

.jobber-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 18px 16px 10px;
}

.jobber-card-head h3 {
  margin: 0;
  color: #012939;
  font-size: 20px;
  line-height: 1.15;
}

.jobber-card-head span,
.jobber-card-head a {
  color: #395468;
  font-size: 13px;
  font-weight: 700;
}

.jobber-card-head a {
  text-decoration: none;
}

.jobber-card-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-end;
  gap: 12px;
  min-width: 260px;
}

.jobber-range-control {
  display: grid;
  justify-items: end;
  gap: 8px;
}

.jobber-range-control label {
  display: grid;
  gap: 4px;
}

.jobber-range-control label span {
  color: #667888;
  font-size: 11px;
  text-align: right;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.jobber-range-control select,
.jobber-range-control input {
  min-height: 34px;
  border: 1px solid #c8d3dc;
  border-radius: 6px;
  padding: 0 10px;
  color: #012939;
  background: #fff;
  font-weight: 800;
}

.jobber-custom-range {
  display: none;
  grid-template-columns: 132px 132px auto;
  gap: 8px;
}

.jobber-custom-range.is-visible {
  display: grid;
}

.jobber-overview-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  padding: 8px 16px 16px;
}

.jobber-overview-metric {
  display: grid;
  gap: 7px;
  min-width: 0;
  border-left: 1px solid #d7dde2;
  padding: 0 14px;
  color: inherit;
  text-decoration: none;
}

.jobber-overview-metric:hover span {
  text-decoration: underline;
}

.jobber-overview-metric:first-child {
  border-left: 0;
  padding-left: 0;
}

.jobber-overview-metric span {
  color: #012939;
  font-size: 14px;
  font-weight: 900;
}

.jobber-overview-metric strong {
  color: #012939;
  font-size: 26px;
  line-height: 1;
}

.jobber-overview-metric em {
  width: max-content;
  border-radius: 999px;
  padding: 4px 10px;
  background: #e3f2df;
  color: #1e6b2d;
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
}

.jobber-overview-metric em.is-down {
  background: #f9e2df;
  color: #9c2f21;
}

.jobber-revenue-card {
  padding-bottom: 16px;
}

.jobber-revenue-totals {
  display: flex;
  gap: 24px;
  padding: 0 16px 8px;
}

.jobber-revenue-totals div {
  display: grid;
  gap: 3px;
}

.jobber-revenue-totals strong {
  color: #012939;
  font-size: 30px;
  line-height: 1;
}

.jobber-revenue-totals span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #395468;
  font-size: 13px;
  font-weight: 800;
}

.jobber-revenue-totals i,
.jobber-source-list i {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #5540bd;
}

.jobber-revenue-totals i.current {
  background: #9c8adf;
}

.jobber-revenue-chart {
  display: grid;
  grid-template-columns: 42px minmax(720px, 1fr);
  gap: 10px;
  overflow-x: auto;
  padding: 6px 16px 0;
}

.jobber-y-axis {
  display: grid;
  grid-template-rows: 1fr 1fr 1fr;
  min-height: 165px;
  padding-bottom: 28px;
  color: #395468;
  font-size: 12px;
  font-weight: 700;
  text-align: right;
}

.jobber-month-chart {
  display: grid;
  grid-template-columns: repeat(12, minmax(46px, 1fr));
  gap: 12px;
  min-width: 720px;
  min-height: 165px;
  border-bottom: 1px solid #d7dde2;
  background:
    linear-gradient(to bottom, #e3e8ec 1px, transparent 1px) 0 0 / 100% 50%,
    linear-gradient(to bottom, transparent calc(100% - 1px), #d7dde2 1px);
}

.jobber-month-group {
  position: relative;
  display: grid;
  grid-template-rows: 1fr auto;
  gap: 8px;
  outline: none;
}

.jobber-month-bars {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 6px;
  min-height: 140px;
}

.jobber-bar {
  display: block;
  width: 24px;
  min-height: 3px;
  border-radius: 3px 3px 0 0;
  background: #5540bd;
}

.jobber-bar.current {
  background: #9c8adf;
}

.jobber-bar.is-zero {
  opacity: 0.24;
}

.jobber-month-group > strong {
  color: #395468;
  font-size: 12px;
  font-weight: 700;
  text-align: center;
}

.jobber-hover-card {
  position: absolute;
  left: 50%;
  bottom: 34px;
  z-index: 7;
  display: none;
  width: 238px;
  transform: translateX(-50%);
  border: 1px solid #d7dde2;
  border-radius: 8px;
  padding: 10px;
  background: #fff;
  box-shadow: 0 12px 34px rgba(1, 41, 57, 0.18);
}

.jobber-month-group:hover .jobber-hover-card,
.jobber-month-group:focus-visible .jobber-hover-card {
  display: grid;
  gap: 6px;
}

.jobber-hover-card b {
  color: #012939;
  font-size: 13px;
}

.jobber-hover-card span {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: #395468;
  font-size: 12px;
  font-weight: 700;
}

.jobber-hover-card i {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  flex: 0 0 auto;
}

.jobber-hover-card i.compare {
  background: #5540bd;
}

.jobber-hover-card i.current {
  background: #9c8adf;
}

.jobber-hover-card span strong {
  margin-left: auto;
}

.jobber-hover-card .jobber-hover-change {
  margin-top: 4px;
  border-top: 1px solid #e2e8ee;
  padding-top: 8px;
}

.jobber-hover-change.is-up strong {
  color: #2f7d32;
}

.jobber-hover-change.is-down strong {
  color: #a82417;
}

.jobber-hover-card strong {
  color: #012939;
}

.jobber-insight-grid {
  display: grid;
  gap: 16px;
}

.jobber-insight-grid.two {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
}

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

.jobber-insight-grid.four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.jobber-donut-wrap {
  display: grid;
  place-items: center;
  gap: 18px;
  min-height: 280px;
  padding: 16px;
}

.jobber-lead-card .jobber-donut-wrap {
  grid-template-columns: 180px minmax(0, 1fr);
  min-height: 190px;
}

.jobber-donut {
  display: grid;
  place-items: center;
  width: 152px;
  height: 152px;
  border-radius: 999px;
  background:
    radial-gradient(circle at center, #fff 0 54%, transparent 55%),
    conic-gradient(#9c8adf 0 var(--fill), #dfe4e8 var(--fill) 100%);
}

.jobber-donut strong {
  align-self: end;
  color: #012939;
  font-size: 24px;
}

.jobber-donut span {
  align-self: start;
  color: #395468;
  font-size: 12px;
  font-weight: 700;
}

.jobber-source-list {
  display: grid;
  gap: 7px;
  width: 100%;
}

.jobber-source-list span {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  color: #395468;
  font-size: 13px;
  font-weight: 700;
}

.jobber-source-list strong {
  color: #012939;
  margin-left: auto;
}

.jobber-revenue-map-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 230px;
  gap: 12px;
  padding: 14px;
}

.jobber-revenue-map-canvas {
  position: relative;
  min-height: 330px;
  overflow: hidden;
  border: 1px solid #d7dde2;
  border-radius: 8px;
  background: #e8eef1;
}

.jobber-heatmap-card .jobber-revenue-map-canvas {
  min-height: 520px;
  margin: 14px;
}

.jobber-revenue-map-canvas .leaflet-interactive {
  cursor: pointer;
}

.revenue-map-floating-legend {
  position: absolute;
  right: 14px;
  bottom: 14px;
  z-index: 500;
  display: grid;
  gap: 7px;
  border: 1px solid #d7dde2;
  border-radius: 8px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 8px 26px rgba(1, 41, 57, 0.16);
  pointer-events: none;
}

.revenue-map-floating-legend strong {
  color: #012939;
  font-size: 13px;
}

.revenue-map-floating-legend span {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #395468;
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.revenue-map-floating-legend i {
  width: 12px;
  height: 12px;
  border: 1px solid rgba(1, 41, 57, 0.12);
}

.jobber-revenue-map-canvas > .muted {
  display: grid;
  min-height: 260px;
  place-items: center;
  margin: 0;
  padding: 18px;
  text-align: center;
}

.jobber-revenue-map-panel {
  display: grid;
  align-content: start;
  gap: 10px;
  min-width: 0;
}

.revenue-map-stat {
  display: grid;
  gap: 3px;
  border: 1px solid #d7dde2;
  border-radius: 8px;
  padding: 10px;
  background: #f7fafc;
}

.revenue-map-stat span,
.revenue-map-stat em {
  color: #395468;
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}

.revenue-map-stat strong {
  color: #012939;
  font-size: 24px;
  line-height: 1;
}

.revenue-map-legend {
  display: grid;
  gap: 7px;
  border: 1px solid #d7dde2;
  border-radius: 8px;
  padding: 10px;
  background: #fff;
}

.revenue-map-legend span {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #395468;
  font-size: 12px;
  font-weight: 800;
}

.revenue-map-legend i {
  width: 12px;
  height: 12px;
  border-radius: 999px;
}

.revenue-map-legend i.low {
  background: #18bfae;
}

.revenue-map-legend i.mid {
  background: #00a9c8;
}

.revenue-map-legend i.high {
  background: #5540bd;
}

.revenue-map-areas {
  display: grid;
  gap: 7px;
}

.revenue-map-areas > strong {
  color: #012939;
  font-size: 13px;
  text-transform: uppercase;
}

.revenue-map-areas button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 38px;
  border: 1px solid #d7dde2;
  border-radius: 8px;
  padding: 8px 10px;
  color: #012939;
  background: #fff;
  font: inherit;
  font-size: 12px;
  font-weight: 900;
  text-align: left;
  cursor: pointer;
}

.revenue-map-areas button:hover {
  border-color: #00a9c8;
  background: #eefcfd;
}

.revenue-map-areas button span {
  min-width: 0;
}

.revenue-map-areas button em {
  flex: 0 0 auto;
  color: #395468;
  font-style: normal;
}

.revenue-map-popup-list {
  display: grid;
  gap: 5px;
  border-top: 1px solid #d7dde2;
  padding-top: 6px;
}

.revenue-map-popup-list span {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.revenue-map-popup-list b {
  max-width: 150px;
  overflow: hidden;
  color: #012939;
  font-size: 12px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.jobber-report-tile {
  position: relative;
  display: grid;
  align-content: start;
  gap: 8px;
  min-height: 150px;
  padding: 20px 16px;
  color: inherit;
  text-decoration: none;
}

.jobber-report-tile:hover {
  border-color: #9fb0bd;
  box-shadow: 0 8px 24px rgba(1, 41, 57, 0.08);
}

.jobber-report-tile h3 {
  margin: 0;
  color: #012939;
  font-size: 19px;
}

.jobber-report-tile p,
.jobber-report-tile span {
  margin: 0;
  color: #395468;
  font-size: 13px;
  font-weight: 700;
}

.jobber-report-tile strong {
  color: #012939;
  font-size: 28px;
  line-height: 1;
}

.jobber-tile-link {
  position: absolute;
  top: 14px;
  right: 14px;
  color: #395468;
  font-size: 12px;
  font-weight: 900;
}

.jobber-caveats {
  display: grid;
  gap: 4px;
  color: #395468;
  font-size: 12px;
  font-weight: 700;
}

.jobber-report-detail {
  display: grid;
  gap: 16px;
}

.jobber-report-detail-hero {
  padding: 22px 18px;
}

.jobber-report-detail-hero h3 {
  margin: 0 0 6px;
  color: #012939;
  font-size: 28px;
}

.jobber-report-detail-hero p,
.jobber-report-detail-hero span {
  margin: 0;
  color: #395468;
  font-size: 14px;
  font-weight: 700;
}

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

.jobber-detail-stats article {
  display: grid;
  gap: 7px;
  padding: 16px;
}

.jobber-detail-stats span,
.jobber-aging-grid span {
  color: #395468;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.jobber-detail-stats strong,
.jobber-aging-grid strong {
  color: #012939;
  font-size: 24px;
  line-height: 1;
}

.jobber-aging-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  padding: 0 16px 16px;
}

.jobber-aging-grid article {
  display: grid;
  gap: 6px;
  border: 1px solid #d7dde2;
  border-radius: 8px;
  padding: 12px;
  background: #f7f9fa;
}

.jobber-aging-grid em {
  color: #395468;
  font-size: 12px;
  font-style: normal;
  font-weight: 700;
}

.jobber-detail-table-wrap {
  overflow-x: auto;
  padding: 0 16px 16px;
}

.jobber-detail-table {
  display: grid;
  gap: 0;
  min-width: 760px;
  border: 1px solid #d7dde2;
  border-radius: 8px;
  overflow: hidden;
}

.jobber-detail-row {
  display: grid;
  grid-template-columns: repeat(var(--report-columns), minmax(130px, 1fr));
  gap: 0;
  color: inherit;
  text-decoration: none;
}

.jobber-detail-row.header {
  background: #f7f9fa;
}

.jobber-detail-row:not(.header):hover {
  background: #f3f8fb;
}

.jobber-detail-row span {
  min-width: 0;
  border-bottom: 1px solid #d7dde2;
  padding: 11px 12px;
  color: #012939;
  font-size: 13px;
  font-weight: 700;
  overflow-wrap: anywhere;
}

.jobber-detail-row.header span {
  color: #395468;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.report-toolbar {
  display: grid;
  grid-template-columns: minmax(180px, 0.5fr) minmax(280px, 1fr);
  gap: 12px;
  align-items: end;
}

.revenue-year-controls {
  display: grid;
  grid-template-columns: repeat(2, minmax(130px, 1fr));
  gap: 12px;
}

.revenue-report {
  display: grid;
  gap: 14px;
}

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

.revenue-kpi {
  display: grid;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
  background: #fff;
}

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

.revenue-kpi strong {
  color: var(--navy);
  font-size: 28px;
  line-height: 1;
}

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

.revenue-chart-card {
  display: grid;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
  background: #fff;
}

.revenue-chart-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 14px;
}

.revenue-chart-head div:first-child {
  display: grid;
  gap: 4px;
}

.revenue-chart-head strong {
  color: var(--navy);
  font-size: 18px;
}

.revenue-chart-head span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.revenue-legend {
  display: flex;
  flex-wrap: wrap;
  justify-content: end;
  gap: 8px;
}

.revenue-legend span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 5px 9px;
  background: var(--soft);
  color: var(--ink);
  font-size: 11px;
  font-weight: 900;
}

.revenue-legend i {
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 999px;
}

.revenue-legend i.paid {
  background: var(--success);
}

.revenue-legend i.invoiced {
  background: var(--navy);
}

.revenue-legend i.compare {
  background: var(--open);
}

.revenue-chart-scroll {
  display: grid;
  grid-template-columns: 54px minmax(740px, 1fr);
  gap: 10px;
  overflow-x: auto;
  padding: 6px 2px 8px;
}

.revenue-chart-scale {
  display: grid;
  grid-template-rows: 1fr 1fr 1fr;
  min-height: 280px;
  padding: 4px 0 28px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-align: right;
}

.revenue-chart {
  display: grid;
  grid-template-columns: repeat(12, minmax(58px, 1fr));
  gap: 8px;
  min-height: 280px;
  min-width: 740px;
  border-bottom: 2px solid var(--line);
  background:
    linear-gradient(to bottom, rgba(13, 56, 82, 0.08) 1px, transparent 1px) 0 0 / 100% 33.333%,
    linear-gradient(to bottom, rgba(13, 56, 82, 0.06), rgba(13, 56, 82, 0));
  padding: 4px 6px 0;
}

.revenue-month-group {
  position: relative;
  display: grid;
  grid-template-rows: 1fr auto;
  gap: 8px;
  min-width: 0;
  outline: none;
}

.revenue-month-group > strong {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-align: center;
}

.revenue-bars {
  display: flex;
  align-items: end;
  justify-content: center;
  gap: 5px;
  min-height: 242px;
}

.revenue-bar-column {
  display: flex;
  align-items: end;
  width: 20px;
  height: 100%;
  border-radius: 7px 7px 0 0;
  background: rgba(13, 56, 82, 0.05);
}

.revenue-bar-fill {
  display: block;
  width: 100%;
  border-radius: 7px 7px 0 0;
  min-height: 4px;
  transition: filter 160ms ease, transform 160ms ease;
}

.revenue-bar-fill.paid {
  background: linear-gradient(180deg, var(--success), #12948e);
}

.revenue-bar-fill.compare {
  background: linear-gradient(180deg, var(--open), #e58b08);
}

.revenue-bar-fill.is-zero {
  min-height: 2px;
  opacity: 0.35;
}

.revenue-month-group:hover .revenue-bar-fill,
.revenue-month-group:focus-visible .revenue-bar-fill {
  filter: brightness(1.04);
  transform: translateY(-2px);
}

.revenue-hover-card {
  position: absolute;
  left: 50%;
  bottom: 42px;
  z-index: 6;
  display: none;
  width: 230px;
  transform: translateX(-50%);
  border: 1px solid rgba(13, 56, 82, 0.18);
  border-radius: 8px;
  padding: 10px;
  background: #fff;
  box-shadow: 0 18px 38px rgba(13, 56, 82, 0.18);
  color: var(--ink);
}

.revenue-month-group:hover .revenue-hover-card,
.revenue-month-group:focus-visible .revenue-hover-card {
  display: grid;
  gap: 5px;
}

.revenue-hover-card b {
  color: var(--navy);
  font-size: 13px;
}

.revenue-hover-card span,
.revenue-hover-card em {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 800;
}

.revenue-hover-card span strong {
  color: var(--navy);
}

.revenue-report-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.8fr);
  gap: 14px;
}

.revenue-table-wrap,
.revenue-open-wrap {
  display: grid;
  align-content: start;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
  background: #fff;
}

.revenue-table-wrap {
  overflow-x: auto;
}

.revenue-table {
  display: grid;
  align-content: start;
  gap: 7px;
  min-width: 820px;
}

.revenue-table-row {
  display: grid;
  grid-template-columns: 58px repeat(6, minmax(86px, 1fr));
  gap: 8px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 9px 10px;
  background: var(--soft);
}

.revenue-table-row.header {
  border: 0;
  padding-block: 0;
  background: transparent;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.revenue-table-row span,
.revenue-table-row em,
.revenue-table-row strong {
  min-width: 0;
  overflow-wrap: anywhere;
  color: var(--ink);
  font-size: 13px;
  font-style: normal;
}

.revenue-table-row strong {
  color: var(--navy);
}

.revenue-owner-signals {
  display: grid;
  grid-template-columns: minmax(220px, 0.8fr) minmax(0, 1.6fr);
  gap: 12px;
  border: 1px solid rgba(22, 189, 183, 0.35);
  border-radius: 8px;
  padding: 14px;
  background: linear-gradient(135deg, rgba(22, 189, 183, 0.12), rgba(255, 255, 255, 0.88));
}

.revenue-owner-copy {
  display: grid;
  align-content: start;
  gap: 5px;
}

.revenue-owner-copy strong {
  color: var(--navy);
  font-size: 20px;
}

.revenue-owner-copy em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  font-weight: 800;
}

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

.revenue-signal {
  display: grid;
  gap: 5px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: #fff;
}

.revenue-signal span,
.revenue-small-metrics span,
.revenue-mini-grid span,
.revenue-aging-total span,
.revenue-aging-row span {
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.revenue-signal strong {
  color: var(--navy);
  font-size: 22px;
  line-height: 1;
}

.revenue-signal em,
.revenue-mini-grid em,
.revenue-aging-row em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 800;
}

.revenue-signal.is-good {
  border-color: rgba(22, 163, 74, 0.28);
}

.revenue-signal.is-warn {
  border-color: rgba(245, 158, 11, 0.4);
  background: rgba(245, 158, 11, 0.08);
}

.revenue-small-metrics {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.revenue-small-metrics span {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  border: 1px solid rgba(13, 56, 82, 0.1);
  border-radius: 7px;
  padding: 8px 10px;
  background: rgba(255, 255, 255, 0.78);
}

.revenue-small-metrics strong {
  color: var(--navy);
  white-space: nowrap;
}

.revenue-side-stack {
  align-content: start;
}

.revenue-side-stack > div {
  display: grid;
  gap: 8px;
}

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

.revenue-mini-grid article {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 10px;
  background: var(--soft);
}

.revenue-mini-grid article.needs-attention {
  border-color: rgba(245, 158, 11, 0.45);
  background: rgba(245, 158, 11, 0.08);
}

.revenue-mini-grid strong {
  color: var(--navy);
  font-size: 18px;
}

.revenue-aging {
  display: grid;
  gap: 8px;
}

.revenue-aging-total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border: 1px solid rgba(13, 56, 82, 0.12);
  border-radius: 7px;
  padding: 9px 10px;
  background: rgba(22, 189, 183, 0.08);
}

.revenue-aging-total strong {
  color: var(--navy);
  font-size: 18px;
}

.revenue-aging-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 6px 10px;
  align-items: center;
}

.revenue-aging-row div {
  display: grid;
  gap: 2px;
}

.revenue-aging-row strong {
  color: var(--navy);
  font-size: 13px;
}

.revenue-aging-row i {
  grid-column: 1 / -1;
  display: block;
  height: 6px;
  border-radius: 999px;
  background: var(--open);
}

.revenue-caveats {
  display: grid;
  gap: 4px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.revenue-open-list {
  display: grid;
  gap: 8px;
}

.revenue-open-card {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  border-left: 5px solid var(--open);
  border-radius: 7px;
  padding: 10px;
  background: var(--soft);
  color: inherit;
  text-decoration: none;
}

.revenue-open-card span {
  color: var(--navy);
  font-size: 13px;
  font-weight: 900;
}

.revenue-open-card strong {
  color: var(--navy);
  font-size: 20px;
}

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

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

.report-stat {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
  background: #fff;
}

.report-stat span {
  display: block;
  margin-bottom: 5px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.report-stat strong {
  color: var(--navy);
  font-size: 30px;
  line-height: 1;
}

.report-stat.is-open {
  border-color: rgba(245, 158, 11, 0.4);
  background: rgba(245, 158, 11, 0.1);
}

.report-panel {
  display: grid;
  gap: 12px;
}

.report-map-canvas {
  min-height: 440px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--soft);
}

.report-map-canvas > .muted {
  display: grid;
  min-height: 260px;
  place-items: center;
  margin: 0;
  padding: 18px;
  text-align: center;
}

.report-time-list {
  display: grid;
  gap: 10px;
}

.report-time-card {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  border-left: 5px solid var(--open);
  border-radius: 8px;
  padding: 13px;
  background: #fff;
}

.report-time-card.is-open {
  border-left-color: var(--success);
  background: rgba(17, 199, 189, 0.07);
}

.report-time-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 10px;
}

.report-time-head div {
  display: grid;
  gap: 3px;
}

.report-time-head strong {
  color: var(--navy);
}

.report-time-head span,
.report-time-head em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  font-weight: 800;
}

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

.report-time-actions span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 0 10px;
  color: var(--muted);
  background: var(--soft);
  font-size: 12px;
  font-weight: 900;
}

.jobs-view .section-body,
.crm-job-form,
.crm-detail-grid {
  display: grid;
  gap: 16px;
}

.crm-toolbar {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) minmax(150px, 0.42fr) minmax(150px, 0.36fr) minmax(130px, 0.32fr) auto;
  gap: 12px;
  align-items: end;
}

.crm-toolbar.simple {
  grid-template-columns: minmax(220px, 1fr) auto;
}

.crm-tabs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 8px;
}

.crm-tabs a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 40px;
  border: 1.5px solid var(--line);
  border-radius: 6px;
  padding: 0 12px;
  color: var(--navy);
  background: #fff;
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
}

.crm-tabs a svg {
  width: 16px;
  height: 16px;
}

.crm-tabs a.active {
  color: #fff;
  border-color: var(--navy);
  background: var(--navy);
}

.crm-toolbar-actions,
.crm-detail-actions,
.crm-job-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.crm-toolbar-actions .button {
  min-width: 96px;
}

.crm-results-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 10px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.pill-row {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
}

.crm-job-list {
  display: grid;
  gap: 12px;
  margin-top: 12px;
}

.crm-job-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  border: 1px solid var(--line);
  border-left: 6px solid var(--open);
  border-radius: 8px;
  padding: 14px;
  background: #fff;
}

.crm-job-card.is-complete,
.crm-job-card.is-invoiced,
.crm-job-card.is-paid {
  border-left-color: var(--success);
  background: rgba(17, 199, 189, 0.07);
}

.crm-job-card.is-partial {
  border-left-color: #f0b429;
  background: rgba(240, 180, 41, 0.08);
}

.crm-job-card.is-cancelled {
  border-left-color: var(--muted);
  opacity: 0.84;
}

.crm-job-card.client-card {
  border-left-color: var(--teal);
}

.crm-client-list {
  display: grid;
  gap: 8px;
}

.crm-client-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: #fff;
}

.crm-client-row:hover {
  border-color: rgba(17, 199, 189, 0.58);
  box-shadow: 0 10px 24px rgba(5, 24, 44, 0.08);
}

.crm-client-main {
  min-width: 0;
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  color: inherit;
  text-decoration: none;
}

.client-avatar {
  width: 46px;
  height: 46px;
  display: inline-grid;
  place-items: center;
  border-radius: 8px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.22);
  font-size: 15px;
  font-weight: 900;
}

.client-avatar.large {
  width: 64px;
  height: 64px;
  color: #fff;
  background: var(--navy);
  font-size: 22px;
}

.client-row-info {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.client-row-info strong {
  color: var(--navy);
  font-size: 17px;
  line-height: 1.2;
}

.client-row-info span,
.client-row-info em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.client-row-counts {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
  max-width: 360px;
}

.client-row-counts span {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  min-height: 28px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 4px 8px;
  color: var(--muted);
  background: var(--soft);
  font-size: 11px;
  font-weight: 900;
  white-space: nowrap;
}

.client-row-counts strong {
  color: var(--navy);
  font-size: 13px;
}

.client-row-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.client-row-actions .button {
  min-height: 36px;
  padding: 8px 10px;
  font-size: 12px;
}

.crm-client-page {
  display: grid;
  gap: 16px;
}

.client-profile-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  border: 1px solid rgba(17, 199, 189, 0.34);
  border-radius: 8px;
  padding: 18px;
  background: #fff;
}

.client-profile-title {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 14px;
  align-items: center;
}

.client-profile-title .eyebrow {
  color: var(--muted);
}

.client-profile-title h2 {
  margin: 0 0 4px;
  color: var(--navy);
  font-size: 30px;
  line-height: 1.05;
}

.client-profile-title p:last-child {
  margin: 0;
  color: var(--muted);
  overflow-wrap: anywhere;
}

.client-profile-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.client-profile-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 10px;
}

.client-stat {
  display: grid;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: #fff;
}

.client-stat span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.client-stat strong {
  color: var(--navy);
  font-size: 26px;
  line-height: 1;
}

.client-profile-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
  gap: 16px;
  align-items: start;
}

.client-activity-section {
  grid-column: 1 / -1;
}

.subsection-label {
  margin: 2px 0 10px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.client-property-list {
  display: grid;
  gap: 8px;
  margin-bottom: 14px;
}

.client-property-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 6px 10px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: var(--soft);
}

.client-property-card strong {
  color: var(--navy);
  overflow-wrap: anywhere;
}

.client-property-card span {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}

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

.client-activity-list {
  display: grid;
  gap: 8px;
}

.client-activity-row {
  display: grid;
  grid-template-columns: 86px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
  color: inherit;
  background: #fff;
  text-decoration: none;
}

.client-activity-row:hover {
  border-color: rgba(17, 199, 189, 0.58);
  background: rgba(17, 199, 189, 0.07);
}

.client-activity-row > span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.client-activity-row div {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.client-activity-row strong {
  color: var(--navy);
  overflow-wrap: anywhere;
}

.client-activity-row em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  line-height: 1.3;
  overflow-wrap: anywhere;
}

.client-activity-row small {
  justify-self: end;
  border-radius: 999px;
  padding: 5px 8px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.18);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  white-space: nowrap;
}

.quote-client-picker {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
  gap: 12px;
  align-items: end;
}

.quote-client-actions {
  display: flex;
  align-items: end;
}

.quote-client-empty {
  display: grid;
  gap: 12px;
  justify-items: start;
}

.quote-client-summary {
  grid-column: 1 / -1;
  display: grid;
  gap: 4px;
  border: 1px solid rgba(17, 199, 189, 0.32);
  border-radius: 8px;
  padding: 12px;
  background: rgba(17, 199, 189, 0.08);
}

.quote-client-summary strong {
  color: var(--navy);
  font-size: 16px;
}

.quote-client-summary span,
.quote-client-summary em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.pricing-client-search {
  display: grid;
  grid-template-columns: minmax(260px, 1.3fr) minmax(210px, 0.9fr) auto;
  gap: 12px;
  align-items: end;
}

.pricing-client-results {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 8px;
  align-items: stretch;
}

.pricing-client-result {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  border: 1.5px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  color: var(--ink);
  background: var(--soft);
  text-align: left;
  cursor: pointer;
}

.pricing-client-result:hover,
.pricing-client-result:focus-visible {
  border-color: var(--teal);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(17, 199, 189, 0.15);
}

.pricing-client-result-main {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.pricing-client-result-main strong {
  color: var(--navy);
  font-size: 15px;
  line-height: 1.15;
}

.pricing-client-result-main em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.pricing-client-result small {
  border-radius: 999px;
  padding: 5px 7px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.18);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  white-space: nowrap;
}

.pricing-client-no-results {
  display: grid;
  gap: 4px;
  border: 1.5px dashed var(--line);
  border-radius: 8px;
  padding: 12px;
  color: var(--muted);
  background: var(--soft);
}

.pricing-client-no-results strong {
  color: var(--navy);
}

.pricing-draft-banner {
  display: grid;
  gap: 4px;
  margin-bottom: 12px;
  border: 1px solid rgba(17, 199, 189, 0.38);
  border-radius: 8px;
  padding: 12px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.12);
}

.pricing-draft-banner strong {
  color: var(--navy);
  font-size: 14px;
}

.pricing-draft-banner span {
  color: #06343d;
  font-size: 13px;
  line-height: 1.35;
}

.quote-public-shell {
  display: grid;
  gap: 14px;
  max-width: 1140px;
  margin: 0 auto;
}

.quote-public-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.quote-public-card {
  display: grid;
  gap: 28px;
  min-height: 1180px;
  border: 1px solid #d7d7d7;
  border-radius: 3px;
  padding: 46px 58px;
  background: #fff;
  box-shadow: 0 16px 42px rgba(5, 24, 44, 0.14);
}

.quote-public-header {
  display: grid;
  grid-template-columns: 132px minmax(0, 1fr);
  gap: 22px;
  align-items: center;
}

.quote-public-header img {
  width: 100%;
  max-height: 118px;
  object-fit: contain;
}

.quote-public-header h2 {
  margin: 0 0 3px;
  color: #000;
  font-size: 36px;
  line-height: 1;
}

.quote-public-header p,
.quote-recipient p,
.quote-recipient em,
.quote-public-footer span {
  margin: 0;
  color: #111;
  font-style: normal;
  line-height: 1.25;
}

.quote-document-top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 0.9fr);
  gap: 42px;
  align-items: start;
}

.quote-recipient {
  display: grid;
  gap: 8px;
  max-width: 320px;
}

.quote-recipient span {
  color: #111;
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

.quote-recipient strong {
  color: #000;
  font-size: 23px;
  line-height: 1.1;
  overflow-wrap: anywhere;
}

.quote-number-panel {
  display: grid;
  justify-self: stretch;
  border-collapse: collapse;
}

.quote-number-panel h3 {
  margin: 0;
  padding: 14px 20px;
  color: #fff;
  background: #4a9dca;
  font-size: 28px;
  line-height: 1;
}

.quote-number-panel > div {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  padding: 9px 20px;
  background: #f6f6f6;
}

.quote-number-panel span,
.quote-number-panel strong {
  color: #000;
  font-size: 16px;
  font-weight: 500;
}

.quote-number-panel .quote-number-total {
  color: #fff;
  background: #4a9dca;
}

.quote-number-panel .quote-number-total span,
.quote-number-panel .quote-number-total strong {
  color: #fff;
  font-size: 24px;
  font-weight: 800;
}

.quote-public-section,
.quote-public-notes {
  display: grid;
  gap: 10px;
}

.quote-product-table {
  display: grid;
  border-bottom: 3px solid #aaa;
}

.quote-product-head,
.quote-product-row {
  display: grid;
  grid-template-columns: minmax(190px, 1.05fr) minmax(0, 1.9fr) 66px 116px 104px;
  gap: 12px;
  align-items: center;
  padding: 12px 10px;
}

.quote-product-head {
  color: #fff;
  background: #4a9dca;
  font-size: 19px;
  font-weight: 800;
}

.quote-product-row {
  align-items: start;
  min-height: 72px;
  border-bottom: 1px solid #aaa;
  color: #000;
  font-size: 18px;
}

.quote-product-row strong {
  color: #000;
  font-size: 18px;
  font-weight: 500;
}

.quote-product-row span {
  color: #000;
  line-height: 1.2;
  white-space: pre-line;
  overflow-wrap: anywhere;
}

.quote-product-row em {
  color: #000;
  font-style: normal;
  text-align: right;
  white-space: nowrap;
}

.quote-total-box {
  justify-self: end;
  display: grid;
  width: min(100%, 360px);
  margin-top: -10px;
}

.quote-total-box > div {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px;
  align-items: center;
  min-height: 43px;
}

.quote-total-box span {
  justify-self: end;
  padding-right: 26px;
  color: #000;
  font-size: 18px;
  font-weight: 800;
}

.quote-total-box strong {
  align-self: stretch;
  display: grid;
  place-items: center end;
  border: 1px solid #aaa;
  border-bottom: 0;
  padding: 0 10px;
  color: #000;
  font-size: 18px;
}

.quote-total-box > div:last-child strong {
  border-bottom: 1px solid #aaa;
  font-size: 20px;
  font-weight: 900;
}

.quote-public-notes {
  border: 1px solid #d8d8d8;
  border-radius: 3px;
  padding: 12px;
  background: #fafafa;
}

.quote-public-notes h3,
.quote-terms h3 {
  margin: 0;
  color: #000;
  font-size: 16px;
  font-weight: 500;
}

.quote-public-notes p,
.quote-terms p {
  margin: 0;
  color: #000;
  line-height: 1.18;
  white-space: pre-line;
}

.quote-terms {
  display: grid;
  gap: 18px;
  color: #000;
  font-size: 18px;
}

.quote-public-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  border-top: 1px solid #d8d8d8;
  padding-top: 18px;
}

.quote-public-footer div {
  display: grid;
  gap: 4px;
}

.quote-public-footer strong {
  color: var(--navy);
  font-size: 18px;
}

.quote-approval-panel {
  border: 2px solid rgba(17, 199, 189, 0.5);
  border-radius: 8px;
  padding: 18px;
  background: rgba(17, 199, 189, 0.1);
}

.quote-section-title {
  margin: 0;
  color: #000;
  font-size: 20px;
}

.quote-product-row.is-discount strong,
.quote-product-row.is-discount em {
  color: #8d1f1f;
}

.quote-builder {
  display: grid;
  gap: 14px;
  margin-top: 14px;
  border: 1px solid rgba(17, 199, 189, 0.3);
  border-radius: 8px;
  padding: 14px;
  background: #fff;
}

.quote-builder-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
}

.quote-builder-head h3 {
  margin: 2px 0 3px;
  color: var(--navy);
  font-size: 22px;
}

.quote-builder-head p {
  margin: 0;
  color: var(--muted);
  line-height: 1.35;
}

.quote-builder-actions,
.quote-tax-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: end;
}

.quote-tax-controls {
  justify-content: space-between;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: var(--soft);
}

.quote-tax-controls .field {
  min-width: 140px;
}

.quote-line-editor {
  display: grid;
  gap: 8px;
  overflow-x: auto;
}

.quote-line-head,
.quote-line-row {
  display: grid;
  grid-template-columns: 112px minmax(150px, 0.8fr) minmax(260px, 1.3fr) 76px 110px 100px 44px;
  gap: 8px;
  align-items: center;
  min-width: 910px;
}

.quote-line-head {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.quote-line-row {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px;
  background: var(--soft);
}

.quote-line-row.is-optional {
  background: rgba(17, 199, 189, 0.08);
}

.quote-line-row.is-discount {
  background: rgba(229, 75, 75, 0.08);
}

.quote-line-row input,
.quote-line-row textarea,
.quote-line-row select {
  width: 100%;
  border: 1.5px solid var(--line);
  border-radius: 6px;
  padding: 9px;
  background: #fff;
}

.quote-line-row textarea {
  min-height: 46px;
  resize: vertical;
}

.quote-line-row strong {
  color: var(--navy);
  text-align: right;
  white-space: nowrap;
}

.quote-line-taxable {
  grid-column: 2 / 4;
  display: inline-flex;
  gap: 7px;
  align-items: center;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.quote-line-taxable input {
  width: 16px;
  height: 16px;
  accent-color: var(--teal);
}

.icon-button {
  display: inline-grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 0;
  border-radius: 8px;
  color: #fff;
  cursor: pointer;
}

.quote-builder-summary {
  justify-self: end;
  display: grid;
  width: min(100%, 420px);
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
}

.quote-builder-summary > div {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  padding: 10px 12px;
  background: #fff;
}

.quote-builder-summary > div + div {
  border-top: 1px solid var(--line);
}

.quote-builder-summary span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.quote-builder-summary strong {
  color: var(--navy);
}

.quote-builder-total {
  background: rgba(17, 199, 189, 0.14) !important;
}

.quote-builder-total strong {
  font-size: 22px;
}

.quote-followup-fields {
  display: grid;
  grid-template-columns: minmax(180px, 0.55fr) minmax(0, 1fr);
  gap: 12px;
  margin: 12px 0;
}

.quote-followup-fields textarea {
  min-height: 86px;
}

.quote-followup-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.quote-followup-stat {
  display: grid;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: #fff;
}

.quote-followup-stat span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.quote-followup-stat strong {
  color: var(--navy);
  font-size: 28px;
  line-height: 1;
}

.quote-followup-stat em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  line-height: 1.3;
}

.quote-followup-list {
  display: grid;
  gap: 12px;
}

.quote-followup-card {
  display: grid;
  gap: 12px;
  border: 1px solid var(--line);
  border-left: 5px solid var(--open);
  border-radius: 8px;
  padding: 14px;
  background: #fff;
}

.quote-followup-card.is-converted,
.quote-followup-card.is-approved {
  border-left-color: var(--teal);
}

.quote-followup-card.is-not-converted,
.quote-followup-card.is-non-responsive,
.quote-followup-card.is-lost,
.quote-followup-card.is-cancelled {
  border-left-color: var(--muted);
}

.quote-followup-main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 170px;
  gap: 14px;
  align-items: start;
}

.quote-followup-money {
  display: grid;
  gap: 4px;
  justify-items: end;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: var(--soft);
}

.quote-followup-money span,
.quote-followup-money em {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.quote-followup-money strong {
  color: var(--navy);
  font-size: 24px;
  line-height: 1;
}

.quote-followup-money em {
  font-style: normal;
  text-align: right;
}

.quote-followup-checks {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.quote-followup-check {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: var(--soft);
}

.quote-followup-check.is-due {
  border-color: rgba(17, 199, 189, 0.52);
  background: rgba(17, 199, 189, 0.1);
}

.quote-followup-check.is-overdue {
  border-color: rgba(220, 38, 38, 0.45);
  background: rgba(220, 38, 38, 0.08);
}

.quote-followup-check.is-done {
  border-color: rgba(17, 199, 189, 0.4);
  background: rgba(17, 199, 189, 0.14);
}

.quote-followup-check span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.quote-followup-check strong {
  display: block;
  margin: 3px 0;
  color: var(--navy);
  font-size: 16px;
}

.quote-followup-check em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
}

.quote-followup-edit {
  display: grid;
  grid-template-columns: minmax(150px, 0.7fr) minmax(150px, 0.65fr) minmax(170px, 0.75fr) minmax(240px, 1.4fr);
  gap: 10px;
  align-items: start;
}

.quote-followup-notes textarea {
  min-height: 76px;
}

.quote-followup-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.crm-job-main {
  display: grid;
  grid-template-columns: 130px minmax(0, 1fr);
  gap: 14px;
}

.crm-job-time {
  display: grid;
  align-content: start;
  gap: 4px;
  border-right: 1px solid var(--line);
  padding-right: 12px;
}

.crm-job-time strong {
  color: var(--navy);
  font-size: 16px;
}

.crm-job-time span,
.crm-address {
  color: var(--muted);
  font-size: 13px;
}

.crm-job-info {
  min-width: 0;
  display: grid;
  gap: 6px;
}

.crm-title-row {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 10px;
}

.crm-title-row h3 {
  margin: 0;
  color: var(--navy);
  font-size: 20px;
  line-height: 1.15;
}

.crm-address,
.crm-job-info .muted {
  margin: 0;
}

.crm-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 6px 9px;
  color: #fff;
  background: var(--open);
  font-size: 10px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
}

.crm-status.complete,
.crm-status.invoiced,
.crm-status.paid,
.crm-status.approved,
.crm-status.converted,
.crm-status.won {
  color: #06343d;
  background: var(--teal);
}

.crm-status.partial {
  color: #3c2a00;
  background: #f0b429;
}

.crm-status.cancelled {
  background: var(--muted);
}

.crm-job-actions {
  justify-content: end;
  align-content: start;
  max-width: 360px;
}

.crm-detail-header .section-heading {
  align-items: center;
}

.crm-detail-actions {
  justify-content: flex-end;
}

.crm-detail-grid {
  grid-template-columns: minmax(0, 1fr);
}

.crm-textarea-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 12px;
  margin-top: 12px;
}

.crm-assignment-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 10px;
}

.crm-assignment {
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: #fff;
}

.crm-assignment input {
  width: 20px;
  height: 20px;
  accent-color: var(--danger);
}

.crm-assignment span {
  display: grid;
  gap: 2px;
}

.crm-assignment strong {
  color: var(--navy);
}

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

.crm-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 12px;
}

.crm-summary-grid .detail strong {
  overflow-wrap: anywhere;
}

.invoice-payment-panel {
  border-color: rgba(17, 199, 189, 0.32);
}

.invoice-payment-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}

.invoice-payment-summary > div {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: var(--soft);
}

.invoice-payment-summary span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.invoice-payment-summary strong {
  color: var(--navy);
  font-size: 22px;
  line-height: 1;
}

.invoice-payment-summary .is-due {
  border-color: rgba(229, 75, 75, 0.28);
  background: rgba(229, 75, 75, 0.07);
}

.invoice-payment-summary .is-clear {
  border-color: rgba(17, 199, 189, 0.36);
  background: rgba(17, 199, 189, 0.08);
}

.invoice-payment-link {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  border: 1px solid rgba(17, 199, 189, 0.28);
  border-radius: 8px;
  padding: 10px 12px;
  margin-bottom: 12px;
  background: rgba(17, 199, 189, 0.07);
}

.invoice-payment-link span {
  color: var(--navy);
  font-size: 13px;
  font-weight: 900;
}

.invoice-payment-link div {
  display: grid;
  gap: 3px;
}

.invoice-payment-link em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
  line-height: 1.3;
}

.invoice-payment-link.needs-setup {
  border-color: rgba(229, 75, 75, 0.24);
  background: rgba(229, 75, 75, 0.06);
}

.invoice-payment-form {
  display: grid;
  grid-template-columns: minmax(110px, 0.55fr) minmax(120px, 0.55fr) minmax(135px, 0.55fr) minmax(220px, 1fr) auto;
  gap: 10px;
  align-items: end;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: #fff;
}

.invoice-payment-form .button {
  min-height: 42px;
  white-space: nowrap;
}

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

.invoice-payment-row {
  display: grid;
  grid-template-columns: 110px 130px 110px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
  background: var(--soft);
}

.invoice-payment-row strong {
  color: var(--navy);
  font-size: 18px;
}

.invoice-payment-row span {
  color: var(--navy);
  font-size: 13px;
  font-weight: 900;
}

.invoice-payment-row em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  overflow-wrap: anywhere;
}

.crm-notes-panel {
  border-color: rgba(18, 64, 95, 0.14);
}

.crm-note-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(130px, 0.24fr) auto;
  gap: 10px;
  align-items: end;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: #fff;
}

.crm-note-form textarea {
  min-height: 64px;
}

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

.crm-note-row {
  display: grid;
  gap: 6px;
  border: 1px solid var(--line);
  border-left: 5px solid var(--teal);
  border-radius: 8px;
  padding: 10px 12px;
  background: var(--soft);
}

.crm-note-row.is-task {
  border-left-color: var(--warning);
}

.crm-note-row.is-issue {
  border-left-color: var(--open);
}

.crm-note-row.is-complete {
  border-left-color: #8a97a6;
  opacity: 0.76;
}

.crm-note-row > div {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
}

.crm-note-row strong {
  color: var(--navy);
  font-size: 13px;
}

.crm-note-row span,
.crm-note-row small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.crm-note-row p {
  margin: 0;
  color: var(--ink);
  line-height: 1.4;
}

.crm-note-row .button.compact {
  justify-self: start;
  min-height: 32px;
  padding: 7px 10px;
  font-size: 12px;
}

.payments-view .section-body {
  display: grid;
  gap: 14px;
}

.payments-toolbar {
  grid-template-columns: minmax(220px, 1fr) minmax(140px, 0.42fr) minmax(132px, 0.36fr) minmax(132px, 0.36fr) auto;
}

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

.payment-summary-card {
  display: grid;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
  background: #fff;
}

.payment-summary-card span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.payment-summary-card strong {
  color: var(--navy);
  font-size: 28px;
  line-height: 1;
}

.payment-summary-card em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  font-weight: 800;
}

.payment-summary-card.is-due {
  border-color: rgba(229, 75, 75, 0.26);
  background: rgba(229, 75, 75, 0.06);
}

.payment-summary-card.is-warning {
  border-color: rgba(245, 158, 11, 0.4);
  background: rgba(245, 158, 11, 0.1);
}

.payment-method-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.payment-method-strip span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 7px 10px;
  color: var(--navy);
  background: #fff;
  font-size: 12px;
  font-weight: 900;
}

.payment-method-strip strong {
  color: var(--muted);
  font-size: 10px;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.payment-collection-panel {
  display: grid;
  gap: 12px;
  border: 1px solid rgba(18, 64, 95, 0.16);
  border-radius: 8px;
  padding: 14px;
  background: #fff;
}

.payment-collection-panel.is-clear {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  border-color: rgba(17, 199, 189, 0.3);
  background: rgba(17, 199, 189, 0.06);
}

.payment-collection-panel h3 {
  margin: 3px 0;
  color: var(--navy);
  font-size: 22px;
  line-height: 1.1;
}

.payment-collection-panel p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.payment-collection-head {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  justify-content: space-between;
}

.payment-collection-list {
  display: grid;
  gap: 8px;
}

.payment-collection-card {
  display: grid;
  grid-template-columns: 146px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  border: 1px solid var(--line);
  border-left: 5px solid var(--teal);
  border-radius: 8px;
  padding: 11px 12px;
  background: var(--soft);
}

.payment-collection-card.overdue {
  border-left-color: var(--open);
  background: rgba(229, 75, 75, 0.06);
}

.payment-collection-card.due_today,
.payment-collection-card.due_soon {
  border-left-color: var(--warning);
}

.payment-collection-status {
  display: grid;
  gap: 7px;
}

.payment-collection-status strong {
  color: var(--navy);
  font-size: 22px;
  line-height: 1;
}

.payment-collection-main {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.payment-collection-main h4,
.payment-collection-main p {
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.payment-collection-main h4 {
  color: var(--navy);
  font-size: 16px;
}

.payment-collection-main p {
  color: var(--ink);
  font-size: 13px;
  font-weight: 800;
}

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

.payment-collection-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  justify-content: flex-end;
}

.payment-collection-actions .button {
  min-height: 36px;
  padding: 8px 11px;
  font-size: 12px;
}

.payment-list {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.payment-card {
  display: grid;
  grid-template-columns: 150px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  border: 1px solid var(--line);
  border-left: 6px solid var(--teal);
  border-radius: 8px;
  padding: 12px;
  background: #fff;
}

.payment-card.is-unapplied {
  border-left-color: #f0b429;
}

.payment-card-amount {
  display: grid;
  gap: 4px;
  border-right: 1px solid var(--line);
  padding-right: 12px;
}

.payment-card-amount strong {
  color: var(--navy);
  font-size: 24px;
  line-height: 1;
}

.payment-card-amount span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.payment-card-main {
  min-width: 0;
}

.payment-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: end;
}

@media (max-width: 760px) {
  .payment-card-amount {
    border-right: 0;
    border-bottom: 1px solid var(--line);
    padding-right: 0;
    padding-bottom: 10px;
  }

  .payment-card-actions {
    justify-content: stretch;
  }

  .payment-card-actions .button {
    flex: 1 1 120px;
  }
}

.pricing-view {
  display: grid;
  gap: 16px;
}

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

.pricing-sales-hero,
.pricing-setup-note {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  border: 1px solid rgba(17, 199, 189, 0.32);
  border-radius: 8px;
  padding: 16px;
  background: rgba(17, 199, 189, 0.08);
}

.pricing-customer-step {
  display: grid;
  gap: 12px;
  margin-bottom: 16px;
  border: 1px solid rgba(17, 199, 189, 0.32);
  border-radius: 8px;
  padding: 14px;
  background: #fff;
}

.pricing-step-heading {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}

.pricing-step-heading > span {
  display: inline-grid;
  place-items: center;
  min-width: 62px;
  border-radius: 999px;
  padding: 7px 10px;
  color: #fff;
  background: var(--navy);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.pricing-step-heading strong {
  color: var(--navy);
  font-size: 18px;
}

.pricing-step-heading p {
  margin: 2px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}

.pricing-followup-fields {
  margin: 0;
}

.pricing-sales-hero .eyebrow {
  color: var(--muted);
}

.pricing-sales-hero h3 {
  margin: 0 0 5px;
  color: var(--navy);
  font-size: 24px;
  line-height: 1.1;
}

.pricing-sales-hero p,
.pricing-setup-note span {
  margin: 0;
  color: var(--muted);
  line-height: 1.4;
}

.pricing-flow-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.pricing-flow-strip span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border: 1px solid rgba(17, 199, 189, 0.35);
  border-radius: 999px;
  padding: 6px 9px;
  color: var(--navy);
  background: #fff;
  font-size: 12px;
  font-weight: 900;
}

.pricing-flow-strip strong {
  display: inline-grid;
  place-items: center;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  color: #fff;
  background: var(--navy);
  font-size: 11px;
}

.pricing-hero-total {
  display: grid;
  gap: 5px;
  min-width: 190px;
  border-radius: 8px;
  padding: 14px;
  color: #fff;
  background: var(--navy);
  text-align: right;
}

.pricing-hero-total span {
  color: rgba(255, 255, 255, 0.72);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.pricing-hero-total strong {
  font-size: 30px;
  line-height: 1;
}

.pricing-setup-note {
  grid-template-columns: 210px minmax(0, 1fr);
  margin-bottom: 12px;
}

.pricing-setup-note strong {
  color: var(--navy);
  font-size: 17px;
}

.pricing-unsaved-banner {
  display: grid;
  gap: 4px;
  margin: 12px 0;
  border: 1px solid rgba(245, 158, 11, 0.5);
  border-radius: 8px;
  padding: 11px;
  color: var(--warning-ink);
  background: rgba(245, 158, 11, 0.12);
}

.pricing-unsaved-banner strong {
  font-size: 14px;
}

.pricing-unsaved-banner span {
  color: var(--warning-ink);
  font-size: 13px;
  line-height: 1.35;
}

.field.is-unsaved input,
.pricing-rate-row.is-unsaved input[type="number"] {
  border-color: rgba(245, 158, 11, 0.72);
  background: rgba(245, 158, 11, 0.1);
  box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.1);
}

.pricing-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 380px;
  gap: 16px;
  align-items: start;
}

.pricing-view,
.pricing-shell,
.pricing-calculator,
.pricing-service-grid,
.pricing-service-card,
.pricing-service-body,
.pricing-area-row,
.pricing-row,
.pricing-count-grid,
.pricing-window-main,
.pricing-option-stack,
.pricing-mini-card,
.pricing-addon-panel {
  min-width: 0;
  max-width: 100%;
}

.pricing-calculator .section-body {
  display: grid;
  gap: 12px;
}

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

.pricing-service-card {
  display: grid;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: #fff;
}

.pricing-service-card.is-disabled {
  background: var(--soft);
}

.pricing-service-card.is-disabled header {
  min-height: 82px;
}

.pricing-service-card:not(.is-disabled) {
  grid-column: 1 / -1;
  border-color: rgba(17, 199, 189, 0.45);
  box-shadow: 0 12px 26px rgba(5, 24, 44, 0.08);
}

.pricing-service-card.is-disabled .pricing-service-body,
.pricing-service-card.is-disabled footer {
  display: none;
}

.pricing-service-card.is-disabled h3 {
  color: var(--ink);
}

.pricing-service-card.is-disabled p {
  display: none;
}

.pricing-service-card header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  border-bottom: 1px solid var(--line);
  padding-bottom: 10px;
}

.pricing-service-card header {
  cursor: pointer;
}

.pricing-service-card.is-disabled header {
  border-bottom: 0;
  padding-bottom: 0;
}

.pricing-service-title {
  min-width: 0;
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}

.pricing-service-icon {
  position: relative;
  display: inline-grid;
  place-items: center;
  width: 52px;
  height: 52px;
  border-radius: 8px;
  color: #06343d;
  background: linear-gradient(145deg, rgba(17, 199, 189, 0.26), rgba(18, 168, 216, 0.16));
  font-size: 12px;
  font-weight: 900;
}

.pricing-service-icon svg {
  width: 28px;
  height: 28px;
  stroke-width: 2.4;
}

.pricing-service-card:not(.is-disabled) .pricing-service-icon {
  color: #fff;
  background: var(--navy);
}

.pricing-service-card h3 {
  margin: 0 0 3px;
  color: var(--navy);
  font-size: 18px;
  line-height: 1.15;
  overflow-wrap: normal;
}

.pricing-service-card small {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.25;
}

.pricing-service-card p {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}

.pricing-include {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border-radius: 999px;
  padding: 9px 12px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.18);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  white-space: nowrap;
}

.pricing-service-card:not(.is-disabled) .pricing-include {
  color: #fff;
  background: var(--danger);
}

.pricing-include input,
.pricing-active-check input,
.pricing-check-field input {
  width: 18px;
  height: 18px;
  accent-color: var(--danger);
}

.pricing-include input {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.pricing-include span::before {
  content: "+";
  margin-right: 6px;
  font-size: 15px;
  line-height: 1;
}

.pricing-service-card:not(.is-disabled) .pricing-include span::before {
  content: "";
  margin-right: 0;
}

.pricing-service-body {
  display: grid;
  gap: 10px;
}

.pricing-area-list {
  display: grid;
  gap: 10px;
}

.pricing-area-row {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: var(--soft);
}

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

.pricing-area-head strong {
  color: var(--navy);
  font-size: 14px;
}

.pricing-area-head .button {
  min-height: 32px;
  padding: 0 10px;
  font-size: 12px;
}

.pricing-add-row {
  justify-self: start;
}

.pricing-window-simple,
.pricing-window-main,
.pricing-option-stack {
  display: grid;
  gap: 12px;
}

.pricing-window-main {
  grid-template-columns: minmax(180px, 0.8fr) minmax(220px, 1fr);
  align-items: end;
}

.pricing-stepper-field {
  min-width: 0;
}

.pricing-stepper {
  width: 100%;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) 44px;
  overflow: hidden;
  border: 1.5px solid var(--line);
  border-radius: 7px;
  background: #fff;
}

.pricing-stepper button {
  display: inline-grid;
  place-items: center;
  min-height: 43px;
  border: 0;
  color: var(--navy);
  background: rgba(17, 199, 189, 0.16);
  font-size: 20px;
  font-weight: 900;
  cursor: pointer;
}

.pricing-stepper button:hover,
.pricing-stepper button:focus {
  background: rgba(17, 199, 189, 0.28);
}

.pricing-stepper input {
  width: 100%;
  min-width: 0;
  min-height: 43px;
  border: 0;
  border-left: 1px solid var(--line);
  border-right: 1px solid var(--line);
  padding: 0 10px;
  color: var(--navy);
  background: #fff;
  font-size: 18px;
  font-weight: 900;
  text-align: center;
}

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

.pricing-choice-card {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 43px;
  border: 1.5px solid var(--line);
  border-radius: 7px;
  padding: 8px 10px;
  color: var(--navy);
  background: #fff;
  font-size: 13px;
  font-weight: 900;
  cursor: pointer;
}

.pricing-choice-card:has(input:checked) {
  border-color: rgba(17, 199, 189, 0.58);
  color: #06343d;
  background: rgba(17, 199, 189, 0.18);
}

.pricing-choice-card input {
  width: 18px;
  height: 18px;
  accent-color: var(--danger);
}

.pricing-addon-panel {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

.pricing-addon-panel summary {
  min-height: 42px;
  display: flex;
  align-items: center;
  padding: 0 12px;
  color: var(--navy);
  cursor: pointer;
  font-size: 13px;
  font-weight: 900;
  list-style: none;
}

.pricing-addon-panel summary::-webkit-details-marker {
  display: none;
}

.pricing-addon-panel summary::after {
  content: "+";
  margin-left: auto;
  color: var(--muted);
  font-size: 18px;
}

.pricing-addon-panel[open] summary::after {
  content: "-";
}

.pricing-addon-panel .pricing-count-grid {
  border-top: 1px solid var(--line);
  padding: 10px;
  background: var(--soft);
}

.pricing-mini-card {
  display: grid;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: var(--soft);
}

.pricing-mini-card > strong {
  color: var(--navy);
  font-size: 14px;
}

.pricing-row,
.pricing-count-grid {
  display: grid;
  gap: 10px;
}

.pricing-row {
  grid-template-columns: repeat(auto-fit, minmax(min(160px, 100%), 1fr));
}

.pricing-count-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(170px, 100%), 1fr));
}

.pricing-check-field > label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 43px;
  border: 1.5px solid var(--line);
  border-radius: 6px;
  padding: 0 12px;
  color: var(--ink);
  background: var(--soft);
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: none;
}

.pricing-service-card footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  border-top: 1px solid var(--line);
  padding-top: 10px;
}

.pricing-service-card footer span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.pricing-service-card footer strong {
  color: var(--navy);
  font-size: 20px;
}

.pricing-summary-panel {
  position: sticky;
  top: 92px;
}

.pricing-total-stack {
  display: grid;
  gap: 8px;
}

.pricing-total-stack > div,
.pricing-line-summary > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: var(--soft);
}

.pricing-total-stack span,
.pricing-line-summary span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.pricing-total-stack strong,
.pricing-line-summary strong {
  color: var(--navy);
  white-space: nowrap;
}

.pricing-total-stack .is-final {
  border-color: rgba(17, 199, 189, 0.5);
  background: rgba(17, 199, 189, 0.14);
}

.pricing-total-stack .is-final strong {
  font-size: 26px;
}

.pricing-line-summary {
  display: grid;
  gap: 6px;
  margin: 12px 0;
}

.pricing-line-summary .needs-review {
  border-color: rgba(245, 158, 11, 0.5);
  background: rgba(245, 158, 11, 0.12);
}

.pricing-line-summary .needs-review strong {
  color: var(--warning-ink);
}

.pricing-minimum-alert,
.pricing-review-alert {
  display: grid;
  gap: 4px;
  margin-top: 10px;
  border-radius: 8px;
  padding: 11px;
}

.pricing-minimum-alert {
  border: 1px solid rgba(17, 199, 189, 0.42);
  color: #06343d;
  background: rgba(17, 199, 189, 0.13);
}

.pricing-review-alert {
  border: 1px solid rgba(245, 158, 11, 0.48);
  color: var(--warning-ink);
  background: rgba(245, 158, 11, 0.12);
}

.pricing-minimum-alert strong,
.pricing-review-alert strong {
  font-size: 14px;
}

.pricing-minimum-alert span,
.pricing-review-alert span {
  font-size: 13px;
  line-height: 1.35;
}

.pricing-minimum-alert span {
  color: #06343d;
}

.pricing-review-alert span {
  color: var(--warning-ink);
}

.pricing-summary-panel textarea {
  min-height: 160px;
}

.pricing-rate-groups {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.pricing-rate-group {
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
}

.pricing-rate-group summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 48px;
  padding: 0 12px;
  color: var(--navy);
  cursor: pointer;
  font-weight: 900;
  list-style: none;
}

.pricing-rate-group summary::-webkit-details-marker {
  display: none;
}

.pricing-rate-group summary span {
  color: var(--muted);
  font-size: 12px;
}

.pricing-rate-list {
  display: grid;
  gap: 1px;
  border-top: 1px solid var(--line);
  background: var(--line);
}

.pricing-rate-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 140px minmax(138px, auto);
  gap: 10px;
  align-items: center;
  padding: 9px 10px;
  background: #fff;
}

.pricing-rate-row.is-unsaved {
  background: #fffaf0;
  box-shadow: inset 4px 0 0 var(--warning);
}

.pricing-rate-row div {
  display: grid;
  gap: 3px;
}

.pricing-rate-row strong {
  color: var(--navy);
  line-height: 1.2;
}

.pricing-rate-row span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.pricing-rate-row input[type="number"] {
  width: 100%;
  border: 1.5px solid var(--line);
  border-radius: 6px;
  padding: 10px;
  color: var(--ink);
  background: var(--soft);
}

.pricing-active-check {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 6px 9px;
  color: var(--navy);
  background: var(--soft);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  cursor: pointer;
}

.pricing-active-check input {
  position: relative;
  flex: 0 0 34px;
  width: 34px;
  height: 20px;
  margin: 0;
  appearance: none;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #dbe7ef;
  cursor: pointer;
}

.pricing-active-check input::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(5, 24, 44, 0.25);
  transition: transform 0.16s ease;
}

.pricing-active-check input:checked {
  border-color: rgba(7, 149, 143, 0.45);
  background: var(--teal);
}

.pricing-active-check input:checked::after {
  transform: translateX(14px);
}

.pricing-active-check span {
  color: inherit;
  font-size: inherit;
  letter-spacing: 0;
  white-space: nowrap;
}

.button.is-unsaved {
  box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.24), 0 10px 20px rgba(5, 24, 44, 0.16);
}

.time-map-marker {
  position: relative;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border: 3px solid #fff;
  border-radius: 999px 999px 999px 5px;
  transform: rotate(-45deg);
  box-shadow: 0 6px 14px rgba(5, 24, 44, 0.35);
}

.time-map-marker span {
  color: #fff;
  font-size: 11px;
  font-weight: 900;
  transform: rotate(45deg);
}

.time-map-marker.is-in {
  background: var(--open);
}

.time-map-marker.is-out {
  background: var(--danger);
}

.schedule-map-canvas > .muted {
  display: grid;
  min-height: 320px;
  place-items: center;
  margin: 0;
  padding: 18px;
  text-align: center;
}

.schedule-map-jobs {
  max-height: 620px;
  display: grid;
  align-content: start;
  gap: 8px;
  overflow: auto;
}

.schedule-map-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  position: sticky;
  top: 0;
  z-index: 1;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px;
  background: #fff;
}

.schedule-map-legend span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.legend-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
}

.legend-dot.is-open {
  background: var(--open);
}

.legend-dot.is-complete {
  background: var(--success);
}

.legend-dot.is-unscheduled {
  background: var(--warning);
}

.map-job-section {
  display: grid;
  gap: 8px;
}

.map-job-section + .map-job-section {
  margin-top: 6px;
}

.map-job-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border-bottom: 1px solid var(--line);
  padding: 8px 2px 6px;
}

.map-job-section-head strong {
  color: var(--navy);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.map-job-section-head span {
  min-width: 24px;
  border-radius: 999px;
  padding: 4px 7px;
  color: var(--navy);
  background: var(--soft);
  font-size: 11px;
  font-weight: 900;
  text-align: center;
}

.map-job-card {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr) minmax(86px, auto);
  gap: 9px;
  align-items: center;
  border: 1px solid var(--line);
  border-left: 5px solid var(--open);
  border-radius: 8px;
  padding: 9px;
  background: #fff;
}

.map-job-card.is-complete {
  border-left-color: var(--success);
  background: rgba(17, 199, 189, 0.08);
}

.map-job-card.is-unscheduled {
  border-left-color: var(--warning);
  background: #fff8ec;
}

.map-job-card.is-submitted {
  border-color: rgba(7, 149, 143, 0.34);
  background: rgba(17, 199, 189, 0.06);
}

.map-job-pin {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  color: #06343d;
  background: var(--teal);
  font-size: 12px;
  font-weight: 900;
}

.map-job-pin.is-open {
  color: #fff;
  background: var(--open);
}

.map-job-pin.is-complete {
  color: #fff;
  background: var(--success);
}

.map-job-pin.is-unscheduled {
  color: var(--warning-ink);
  background: var(--warning);
}

.map-job-card strong {
  display: block;
  color: var(--navy);
  font-size: 13px;
  line-height: 1.2;
}

.map-job-card em {
  display: inline-flex;
  margin: 3px 0;
  border-radius: 999px;
  padding: 3px 7px;
  color: #fff;
  background: var(--open);
  font-size: 9px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.map-job-card.is-complete em,
.map-job-card.is-submitted em {
  color: #06343d;
  background: var(--teal);
}

.map-job-card.is-unscheduled em {
  color: var(--warning-ink);
  background: rgba(245, 158, 11, 0.24);
}

.map-job-card span,
.map-job-card small {
  display: block;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.25;
}

.map-job-card small {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.map-job-actions {
  display: grid;
  gap: 6px;
}

.map-job-card .button {
  min-height: 34px;
  padding: 0 9px;
  font-size: 12px;
}

.map-popup {
  display: grid;
  gap: 6px;
  min-width: 180px;
}

.map-popup strong {
  color: var(--navy);
  font-size: 14px;
  line-height: 1.2;
}

.map-popup span,
.map-popup small {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.25;
}

.map-popup em {
  justify-self: start;
  border-radius: 999px;
  padding: 3px 7px;
  color: var(--warning-ink);
  background: rgba(245, 158, 11, 0.24);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.map-popup a,
.map-popup button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  border: 0;
  border-radius: 6px;
  padding: 0 10px;
  color: #fff;
  background: var(--danger);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  cursor: pointer;
}

.map-popup button {
  color: var(--navy);
  background: var(--soft);
  border: 1px solid var(--line);
}

.job-map-marker {
  position: relative;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 3px solid #fff;
  border-radius: 999px 999px 999px 4px;
  transform: rotate(-45deg);
  box-shadow: 0 6px 14px rgba(5, 24, 44, 0.35);
}

.job-map-marker span {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  color: #fff;
  font-size: 13px;
  font-weight: 900;
  transform: rotate(45deg);
}

.job-map-marker.is-open {
  background: var(--open);
}

.job-map-marker.is-complete {
  background: var(--success);
}

.job-map-marker.is-unscheduled {
  background: var(--warning);
}

.job-map-marker.is-unscheduled span {
  color: var(--warning-ink);
}

.schedule-card {
  display: grid;
  gap: 12px;
  border: 1px solid var(--line);
  border-left: 6px solid var(--open);
  border-radius: 8px;
  padding: 14px;
  background: #fff;
}

.schedule-card.is-complete {
  border-left-color: var(--success);
  background: rgba(17, 199, 189, 0.07);
}

.schedule-card.is-submitted {
  border-color: rgba(7, 149, 143, 0.34);
  background: rgba(17, 199, 189, 0.06);
}

.schedule-card-main {
  display: grid;
  grid-template-columns: 118px minmax(0, 1fr);
  gap: 14px;
}

.schedule-time {
  display: grid;
  align-content: start;
  gap: 4px;
  border-right: 1px solid var(--line);
  padding-right: 12px;
}

.schedule-time strong {
  color: var(--navy);
  font-size: 15px;
  line-height: 1.2;
}

.schedule-time span,
.schedule-info p {
  color: var(--muted);
  line-height: 1.35;
}

.schedule-info {
  min-width: 0;
}

.schedule-title-row {
  display: flex;
  gap: 10px;
  align-items: start;
  justify-content: space-between;
}

.schedule-title-row h3 {
  margin: 0 0 4px;
  color: var(--navy);
  font-size: 20px;
  line-height: 1.22;
}

.schedule-info p {
  margin: 0 0 7px;
}

.schedule-address {
  margin: 0 0 7px;
  color: var(--ink);
  font-size: 15px;
  font-weight: 800;
  line-height: 1.3;
}

.schedule-job-label {
  font-size: 13px;
}

.service-tags.compact {
  margin: 8px 0;
}

.service-tags.compact span {
  padding: 5px 8px;
  font-size: 11px;
}

.schedule-actions {
  display: grid;
  grid-template-columns: minmax(210px, 0.9fr) minmax(180px, 1.1fr) minmax(140px, 0.8fr);
  gap: 8px;
  align-items: stretch;
}

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

.schedule-secondary-actions {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.schedule-actions .button {
  width: 100%;
  min-height: 38px;
  padding: 0 8px;
  font-size: 13px;
}

.schedule-start-action {
  font-size: 14px;
}

.check {
  width: 24px;
  height: 24px;
  margin: 0;
  border: 2.5px solid var(--navy);
  border-radius: 4px;
  appearance: none;
  background: #fff;
  cursor: pointer;
}

.check:checked {
  background: var(--teal);
  border-color: var(--success);
}

.check:checked::after {
  content: "✓";
  display: grid;
  place-items: center;
  color: #06343d;
  font-size: 18px;
  font-weight: 900;
}

.photo-drop,
.media-drop {
  border: 1.5px dashed #aac2d4;
  border-radius: 8px;
  padding: 16px;
  background: var(--soft);
}

.photo-drop input,
.media-drop input {
  display: block;
  margin-top: 10px;
  width: 100%;
  max-width: 100%;
}

.photo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(96px, 1fr));
  gap: 10px;
  margin-top: 12px;
}

.photo-thumb {
  position: relative;
  margin: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

.media-delete {
  position: absolute;
  top: 6px;
  right: 6px;
  z-index: 2;
  min-height: 28px;
  border: 0;
  border-radius: 999px;
  padding: 0 9px;
  color: #fff;
  background: rgba(8, 40, 61, 0.86);
  font-size: 11px;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.24);
}

.media-delete:hover {
  background: var(--danger);
}

.photo-thumb img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  display: block;
}

.photo-thumb video,
.video-placeholder {
  width: 100%;
  aspect-ratio: 1;
  display: block;
  background: #081f33;
}

.photo-thumb video {
  object-fit: cover;
}

.video-placeholder {
  display: grid;
  place-items: center;
  padding: 8px;
  color: #fff;
  font-size: 11px;
  font-weight: 900;
  text-align: center;
}

.photo-thumb figcaption {
  overflow: hidden;
  padding: 6px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.media-upload-list {
  display: grid;
  gap: 12px;
  margin-top: 12px;
}

.media-upload {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: #fff;
}

.media-upload strong {
  color: var(--navy);
}

.media-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 10px;
}

.media-actions .button {
  width: 100%;
  min-height: 38px;
  padding: 0 10px;
  font-size: 13px;
}

.native-media-input {
  position: absolute;
  width: 1px !important;
  height: 1px;
  margin: 0;
  opacity: 0;
  pointer-events: none;
}

.media-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  min-height: 22px;
  margin-left: 5px;
  border-radius: 999px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.24);
  font-size: 11px;
  font-weight: 900;
}

.media-upload p {
  margin: 4px 0 0;
  font-size: 13px;
  overflow-wrap: anywhere;
}

.media-grid:empty {
  display: none;
}

.media-status {
  min-height: 22px;
  margin: 0;
  color: var(--success);
  font-size: 13px;
  font-weight: 900;
  line-height: 1.35;
}

.camera-status {
  flex: 1 1 auto;
  align-self: center;
}

.batch-camera-view {
  margin: 14px 16px 0;
  overflow: hidden;
  border-radius: 8px;
  background: #081f33;
}

.batch-camera-view video {
  width: 100%;
  aspect-ratio: 4 / 5;
  display: block;
  object-fit: cover;
}

.batch-camera-view.layout-horizontal-split video {
  aspect-ratio: 8 / 5;
}

.batch-camera-strip {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
  padding: 12px 16px 0;
}

.batch-camera-strip:empty {
  display: none;
}

.batch-camera-strip img {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 6px;
  object-fit: cover;
}

.media-camera-button {
  width: 100%;
  margin-top: 10px;
}

.camera-overlay {
  position: fixed;
  inset: 0;
  z-index: 20;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(5, 24, 44, 0.78);
}

.camera-modal {
  width: min(1080px, 100%);
  max-height: min(92vh, 900px);
  overflow: auto;
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}

.batch-camera-modal {
  width: min(820px, 100%);
}

.camera-head,
.camera-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
}

.camera-head {
  color: #fff;
  background: var(--navy);
}

.camera-head h2 {
  margin: 0;
}

.camera-toolbar {
  padding: 14px 16px 0;
}

.angle-step {
  margin: 10px 0 0;
  border-radius: 999px;
  padding: 7px 10px;
  color: #06343d;
  background: rgba(17, 199, 189, 0.2);
  font-size: 12px;
  font-weight: 900;
}

.layout-picker-wrap {
  display: grid;
  gap: 7px;
  padding: 12px 16px 0;
}

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

.layout-option {
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--navy);
  background: #fff;
  font-weight: 900;
  cursor: pointer;
}

.layout-option.is-active {
  border-color: rgba(7, 149, 143, 0.72);
  color: #06343d;
  background: var(--teal);
}

.layout-help {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.angle-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  padding: 14px 16px;
}

.angle-grid.layout-horizontal-split {
  grid-template-columns: minmax(0, 1fr);
  max-width: 780px;
  margin: 0 auto;
}

.angle-grid.single {
  grid-template-columns: minmax(0, 1fr) minmax(220px, 0.7fr);
}

.angle-grid.single.layout-horizontal-split {
  grid-template-columns: minmax(0, 1fr);
}

.angle-grid figure {
  margin: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--soft);
}

.angle-grid figcaption {
  padding: 9px 10px;
  color: var(--navy);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.angle-grid img,
.angle-grid video {
  width: 100%;
  aspect-ratio: 4 / 5;
  display: block;
  object-fit: cover;
  background: #081f33;
}

.angle-grid.layout-horizontal-split img,
.angle-grid.layout-horizontal-split video {
  aspect-ratio: 8 / 5;
}

.angle-frame {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  width: calc(100% - 32px);
  max-width: 960px;
  aspect-ratio: 8 / 5;
  margin: 14px auto;
  overflow: hidden;
  border: 10px solid #fff;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 16px 42px rgba(5, 24, 44, 0.22);
}

.angle-frame.layout-horizontal-split {
  grid-template-columns: 1fr;
  grid-template-rows: repeat(2, minmax(0, 1fr));
  max-width: 640px;
  aspect-ratio: 4 / 5;
}

.angle-frame::after {
  content: "";
  position: absolute;
  z-index: 3;
  background: #11c7bd;
  pointer-events: none;
}

.angle-frame.layout-vertical-split::after {
  top: 0;
  bottom: 0;
  left: calc(50% - 1px);
  width: 2px;
}

.angle-frame.layout-horizontal-split::after {
  top: calc(50% - 1px);
  left: 0;
  right: 0;
  height: 2px;
}

.angle-panel {
  position: relative;
  min-width: 0;
  min-height: 0;
  margin: 0;
  overflow: hidden;
  background: #081f33;
}

.angle-panel img,
.angle-panel video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.angle-panel figcaption,
.angle-panel-label {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  border-radius: 999px;
  padding: 5px 8px;
  color: #fff;
  background: rgba(8, 40, 61, 0.78);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.angle-frame-logo {
  position: absolute;
  z-index: 4;
  top: 12px;
  left: 50%;
  width: min(210px, 28%);
  height: auto;
  transform: translateX(-50%);
  filter: drop-shadow(0 6px 10px rgba(0, 0, 0, 0.36));
  pointer-events: none;
}

.angle-frame.native .native-camera-card {
  justify-items: center;
  align-content: center;
  border: 0;
  border-radius: 0;
  padding: 22px;
  text-align: center;
  background: #eef5f8;
}

.camera-actions {
  border-top: 1px solid var(--line);
}

.native-camera-card {
  display: grid;
  gap: 12px;
  align-content: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  background: var(--soft);
}

.native-camera-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.4;
}

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

.sop-form aside .actions .button {
  flex: 1 1 132px;
}

.button {
  min-height: 44px;
  border: 0;
  border-radius: 6px;
  padding: 0 15px;
  color: #fff;
  background: var(--navy);
  font-weight: 900;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.button.primary {
  background: var(--danger);
}

.button.secondary {
  color: var(--navy);
  background: var(--soft);
  border: 1.5px solid var(--line);
}

.button:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}

.progress {
  display: grid;
  gap: 8px;
}

.progress-bar {
  height: 12px;
  overflow: hidden;
  border-radius: 999px;
  background: #dfeaf2;
}

.progress-bar span {
  display: block;
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--teal), var(--blue));
}

.review-list {
  display: grid;
  gap: 12px;
}

.log-card {
  padding: 16px;
}

.log-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.log-head h3 {
  margin: 0;
  color: var(--navy);
}

.log-details {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 12px 0;
}

.detail {
  border-radius: 6px;
  padding: 8px;
  background: var(--soft);
}

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

.detail strong {
  display: block;
  margin-top: 3px;
  overflow-wrap: anywhere;
}

.checked-summary {
  margin: 0;
  padding-left: 20px;
  color: var(--muted);
  line-height: 1.45;
}

.empty-state {
  padding: 28px;
  text-align: center;
}

.toast {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 50;
  max-width: 360px;
  border-radius: 8px;
  padding: 14px 16px;
  color: #fff;
  background: var(--deep);
  box-shadow: var(--shadow);
  font-weight: 800;
}

.hidden {
  display: none !important;
}

@media (max-width: 940px) {
  .app-shell {
    grid-template-columns: 1fr;
  }

  body.nav-open::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 6;
    background: rgba(5, 24, 44, 0.42);
    backdrop-filter: blur(2px);
  }

  .sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 7;
    width: min(302px, calc(100vw - 48px));
    padding-left: max(18px, calc(var(--safe-left) + 14px));
    transform: translateX(-105%);
    transition: transform 0.18s ease;
  }

  body.nav-open .sidebar {
    transform: translateX(0);
  }

  .menu-button {
    display: inline-grid;
    place-items: center;
  }

  .topbar {
    align-items: center;
  }

  #app {
    padding-bottom: calc(92px + var(--safe-bottom));
  }

  .mobile-tabbar {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 5;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 4px;
    padding: 7px max(8px, var(--safe-right)) calc(7px + var(--safe-bottom)) max(8px, var(--safe-left));
    background: rgba(255, 255, 255, 0.96);
    border-top: 1px solid rgba(8, 40, 61, 0.14);
    box-shadow: 0 -14px 36px rgba(5, 24, 44, 0.16);
    backdrop-filter: blur(14px);
  }

  .mobile-tabbar a,
  .mobile-tabbar button {
    display: grid;
    justify-items: center;
    align-content: center;
    gap: 3px;
    min-width: 0;
    min-height: 54px;
    border: 0;
    border-radius: 8px;
    padding: 5px 3px;
    color: #486476;
    background: transparent;
    font-size: 10px;
    font-weight: 900;
    line-height: 1.1;
    text-decoration: none;
    text-transform: uppercase;
  }

  .mobile-tabbar svg {
    width: 20px;
    height: 20px;
  }

  .mobile-tabbar a.active,
  .mobile-tabbar button:active,
  .mobile-tabbar button[aria-expanded="true"] {
    color: #06343d;
    background: rgba(17, 199, 189, 0.18);
  }

  .hero,
  .ops-hero,
  .ops-layout,
  .grid.two,
  .grid.three,
  .form-grid,
  .log-details,
  .time-clock-grid,
  .report-toolbar,
  .revenue-report-grid,
  .revenue-owner-signals,
  .jobber-overview-grid,
  .jobber-insight-grid.two,
  .jobber-insight-grid.three,
  .jobber-insight-grid.four,
  .jobber-revenue-map-shell,
  .jobber-detail-stats,
  .jobber-aging-grid,
  .report-stats,
  .crm-toolbar,
  .crm-job-card,
  .crm-job-main,
  .crm-client-main,
  .client-profile-hero,
  .client-profile-grid,
  .quote-client-picker,
  .pricing-client-search,
  .pricing-step-heading,
  .quote-followup-fields,
  .quote-followup-stats,
  .quote-followup-main,
  .quote-followup-checks,
  .quote-followup-edit,
  .quote-public-header,
  .quote-document-top,
  .quote-builder-head,
  .quote-tax-controls,
  .pricing-settings-grid,
  .pricing-shell,
  .pricing-sales-hero,
  .pricing-setup-note,
  .pricing-service-grid,
  .pricing-row,
  .invoice-payment-summary,
  .invoice-payment-link,
  .invoice-payment-form,
  .invoice-payment-row,
  .payment-setup-grid,
  .cloud-copy-row,
  .crm-note-form,
  .payment-summary-grid,
  .payment-collection-panel.is-clear,
  .payment-collection-card,
  .payment-card,
  .payments-toolbar,
  .import-detail-layout,
  .crm-textarea-grid,
  .crm-summary-grid,
  .dashboard-job-row,
  .schedule-card-main,
  .schedule-actions {
    grid-template-columns: 1fr;
  }

  .guide-stepper {
    grid-template-columns: repeat(5, minmax(128px, 1fr));
    overflow-x: auto;
    padding-bottom: 4px;
  }

  .schedule-time,
  .crm-job-time,
  .dashboard-job-time {
    border-right: 0;
    border-bottom: 1px solid var(--line);
    padding: 0 0 10px;
  }

  .ops-focus-grid,
  .ops-stats,
  .workflow-stage-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dashboard-stat-grid.compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .raw-type-grid,
  .verification-counts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .schedule-week-board {
    display: none;
  }

  .schedule-month-calendar {
    display: none;
  }

  .schedule-mobile-summary {
    display: grid;
  }

  .schedule-map-layout {
    grid-template-columns: 1fr;
  }

  .schedule-map-jobs {
    order: 2;
    max-height: none;
  }

  .schedule-map-canvas {
    order: 1;
    min-height: min(64vh, 560px);
  }

  .invoice-payment-link {
    flex-direction: column;
    align-items: stretch;
  }

  .payment-setup-head {
    flex-direction: column;
  }

  .payment-collection-head {
    flex-direction: column;
  }

  .payment-collection-actions {
    justify-content: stretch;
  }

  .payment-collection-actions .button {
    flex: 1 1 118px;
  }

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

  .revenue-signal-grid,
  .revenue-small-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .jobber-overview-metric {
    border-left: 0;
    border-top: 1px solid #d7dde2;
    padding: 12px 0 0;
  }

  .jobber-overview-metric:first-child {
    border-top: 0;
  }

  .jobber-card-head {
    display: grid;
  }

  .jobber-card-actions {
    justify-content: stretch;
    min-width: 0;
    width: 100%;
  }

  .jobber-range-control {
    justify-items: stretch;
    width: 100%;
  }

  .jobber-range-control label span {
    text-align: left;
  }

  .jobber-custom-range {
    grid-template-columns: 1fr;
  }

  .jobber-lead-card .jobber-donut-wrap {
    grid-template-columns: 1fr;
    min-height: 260px;
  }

  .jobber-revenue-chart {
    grid-template-columns: 40px minmax(620px, 1fr);
  }

  .jobber-month-chart {
    min-width: 620px;
  }

  .map-job-card {
    grid-template-columns: 30px minmax(0, 1fr);
  }

  .map-job-actions {
    grid-column: 1 / -1;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .schedule-contact-actions,
  .schedule-secondary-actions,
  .crm-job-actions,
  .crm-detail-actions,
  .client-profile-actions,
  .dashboard-job-actions {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .crm-job-actions,
  .crm-detail-actions,
  .client-profile-actions,
  .dashboard-job-actions {
    display: grid;
    max-width: none;
    justify-content: stretch;
  }

  .crm-client-row {
    grid-template-columns: 1fr;
  }

  .client-row-counts {
    justify-content: flex-start;
    max-width: none;
  }

  .client-row-actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    justify-content: stretch;
  }

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

  .hero img {
    max-width: 260px;
  }

  .pricing-summary-panel {
    position: static;
  }

  .pricing-hero-total {
    min-width: 0;
    text-align: left;
  }

  .quote-public-actions,
  .quote-public-footer,
  .quote-builder-actions,
  .quote-followup-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .quote-public-actions .button,
  .quote-public-footer .button,
  .quote-followup-actions .button {
    width: 100%;
  }

  .quote-public-card {
    padding: 24px;
  }

  .quote-number-panel {
    justify-self: stretch;
  }

  .quote-product-table {
    overflow-x: auto;
  }

  .quote-line-editor {
    overflow-x: visible;
  }

  .quote-line-head {
    display: none;
  }

  .quote-line-row {
    grid-template-columns: 1fr;
    min-width: 0;
  }

  .quote-line-row strong {
    justify-self: start;
    text-align: left;
  }

  .quote-line-taxable {
    grid-column: auto;
  }

  .quote-line-row .icon-button {
    justify-self: start;
  }

  .quote-product-head,
  .quote-product-row {
    min-width: 820px;
  }
}

@media print {
  body {
    background: #fff !important;
  }

  .sidebar,
  .topbar,
  .mobile-tabbar,
  .quote-public-actions,
  .quote-public-footer {
    display: none !important;
  }

  .app-shell,
  .workspace,
  #app {
    display: block !important;
    width: auto !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: #fff !important;
  }

  .quote-public-shell {
    max-width: none;
  }

  .quote-public-card {
    min-height: 0;
    border: 0;
    box-shadow: none;
    padding: 0;
  }
}

@media (max-width: 1500px) {
  .pricing-shell {
    grid-template-columns: 1fr;
  }

  .pricing-summary-panel {
    position: static;
  }
}

@media (max-width: 620px) {
  body {
    overflow-x: hidden;
  }

  .workspace,
  .topbar,
  #app {
    max-width: 100vw;
  }

  .workspace {
    overflow-x: hidden;
  }

  #app {
    padding: 12px max(12px, var(--safe-right)) calc(92px + var(--safe-bottom)) max(12px, var(--safe-left));
  }

  .topbar {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 10px;
    justify-content: flex-start;
    padding: max(14px, calc(var(--safe-top) + 8px)) max(12px, var(--safe-right)) 12px max(12px, var(--safe-left));
  }

  .topbar > div:not(.topbar-actions) {
    min-width: 0;
  }

  .status-pill:not(.clock-status-pill) {
    display: none;
  }

  .topbar-actions {
    grid-column: 1 / -1;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-left: 0;
    gap: 6px;
  }

  .topbar-actions > *,
  .create-menu-wrap {
    min-width: 0;
  }

  .global-search {
    grid-column: 1 / -1;
    order: 3;
    max-width: none;
    min-width: 0;
    width: 100%;
  }

  .global-search input,
  .field input,
  .field textarea,
  .field select,
  .login-form input,
  .quote-line-row input,
  .quote-line-row textarea,
  .quote-line-row select,
  .jobber-range-control select,
  .jobber-range-control input {
    font-size: 16px;
  }

  .topbar-actions {
    order: 4;
  }

  .create-button {
    width: 100%;
    justify-content: center;
    min-height: 34px;
    padding: 6px 9px;
    font-size: 11px;
  }

  .create-button-icon {
    width: 16px;
    height: 16px;
    font-size: 14px;
  }

  .create-button-icon svg {
    width: 13px;
    height: 13px;
  }

  .jobsite-guide .section-heading {
    display: grid;
    gap: 10px;
  }

  .jobsite-sop-form .hero {
    padding: 16px;
  }

  .jobsite-sop-form .hero h2 {
    font-size: 25px;
  }

  .jobsite-sop-form .hero img {
    width: 108px;
  }

  .guide-stepper {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 6px;
    overflow: visible;
    padding: 0;
    scroll-snap-type: none;
  }

  .guide-step-button {
    min-width: 0;
    grid-template-columns: 1fr;
    justify-items: center;
    padding: 8px 4px;
    text-align: center;
    scroll-snap-align: unset;
  }

  .guide-step-button strong,
  .guide-step-button em {
    display: none;
  }

  .guide-step-button span {
    width: 28px;
    height: 28px;
  }

  .guided-phase-head {
    grid-template-columns: 1fr;
  }

  .guided-phase-head strong {
    justify-self: start;
  }

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

  .create-menu {
    left: 0;
    right: auto;
    width: min(300px, calc(100vw - 24px));
  }

  .create-menu-item {
    grid-template-columns: 34px minmax(0, 1fr) auto;
    padding: 9px;
  }

  .create-icon {
    width: 31px;
    height: 31px;
  }

  .clock-status-pill {
    width: 100%;
    min-width: 0;
    min-height: 34px;
    padding: 5px 6px;
    font-size: 9px;
  }

  .logout-button {
    width: 100%;
    min-width: 0;
    padding: 5px 6px;
    font-size: 10px;
  }

  #page-title {
    font-size: 22px;
  }

  .hero {
    padding: 22px;
  }

  .hero h2 {
    font-size: 34px;
  }

  .ops-hero {
    padding: 16px;
  }

  .ops-hero h2 {
    font-size: 28px;
  }

  .login-panel {
    width: 100%;
    max-width: calc(100vw - 24px);
    padding: 20px;
  }

  .password-input-row {
    gap: 6px;
  }

  .password-input-row input {
    width: 0;
  }

  .password-toggle {
    flex-basis: 54px;
    min-width: 0;
    padding: 0 6px;
    font-size: 12px;
  }

  .ops-actions {
    grid-template-columns: 1fr 1fr;
  }

  .ops-stats {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .import-counts {
    grid-template-columns: 1fr 1fr;
  }

  .import-live-status,
  .import-mini-row {
    align-items: flex-start;
    grid-template-columns: 1fr;
    flex-direction: column;
  }

  .raw-type-grid,
  .verification-counts {
    grid-template-columns: 1fr 1fr;
  }

  .ops-stat {
    min-height: 98px;
    padding: 11px;
  }

  .ops-stat strong {
    font-size: 25px;
  }

  .workflow-head {
    align-items: stretch;
    flex-direction: column;
  }

  .workflow-stage-grid {
    grid-template-columns: 1fr;
  }

  .attention-item {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .attention-item > span {
    width: fit-content;
  }

  .attention-actions {
    justify-content: stretch;
  }

  .attention-actions .button {
    flex: 1 1 0;
  }

  .dashboard-job-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .section-heading .actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    width: 100%;
  }

  .section-heading .actions .button {
    min-height: 36px;
    padding: 0 12px;
    font-size: 13px;
  }

  .section-body {
    padding: 14px;
  }

  .time-clock-actions {
    grid-template-columns: 1fr;
  }

  .schedule-view {
    width: 100%;
    max-width: calc(100vw - 24px);
    overflow: hidden;
  }

  .schedule-view * {
    min-width: 0;
  }

  .schedule-toolbar,
  .schedule-display-toggle {
    display: flex;
    width: 100%;
    max-width: calc(100vw - 56px);
    gap: 6px;
  }

  .schedule-range,
  .schedule-display {
    flex: 1 1 0;
    max-width: 100%;
    overflow: hidden;
    min-height: 40px;
    padding: 0 6px;
    font-size: 14px;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .mobile-week-strip,
  .mobile-month-grid {
    max-width: calc(100vw - 56px);
    gap: 4px;
  }

  .mobile-week-strip {
    display: flex;
  }

  .mobile-day-chip {
    flex: 1 1 0;
    padding: 6px 2px;
  }

  .mobile-day-chip strong,
  .mobile-month-cell strong {
    font-size: 11px;
  }

  .mobile-day-chip span {
    font-size: 9px;
  }

  .schedule-nav {
    grid-template-columns: 40px minmax(0, 1fr) 40px;
    max-width: calc(100vw - 56px);
    gap: 6px;
  }

  .schedule-arrow,
  .schedule-current {
    min-height: 42px;
  }

  .schedule-current {
    padding: 0 8px;
    font-size: 15px;
  }

  .schedule-card {
    padding: 12px;
  }

  .schedule-map-canvas {
    min-height: 430px;
    max-height: 62vh;
  }

  .report-map-canvas {
    min-height: 380px;
    max-height: 62vh;
  }

  .jobber-revenue-map-canvas {
    min-height: 380px;
    max-height: 62vh;
  }

  .jobber-revenue-map-panel {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .revenue-map-legend,
  .revenue-map-areas {
    grid-column: 1 / -1;
  }

  .report-toolbar,
  .revenue-report-panel,
  .revenue-chart-card,
  .revenue-table-wrap,
  .revenue-open-wrap {
    min-width: 0;
    max-width: 100%;
  }

  .revenue-year-controls {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .revenue-kpis {
    gap: 8px;
  }

  .revenue-kpi {
    padding: 11px;
  }

  .revenue-kpi strong {
    font-size: 22px;
  }

  .revenue-chart-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .revenue-legend {
    justify-content: start;
  }

  .revenue-table-wrap {
    overflow-x: auto;
  }

  .revenue-table {
    min-width: 860px;
  }

  .revenue-chart-scroll {
    grid-template-columns: 46px minmax(740px, 1fr);
  }

  .revenue-signal-grid,
  .revenue-small-metrics {
    grid-template-columns: 1fr;
  }

  .revenue-small-metrics span {
    align-items: center;
  }

  .report-time-head,
  .time-entry-row {
    align-items: flex-start;
    flex-direction: column;
  }

  .schedule-map-jobs {
    padding-bottom: 8px;
  }

  .schedule-contact-actions,
  .schedule-secondary-actions,
  .map-job-actions,
  .crm-job-actions,
  .crm-detail-actions,
  .client-row-actions,
  .client-profile-actions,
  .crm-toolbar-actions {
    grid-template-columns: repeat(auto-fit, minmax(86px, 1fr));
  }

  .crm-title-row,
  .crm-results-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .crm-toolbar-actions {
    display: grid;
  }

  .crm-client-main {
    grid-template-columns: 42px minmax(0, 1fr);
  }

  .client-avatar {
    width: 42px;
    height: 42px;
    font-size: 14px;
  }

  .client-row-counts {
    grid-column: 1 / -1;
  }

  .client-row-counts span {
    flex: 1 1 calc(50% - 6px);
    justify-content: center;
  }

  .client-profile-hero {
    padding: 14px;
  }

  .client-profile-title {
    grid-template-columns: 50px minmax(0, 1fr);
    gap: 10px;
  }

  .client-avatar.large {
    width: 50px;
    height: 50px;
    font-size: 18px;
  }

  .client-profile-title h2 {
    font-size: 24px;
  }

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

  .client-stat {
    padding: 10px;
  }

  .client-stat strong {
    font-size: 22px;
  }

  .client-action-grid,
  .client-property-card,
  .quote-client-picker,
  .pricing-client-search,
  .pricing-client-results,
  .pricing-window-main,
  .pricing-row,
  .pricing-count-grid,
  .pricing-rate-row,
  .client-activity-row {
    grid-template-columns: 1fr;
  }

  .pricing-view,
  .pricing-shell,
  .pricing-calculator,
  .pricing-service-grid,
  .pricing-service-card,
  .pricing-service-body {
    width: 100%;
    max-width: 100%;
    overflow: hidden;
  }

  .pricing-service-card header,
  .pricing-total-stack > div,
  .pricing-line-summary > div {
    align-items: flex-start;
    flex-direction: column;
  }

  .pricing-service-card header {
    grid-template-columns: 1fr;
  }

  .pricing-service-title {
    grid-template-columns: 42px minmax(0, 1fr);
  }

  .pricing-service-icon {
    width: 42px;
    height: 42px;
  }

  .pricing-service-icon svg {
    width: 24px;
    height: 24px;
  }

  .pricing-include {
    justify-self: start;
  }

  .pricing-stepper {
    grid-template-columns: 40px minmax(0, 1fr) 40px;
  }

  .pricing-rate-row {
    align-items: stretch;
  }

  .pricing-active-check {
    justify-content: flex-start;
  }

  .quote-public-card {
    padding: 14px;
  }

  .quote-public-header h2 {
    font-size: 25px;
  }

  .quote-number-panel h3 {
    padding: 12px 14px;
    font-size: 24px;
  }

  .quote-number-panel > div {
    grid-template-columns: 1fr;
    gap: 3px;
    padding: 10px 14px;
  }

  .quote-number-panel span,
  .quote-number-panel strong {
    min-width: 0;
    font-size: 14px;
  }

  .quote-number-panel .quote-number-total strong {
    font-size: 21px;
  }

  .quote-product-head {
    display: none;
  }

  .quote-product-table {
    overflow: visible;
    border-bottom: 0;
    gap: 10px;
  }

  .quote-product-row {
    min-width: 0;
    grid-template-columns: 1fr;
    gap: 7px;
    border: 1px solid #d6dee4;
    border-radius: 8px;
    padding: 12px;
    background: #fff;
  }

  .quote-product-row strong {
    font-size: 16px;
    font-weight: 800;
  }

  .quote-product-row span {
    font-size: 14px;
  }

  .quote-product-row span:empty {
    display: none;
  }

  .quote-product-row em {
    justify-self: start;
    border-radius: 999px;
    padding: 4px 8px;
    background: #f3f7f9;
    color: #203f52;
    font-size: 13px;
    font-weight: 800;
    text-align: left;
    white-space: normal;
  }

  .quote-product-row em:nth-of-type(1)::before {
    content: "Qty: ";
    color: #667b88;
  }

  .quote-product-row em:nth-of-type(2)::before {
    content: "Unit: ";
    color: #667b88;
  }

  .quote-product-row em:nth-of-type(3)::before {
    content: "Total: ";
    color: #667b88;
  }

  .quote-total-box {
    justify-self: stretch;
  }

  .quote-total-box > div {
    grid-template-columns: minmax(0, 1fr) minmax(112px, 0.8fr);
  }

  .quote-total-box span {
    padding-right: 12px;
    font-size: 14px;
  }

  .quote-followup-check {
    grid-template-columns: 1fr;
  }

  .quote-followup-money {
    justify-items: start;
  }

  .client-activity-row small {
    justify-self: start;
  }

  .crm-tabs {
    display: flex;
    max-width: calc(100vw - 56px);
    gap: 6px;
    overflow-x: auto;
    padding-bottom: 4px;
    scroll-snap-type: x proximity;
  }

  .crm-tabs a {
    flex: 0 0 auto;
    min-width: 108px;
    min-height: 38px;
    padding: 0 12px;
    font-size: 12px;
    scroll-snap-align: start;
    white-space: nowrap;
  }

  .match-card {
    grid-template-columns: 52px 1fr;
  }

  .match-card .button {
    grid-column: 1 / -1;
  }

  .generated-post-card {
    grid-template-columns: 1fr;
  }

  .generated-post-card img {
    width: 100%;
    max-height: 260px;
  }

  .angle-grid,
  .angle-grid.single,
  .media-actions,
  .camera-head,
  .camera-actions {
    grid-template-columns: 1fr;
    flex-direction: column;
    align-items: stretch;
  }
}

.imported-history-section {
  grid-column: 1 / -1;
}

.imported-history-summary {
  cursor: pointer;
  list-style: none;
}

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

.imported-history-summary::marker {
  content: "";
}

.imported-history-summary::after {
  content: "Open";
  border: 1px solid rgba(14, 64, 94, 0.18);
  border-radius: 999px;
  padding: 5px 10px;
  color: #0e405e;
  background: #fff;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.imported-history-section[open] .imported-history-summary::after {
  content: "Close";
}

.imported-history-summary-copy {
  display: grid;
  gap: 3px;
}

.imported-history-summary-copy em {
  color: #4d6e7f;
  font-size: 13px;
  font-style: normal;
  font-weight: 700;
}

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

.imported-history-block {
  border: 1px solid rgba(14, 64, 94, 0.14);
  border-radius: 8px;
  padding: 12px;
  background: #ffffff;
}

.imported-history-block h3 {
  margin: 0 0 10px;
  font-size: 14px;
  color: #0e405e;
}

.imported-key-values,
.imported-note-list {
  display: grid;
  gap: 8px;
}

.imported-key-values div,
.imported-note-list article {
  border: 1px solid rgba(14, 64, 94, 0.1);
  border-radius: 7px;
  padding: 9px;
  background: #f8fbfc;
}

.imported-key-values span,
.imported-note-list small,
.imported-attachment em {
  display: block;
  color: #5d7280;
  font-size: 12px;
}

.imported-key-values strong,
.imported-note-list strong {
  color: #0e405e;
}

.imported-note-list p {
  margin: 6px 0 0;
  color: #183848;
  white-space: pre-wrap;
}

.imported-attachment-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 10px;
}

.imported-attachment {
  display: grid;
  gap: 6px;
  color: inherit;
  text-decoration: none;
}

.imported-attachment img,
.imported-attachment > span {
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: 7px;
  border: 1px solid rgba(14, 64, 94, 0.14);
  background: #eef6f8;
  object-fit: cover;
}

.imported-attachment > span {
  display: grid;
  place-items: center;
  color: #0e405e;
  font-weight: 800;
}
