*,
*::before,
*::after {
  box-sizing: border-box;
}

:root {
  color-scheme: light;
  --lt-bg-page: #f3f7f4;
  --lt-surface: #ffffff;
  --lt-surface-muted: #f8fbf9;
  --lt-surface-elevated: #ffffff;
  --lt-surface-strong: #f2f8f4;
  --lt-topbar-bg: #ffffff;
  --lt-drawer-bg: #fdfefd;
  --lt-bottom-nav-bg: rgba(255, 255, 255, 0.97);
  --lt-text-primary: #1f2937;
  --lt-text-strong: #0f172a;
  --lt-text-muted: #556273;
  --lt-link: #1f4f46;
  --lt-link-hover: #163a34;
  --lt-brand-500: #22c55e;
  --lt-brand-600: #16a34a;
  --lt-brand-700: #166534;
  --lt-brand-800: #14532d;
  --lt-brand-900: #124537;
  --lt-accent-bg: #ecfdf5;
  --lt-accent-border: #86efac;
  --lt-accent-soft-border: #bbf7d0;
  --lt-danger-bg: #fee2e2;
  --lt-danger-border: #fecaca;
  --lt-danger-text: #991b1b;
  --lt-success-bg: #dcfce7;
  --lt-success-border: #bbf7d0;
  --lt-success-text: #166534;
  --lt-border: #d1ddd5;
  --lt-border-muted: #dbe4de;
  --lt-card-border: #d5e1da;
  --lt-card-bg: #ffffff;
  --lt-field-bg: #ffffff;
  --lt-field-border: #c4d0c9;
  --lt-button-primary-bg: #166534;
  --lt-button-primary-hover: #14532d;
  --lt-button-primary-text: #ffffff;
  --lt-button-secondary-bg: #ffffff;
  --lt-button-secondary-hover: #f2f7f4;
  --lt-button-secondary-text: #1f2937;
  --lt-nav-active-bg: #ecfdf5;
  --lt-nav-active-border: #86efac;
  --lt-nav-active-text: #14532d;
  --lt-badge-neutral-bg: #edf4ef;
  --lt-badge-neutral-text: #334155;
  --lt-empty-bg: #f7fbf8;
  --lt-empty-border: #cbd9d1;
  --lt-radius-sm: 10px;
  --lt-radius-md: 14px;
  --lt-radius-lg: 18px;
  --lt-radius-xl: 22px;
  --lt-shadow-sm: 0 4px 10px rgba(15, 23, 42, 0.06);
  --lt-shadow-md: 0 10px 24px rgba(15, 23, 42, 0.10);
  --lt-shadow-lg: 0 20px 52px rgba(15, 23, 42, 0.14);
}

[data-theme-resolved="dark"] {
  color-scheme: dark;
  --lt-bg-page: #0b120f;
  --lt-surface: #121d18;
  --lt-surface-muted: #182621;
  --lt-surface-elevated: #1d2d26;
  --lt-surface-strong: #20332b;
  --lt-topbar-bg: #101a15;
  --lt-drawer-bg: #0f1814;
  --lt-bottom-nav-bg: rgba(15, 24, 20, 0.97);
  --lt-text-primary: #e8f0eb;
  --lt-text-strong: #f3f8f5;
  --lt-text-muted: #b6c6bd;
  --lt-link: #95efbe;
  --lt-link-hover: #b2f6d0;
  --lt-brand-500: #5ce794;
  --lt-brand-600: #43cf7b;
  --lt-brand-700: #35b56d;
  --lt-brand-800: #2a9f5f;
  --lt-brand-900: #238551;
  --lt-accent-bg: #153727;
  --lt-accent-border: #3d8a61;
  --lt-accent-soft-border: #4ba974;
  --lt-danger-bg: #3a1a1d;
  --lt-danger-border: #7f2e35;
  --lt-danger-text: #ffc7cc;
  --lt-success-bg: #153727;
  --lt-success-border: #3d8a61;
  --lt-success-text: #abf5cd;
  --lt-border: #344740;
  --lt-border-muted: #3f554d;
  --lt-card-border: #3a4f47;
  --lt-card-bg: #15231d;
  --lt-field-bg: #1a2a23;
  --lt-field-border: #496257;
  --lt-button-primary-bg: #43cf7b;
  --lt-button-primary-hover: #35b56d;
  --lt-button-primary-text: #072110;
  --lt-button-secondary-bg: #1b2b24;
  --lt-button-secondary-hover: #243730;
  --lt-button-secondary-text: #e8f0eb;
  --lt-nav-active-bg: #1b3d2d;
  --lt-nav-active-border: #4ba974;
  --lt-nav-active-text: #b6f7d3;
  --lt-badge-neutral-bg: #21352c;
  --lt-badge-neutral-text: #c7d8cf;
  --lt-empty-bg: #15241d;
  --lt-empty-border: #486056;
  --lt-shadow-sm: 0 8px 16px rgba(2, 8, 5, 0.35);
  --lt-shadow-md: 0 14px 30px rgba(2, 8, 5, 0.46);
  --lt-shadow-lg: 0 24px 56px rgba(2, 8, 5, 0.56);
}

[data-theme-resolved="dark"] .jobs-board-switcher .segmented-tab {
  background: rgba(243, 248, 245, 0.16);
  color: #d7f5e4;
}

[data-theme-resolved="dark"] .jobs-board-switcher .segmented-tab.is-active {
  background: #f3f8f5;
  color: #1f7c49;
}

html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

body.app-body {
  margin: 0;
  font-family: "Inter", "Segoe UI", Arial, Helvetica, sans-serif;
  background: var(--lt-bg-page, #f4f7fb);
  color: var(--lt-text-primary, #1f2937);
  line-height: 1.45;
}



.app-body--signed-in {
  padding-bottom: calc(74px + env(safe-area-inset-bottom, 0px));
}

.app-topbar {
  position: sticky;
  top: 0;
  z-index: 30;
  background: var(--lt-topbar-bg);
  border-bottom: 1px solid var(--lt-border);
}

.app-topbar-inner {
  width: min(1100px, calc(100% - 24px));
  min-height: 52px;
  margin: 0 auto;
  padding-top: calc(env(safe-area-inset-top, 0px) + 2px);
  padding-bottom: 2px;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 42px;
  align-items: center;
  gap: 8px;
}

.app-menu-button,
.app-drawer-close {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid var(--lt-border);
  background: var(--lt-surface);
  color: var(--lt-text-strong);
  font-size: 1rem;
  font-weight: 700;
}

.app-title-wrap {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 5px;
  min-width: 0;
}

.app-title {
  color: var(--lt-text-strong);
  font-size: 0.98rem;
  font-weight: 700;
  letter-spacing: -0.015em;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.app-topbar-spacer {
  width: 40px;
  height: 40px;
  display: block;
}

.app-topbar-action-slot {
  display: flex;
  justify-content: flex-end;
}

.app-topbar-action {
  min-height: 30px;
  padding: 4px 9px;
  border-radius: 999px;
  border: 1px solid var(--lt-accent-border);
  background: var(--lt-accent-bg);
  color: var(--lt-success-text);
  text-decoration: none;
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}


.app-topbar-action--icon {
  width: 34px;
  min-height: 34px;
  padding: 0;
  border-radius: 10px;
  border-color: var(--lt-accent-soft-border);
  background: var(--lt-surface-strong);
  font-size: 1.05rem;
  line-height: 1;
}

.jobs-board {
  display: grid;
  gap: 8px;
}

.jobs-board-header {
  background: linear-gradient(160deg, #166534 0%, #15803d 100%);
  color: #ffffff;
  border-radius: 18px;
  padding: 14px;
  box-shadow: var(--lt-shadow-md);
  display: grid;
  gap: 12px;
}

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

.jobs-board-switcher .segmented-tab {
  min-height: 38px;
  background: rgba(255, 255, 255, 0.16);
  color: #dcfce7;
}

.jobs-board-switcher .segmented-tab.is-active {
  background: #ffffff;
  color: #166534;
}

.jobs-board-banner {
  border-radius: 14px;
  border: 1px solid #fca5a5;
  background: #ef4444;
  color: #ffffff;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

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

.jobs-board-toolbar {
  background: var(--lt-surface);
  border: 1px solid var(--lt-border);
  border-radius: 16px;
  padding: 12px;
  display: grid;
  gap: 10px;
}

.jobs-board-search {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
}

.jobs-board-filters,
.jobs-board-quick-actions {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 2px;
}

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

.jobs-board-card {
  border: 1px solid var(--lt-card-border);
  border-radius: 16px;
  background: var(--lt-card-bg);
  padding: 12px;
  box-shadow: var(--lt-shadow-sm);
  display: grid;
  gap: 10px;
}

.jobs-board-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 28px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--lt-accent-border);
  background: var(--lt-accent-bg);
  color: var(--lt-success-text);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

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

.jobs-board-empty,
.jobs-board-no-results {
  border: 1px dashed var(--lt-empty-border);
  border-radius: 16px;
  background: var(--lt-empty-bg);
  min-height: 220px;
  padding: 20px 14px;
  display: grid;
  place-items: center;
  text-align: center;
  color: var(--lt-text-primary);
}

.jobs-board-no-results {
  min-height: 150px;
  background: var(--lt-card-bg);
  color: var(--lt-text-muted);
}

.app-drawer-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(2, 6, 23, 0.45);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
  z-index: 39;
}

.app-drawer {
  position: fixed;
  top: 0;
  width: min(272px, 78vw);
  height: 100vh;
  padding: calc(8px + env(safe-area-inset-top, 0px)) 8px calc(10px + env(safe-area-inset-bottom, 0px));
  background: linear-gradient(180deg, var(--lt-drawer-bg) 0%, var(--lt-surface) 100%);
  box-shadow: var(--lt-shadow-lg);
  transition: transform 0.24s ease;
  z-index: 40;
  display: flex;
  flex-direction: column;
}

.app-drawer--left {
  left: 0;
  border-right: 1px solid var(--lt-border);
  transform: translateX(-102%);
}

.app-drawer--right {
  right: 0;
  border-left: 1px solid var(--lt-border);
  transform: translateX(102%);
}

.app-drawer-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1px 2px 6px;
  margin-bottom: 2px;
}

.app-drawer-header p {
  margin: 0;
  color: var(--lt-text-muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.app-drawer-nav {
  display: grid;
  gap: 5px;
  overflow-y: auto;
  padding-bottom: 2px;
}

.app-drawer-section {
  display: grid;
  gap: 3px;
}

.app-drawer-section-heading {
  margin: 0;
  padding: 0 6px;
  color: var(--lt-text-muted);
  font-size: 0.67rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.app-drawer-section-links {
  display: grid;
  gap: 1px;
  padding: 1px;
  border: 1px solid var(--lt-border);
  border-radius: 10px;
  background: var(--lt-surface-muted);
}

.app-drawer-link,
.app-drawer-logout {
  text-decoration: none;
  border: 1px solid transparent;
  border-radius: 8px;
  background: var(--lt-surface);
  color: var(--lt-text-strong);
  font-weight: 650;
  font-size: 0.89rem;
  line-height: 1.2;
  min-height: 42px;
  padding: 9px 10px;
  text-align: left;
}

.app-drawer-link.is-active {
  border-color: var(--lt-nav-active-border);
  background: var(--lt-nav-active-bg);
  color: var(--lt-nav-active-text);
}

.app-drawer-link:hover {
  background: var(--lt-surface-muted);
}

.app-drawer-link--upgrade {
  border-color: var(--lt-accent-border);
  background: linear-gradient(180deg, var(--lt-surface-strong) 0%, var(--lt-accent-bg) 100%);
  color: var(--lt-brand-700);
  font-weight: 750;
}

.app-drawer-link--upgrade:hover {
  background: linear-gradient(180deg, var(--lt-accent-bg) 0%, var(--lt-surface-strong) 100%);
}

.app-drawer-logout {
  border-color: var(--lt-danger-border);
  background: var(--lt-danger-bg);
  color: var(--lt-danger-text);
  margin-top: 1px;
}

.app-drawer-close {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  border-color: var(--lt-border);
  background: var(--lt-surface-muted);
  font-size: 0.85rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.is-nav-open-account .app-drawer--left,
.is-nav-open-more .app-drawer--right {
  transform: translateX(0);
}

.is-nav-open-account .app-drawer-backdrop,
.is-nav-open-more .app-drawer-backdrop {
  opacity: 1;
  pointer-events: auto;
}

body.is-nav-open-account,
body.is-nav-open-more {
  overflow: hidden;
}

.app-bottom-nav {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 35;
  padding: 8px 10px calc(10px + env(safe-area-inset-bottom, 0px));
  background: color-mix(in srgb, var(--lt-bottom-nav-bg) 92%, var(--lt-surface) 8%);
  border-top: 1px solid var(--lt-border);
  box-shadow: 0 -6px 20px color-mix(in srgb, #020617 12%, transparent);
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}

.app-bottom-link {
  border: none;
  background: transparent;
  color: var(--lt-text-muted);
  text-decoration: none;
  min-height: 56px;
  border-radius: 16px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  cursor: pointer;
  transition: color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.app-bottom-link.is-active {
  color: var(--lt-nav-active-text);
  background: var(--lt-nav-active-bg);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--lt-nav-active-border) 72%, transparent);
}

.app-bottom-link:not(.is-active) {
  opacity: 0.82;
}

.app-bottom-link:active {
  transform: translateY(1px);
}

.app-bottom-link:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px rgba(21, 128, 61, 0.35);
}

.app-bottom-icon {
  width: 20px;
  height: 20px;
  line-height: 1;
}

.app-bottom-icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

.app-shell--with-bottom-nav {
  margin-bottom: 10px;
}

.topbar {
  background: linear-gradient(180deg, var(--lt-brand-800) 0%, var(--lt-brand-900) 100%);
  color: #fff;
  box-shadow: var(--lt-shadow-md);
  padding: 16px 0 18px;
  position: sticky;
  top: 0;
  z-index: 20;
}

.topbar-inner {
  width: min(1100px, calc(100% - 28px));
  margin: 0 auto;
  padding-top: env(safe-area-inset-top, 0px);
}

.topbar-header {
  display: flex;
  align-items: center;
  gap: 14px;
}

.brand-row {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
}

.brand-logo {
  width: 84px;
  height: auto;
  border-radius: var(--lt-radius-sm);
  background: var(--lt-surface);
  box-shadow: var(--lt-shadow-sm);
}

.brand-title {
  font-size: clamp(1.7rem, 5vw, 2.4rem);
  font-weight: 800;
  color: #fff;
  letter-spacing: -0.02em;
  line-height: 1.05;
}

.demo-account-pill {
  display: inline-flex;
  align-items: center;
  margin-left: 8px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.42);
  border: 1px solid rgba(255, 255, 255, 0.25);
  color: #dcfce7;
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.owner-nav {
  margin: 18px auto 0;
  display: grid;
  gap: 10px;
  width: min(560px, 100%);
}

.owner-nav-primary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.owner-nav-link,
.owner-nav-more-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  width: 100%;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  font-size: 0.96rem;
  line-height: 1.2;
  text-align: center;
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-sizing: border-box;
}

.owner-nav-link--full {
  grid-column: 1 / -1;
}

.owner-nav-link:hover,
.owner-nav-more-toggle:hover {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
}

.owner-nav-link-danger {
  background: #dc2626;
  border-color: rgba(254, 202, 202, 0.6);
}

.owner-nav-link-danger:hover {
  background: #b91c1c;
}

.owner-nav-more {
  position: relative;
  grid-column: 1 / -1;
}

.owner-nav-more summary {
  list-style: none;
  cursor: pointer;
}

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

.owner-nav-dropdown {
  margin-top: 10px;
  min-width: 220px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px;
  border-radius: var(--lt-radius-lg);
  background: var(--lt-surface);
  box-shadow: var(--lt-shadow-lg);
  box-sizing: border-box;
}

.owner-nav-dropdown a,
.owner-nav-dropdown form {
  width: 100%;
}

.owner-nav-link-form {
  margin: 0;
  width: 100%;
}

.owner-nav-dropdown-link {
  display: block;
  width: 100%;
  padding: 12px 14px;
  border-radius: 12px;
  color: var(--lt-text-strong);
  text-decoration: none;
  font-weight: 700;
  background: var(--lt-surface-muted);
  box-sizing: border-box;
}

.owner-nav-dropdown-link:hover {
  background: #eef2ff;
}

.logout-button-inline {
  display: block;
  width: 100%;
  min-height: 46px;
  padding: 10px 14px;
  border: 0;
  border-radius: 12px;
  background: #dc2626;
  color: #fff;
  font-weight: 800;
  font-size: 1rem;
  box-sizing: border-box;
}

.crew-nav {
  margin-top: 18px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.logged-out-header {
  margin-top: 10px;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.nav-links form {
  margin: 0;
}

.nav-link {
  display: inline-block;
  color: white;
  text-decoration: none;
  padding: 10px 14px;
  border-radius: 10px;
  font-weight: 700;
  transition: background 0.2s ease;
}

.nav-link:hover {
  background: rgba(255, 255, 255, 0.14);
  color: white;
}

.nav-link-cta {
  background: #12202f;
}

.nav-link-cta:hover {
  background: #0b1620;
}

.logout-button {
  background: #dc2626;
  color: white;
  border: none;
  padding: 10px 14px;
  border-radius: 10px;
  font-weight: 700;
  cursor: pointer;
}

.logout-button:hover {
  background: #b91c1c;
}

.page-wrap {
  width: min(1100px, calc(100% - 32px));
  margin: 0 auto;
  padding: 16px 0 20px;
}

.app-shell {
  display: grid;
  gap: 16px;
}

.app-body--signed-in .card-shell:not(.auth-shell):not(.public-billing-payment-card) {
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 0;
}

.page-container,
.section-block {
  background: var(--lt-surface);
  border: 1px solid var(--lt-border);
  border-radius: var(--lt-radius-xl);
  box-shadow: var(--lt-shadow-sm);
  padding: clamp(12px, 2.1vw, 18px);
}

.section-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}

.section-header-title {
  margin: 0;
  font-size: clamp(1.15rem, 3.8vw, 1.6rem);
  color: var(--lt-text-strong);
}

.section-header-subtitle {
  margin: 4px 0 0;
  color: var(--lt-text-muted);
  font-size: 0.9rem;
}

.compact-section {
  display: grid;
  gap: 12px;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid var(--lt-border-muted);
  background: var(--lt-surface);
}

.compact-section__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.compact-section__label {
  margin: 0;
  color: var(--lt-text-muted);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 700;
}

.compact-section__title {
  margin: 2px 0 0;
  font-size: 1.1rem;
  color: var(--lt-text-strong);
}

.compact-section__helper {
  margin: 4px 0 0;
  font-size: 0.9rem;
  color: var(--lt-text-muted);
}

.card-shell {
  background: var(--lt-surface);
  border: 1px solid var(--lt-border);
  border-radius: var(--lt-radius-xl);
  box-shadow: var(--lt-shadow-md);
  padding: clamp(12px, 2.1vw, 18px);
}

.flash {
  margin-bottom: 18px;
  padding: 14px 16px;
  border-radius: var(--lt-radius-md);
  font-weight: 700;
}

.flash-notice {
  color: var(--lt-success-text);
  background: var(--lt-success-bg);
  border: 1px solid var(--lt-success-border);
}

.flash-alert {
  color: var(--lt-danger-text);
  background: var(--lt-danger-bg);
  border: 1px solid var(--lt-danger-border);
}

.page-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 4px;
  flex-wrap: wrap;
  margin-bottom: 6px;
}

.page-header h1 {
  margin: 0;
  font-size: clamp(1.4rem, 4.6vw, 1.9rem);
  line-height: 1.15;
  color: var(--lt-text-strong);
  letter-spacing: -0.02em;
}

.page-subtitle {
  margin-top: 4px;
  margin-bottom: 0;
  font-size: 0.92rem;
  color: var(--lt-text-muted);
}

.section-divider {
  margin-top: 14px;
  padding-top: 10px;
  border-top: 1px solid var(--lt-border-muted);
}

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

.actions-row--flush {
  margin-top: 0;
}

.actions-row--tight {
  margin-top: 6px;
}

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

.content-card,
.section-card {
  border: 1px solid var(--lt-card-border);
  border-radius: var(--lt-radius-lg);
  padding: clamp(10px, 1.8vw, 14px);
  background: var(--lt-card-bg);
}

.stat-card {
  border: 1px solid var(--lt-accent-soft-border);
  border-radius: 14px;
  padding: 14px;
  background: var(--lt-surface);
  min-height: 72px;
}

.stat-card-label {
  margin: 0;
  color: #3f4d60;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 800;
}

.stat-card-value {
  margin: 4px 0 0;
  font-size: clamp(1.4rem, 5.2vw, 1.8rem);
  font-weight: 800;
  color: #14532d;
}

.content-card h2,
.content-card h3,
.section-card h2,
.section-card h3 {
  margin-top: 0;
  color: var(--lt-text-primary);
}

.text-muted {
  color: var(--lt-text-muted);
}

.text-strong {
  font-weight: 700;
}

.text-center {
  text-align: center;
}

.table-wrap-spaced,
.mobile-stack-spaced {
  margin-top: 10px;
}

.max-form-shell {
  max-width: 760px;
  margin: 0 auto;
}

.page-back-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 700;
  text-decoration: none;
  color: var(--lt-link);
  margin-bottom: 14px;
}

.workflow-header {
  display: grid;
  gap: 8px;
}

.workflow-header--compact {
  gap: 8px;
}

.workflow-header-note {
  margin: 0;
  color: var(--lt-text-muted);
  font-size: 0.92rem;
}

.workflow-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.workflow-actions .btn-primary,
.workflow-actions .btn-secondary,
.workflow-actions .btn-success,
.workflow-actions .btn-info,
.workflow-actions .btn-danger {
  min-height: 34px;
  padding: 6px 10px;
  font-size: 0.78rem;
}

.operations-alert-banner {
  margin-top: 8px;
  border-radius: 14px;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  border: 1px solid transparent;
}

.operations-alert-banner strong {
  display: inline-block;
  margin-right: 6px;
}

.operations-alert-banner span {
  color: inherit;
}

.operations-alert-icon {
  font-size: 1.25rem;
  line-height: 1;
}

.operations-alert-banner.is-active {
  background: #fef2f2;
  border-color: #fca5a5;
  color: #991b1b;
}

.operations-alert-banner.is-active:hover {
  background: #fee2e2;
  color: #7f1d1d;
}

.operations-alert-banner.is-clear {
  background: #ecfdf5;
  border-color: #86efac;
  color: #166534;
}

.operations-alert-banner.is-clear:hover {
  background: #dcfce7;
  color: #14532d;
}

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

.quick-card {
  border: 1px solid var(--lt-border-muted);
  border-radius: 14px;
  padding: 10px;
  background: var(--lt-surface);
}

.quick-card h3 {
  margin: 0;
  font-size: 16px;
}

.quick-card p {
  margin: 4px 0 0;
  color: var(--lt-text-muted);
  font-size: 13px;
}

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

.mobile-data-card {
  border: 1px solid var(--lt-border-muted);
  border-radius: 12px;
  padding: 10px 11px;
  background: var(--lt-surface);
}

.mobile-data-card p {
  margin: 0 0 8px;
}

.crew-done-fireworks {
  display: flex;
  justify-content: center;
  gap: 10px;
  font-size: 1.5rem;
  margin-bottom: 10px;
}

.crew-done-fireworks span {
  display: inline-block;
  animation: crew-firework-pop 1.2s ease-in-out infinite;
}

.crew-done-fireworks span:nth-child(2) {
  animation-delay: 0.2s;
}

.crew-done-fireworks span:nth-child(3) {
  animation-delay: 0.4s;
}

.crew-done-fireworks span:nth-child(4) {
  animation-delay: 0.6s;
}

.crew-done-fireworks span:nth-child(5) {
  animation-delay: 0.8s;
}

@keyframes crew-firework-pop {
  0%,
  100% {
    transform: translateY(0) scale(1);
    opacity: 0.7;
  }

  50% {
    transform: translateY(-6px) scale(1.2);
    opacity: 1;
  }
}

.mobile-data-card p:last-child {
  margin-bottom: 0;
}

.hide-desktop {
  display: none;
}

.btn-primary,
.btn-secondary,
.btn-success,
.btn-info,
.btn-danger {
  display: inline-block;
  text-decoration: none;
  padding: 10px 14px;
  border-radius: var(--lt-radius-sm);
  font-weight: 700;
  border: none;
  cursor: pointer;
  box-sizing: border-box;
  max-width: 100%;
  min-height: 44px;
  font-size: 0.9rem;
  transition: transform 0.12s ease, box-shadow 0.12s ease, background-color 0.2s ease;
}

.btn-primary:hover,
.btn-secondary:hover,
.btn-success:hover,
.btn-info:hover,
.btn-danger:hover {
  transform: translateY(-1px);
  box-shadow: var(--lt-shadow-sm);
}

.btn-primary {
  background: var(--lt-button-primary-bg);
  color: var(--lt-button-primary-text);
}

.btn-primary:hover {
  background: var(--lt-button-primary-hover);
  color: var(--lt-button-primary-text);
}

.btn-secondary {
  background: transparent;
  color: var(--lt-button-secondary-text);
  border: 1px solid var(--lt-border);
}

.btn-secondary:hover {
  background: var(--lt-surface-muted);
  color: var(--lt-button-secondary-text);
}

.btn-success {
  background: var(--lt-button-primary-bg);
  color: var(--lt-button-primary-text);
}

.btn-success:hover {
  background: var(--lt-button-primary-hover);
  color: var(--lt-button-primary-text);
}

.btn-info {
  background: transparent;
  color: var(--lt-button-secondary-text);
  border: 1px solid var(--lt-border);
}

.btn-info:hover {
  background: var(--lt-surface-muted);
  color: var(--lt-button-secondary-text);
}

.btn-danger {
  background: #dc2626;
  color: white;
}

.btn-danger:hover {
  background: #b91c1c;
  color: white;
}

.list-stack {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.action-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 60px;
  padding: 10px 12px;
  border: 1px solid var(--lt-border-muted);
  border-radius: 14px;
  background: var(--lt-surface);
  text-decoration: none;
  color: inherit;
}

.action-row__title {
  margin: 0;
  font-weight: 700;
  color: var(--lt-text-strong);
}

.action-row__meta {
  margin: 2px 0 0;
  font-size: 0.86rem;
  color: var(--lt-text-muted);
}

.expandable-row {
  border: 1px solid var(--lt-border-muted);
  border-radius: 14px;
  background: var(--lt-surface);
  overflow: hidden;
}

.expandable-row > summary {
  list-style: none;
  cursor: pointer;
  padding: 12px;
  min-height: 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.expandable-row > summary::-webkit-details-marker { display: none; }

.expandable-row > summary::after {
  content: "›";
  font-size: 1.2rem;
  color: var(--lt-text-muted);
  transition: transform 0.15s ease;
}

.expandable-row[open] > summary {
  background: var(--lt-surface-muted);
}

.expandable-row[open] > summary::after {
  transform: rotate(90deg);
}

.expandable-row__body {
  padding: 0 12px 12px;
}

.interactive-disclosure-row {
  list-style: none;
  cursor: pointer;
  min-height: 48px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--lt-border-muted);
  border-radius: 12px;
  background: var(--lt-surface);
  color: var(--lt-text-strong);
  font-weight: 700;
  transition: background-color 0.16s ease, border-color 0.16s ease, transform 0.12s ease;
}

.interactive-disclosure-row::-webkit-details-marker {
  display: none;
}

.interactive-disclosure-row::after {
  content: "▾";
  color: var(--lt-text-muted);
  font-size: 0.86rem;
  line-height: 1;
  transition: transform 0.16s ease;
}

.interactive-disclosure-row:hover {
  background: #eef2ff;
}

.interactive-disclosure-row:active {
  background: #dbeafe;
  transform: translateY(1px);
}

.interactive-disclosure-row:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

details[open] > .interactive-disclosure-row::after {
  transform: rotate(180deg);
}

details[open] > .interactive-disclosure-row + * {
  animation: disclosure-reveal 0.2s ease;
}

@keyframes disclosure-reveal {
  from {
    opacity: 0;
    transform: translateY(-3px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.info-card {
  border: 1px solid var(--lt-border-muted);
  border-radius: 16px;
  padding: 11px;
  background: var(--lt-surface-muted);
}

.info-card p {
  margin: 0 0 10px 0;
}

.info-card p:last-child {
  margin-bottom: 0;
}

a {
  color: var(--lt-link);
}

a:hover {
  color: var(--lt-link-hover);
}

table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 12px;
  background: var(--lt-surface);
}

th,
td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--lt-border-muted);
  text-align: left;
}

th {
  background: var(--lt-surface-muted);
}

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

.template-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.template-actions form {
  margin: 0;
}

.nav-links-primary {
  justify-content: flex-end;
}

.overview-grid {
  margin-top: 28px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 18px;
}

.tool-sections {
  margin-top: 30px;
  display: grid;
  gap: 18px;
}

.support-section-title {
  margin-top: 0;
  color: var(--lt-text-primary);
}

.support-faq-list {
  margin: 0;
  padding-left: 18px;
  color: #374151;
  line-height: 1.55;
}

.privacy-lead {
  margin-top: 8px;
  font-size: 16px;
  line-height: 1.6;
  color: #374151;
}

.legal-section {
  margin-top: 22px;
}

.legal-section h2 {
  margin: 0 0 10px;
  font-size: 20px;
  color: var(--lt-text-primary);
}

.legal-section p,
.legal-section li {
  font-size: 15px;
  line-height: 1.65;
  color: #374151;
}

.footer-links {
  margin-top: 26px;
  padding-top: 16px;
  border-top: 1px solid var(--lt-border-muted);
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

.footer-links a {
  font-weight: 700;
}

.home-shell .page-header {
  margin-bottom: 8px;
}

.home-shell-compact {
  display: grid;
  gap: 8px;
}

.home-field-snapshot {
  margin-bottom: 8px;
  border: 1px solid #bfdbfe;
  border-radius: 14px;
  padding: 8px 10px;
  background: linear-gradient(145deg, #f8fbff, #eef6ff);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.home-field-snapshot-main {
  min-width: 0;
}

.home-field-snapshot-label {
  margin: 0;
  color: #475569;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.home-field-snapshot-title {
  margin: 1px 0 0;
  color: var(--lt-text-strong);
  font-size: 1.05rem;
  line-height: 1.2;
}

.home-field-snapshot-metrics {
  margin: 3px 0 0;
  color: #0f172a;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.2;
}

.home-field-snapshot-recommendation {
  margin: 2px 0 0;
  color: #334155;
  font-size: 12px;
  line-height: 1.2;
}


.home-field-snapshot-actions {
  margin-top: 6px;
}

.home-field-snapshot-action {
  padding: 3px 8px;
  font-size: 11px;
  line-height: 1.1;
  min-height: auto;
}

.home-field-snapshot-note {
  flex-shrink: 0;
  border: 1px dashed #93c5fd;
  border-radius: 10px;
  padding: 5px 8px;
  font-size: 11px;
  font-weight: 700;
  color: #475569;
  background: rgba(255, 255, 255, 0.65);
}

.home-command-header {
  margin-bottom: 6px;
}

.home-command-title {
  margin: 2px 0 0;
  font-size: clamp(1.3rem, 5.5vw, 1.6rem);
  line-height: 1.2;
}

.home-command-subtitle {
  margin: 0;
}

.home-primary-action {
  margin-top: 4px;
  display: grid;
  gap: 8px;
}

.home-primary-action-title {
  margin: 0;
  font-size: 1rem;
  color: var(--lt-text-strong);
}

.home-primary-cta {
  width: 100%;
  text-align: center;
  padding: 10px 12px;
}

.home-secondary-actions {
  margin-top: 6px;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.home-secondary-actions-drawer {
  margin-top: 4px;
  border: 1px solid var(--lt-border-muted);
  border-radius: 12px;
  background: var(--lt-surface);
}

.home-secondary-actions-drawer > summary {
  font-size: 0.84rem;
}

.home-secondary-actions .btn-small {
  flex: 1 1 calc(33.333% - 6px);
  text-align: center;
  min-height: 38px;
}

.home-quick-link-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

.home-quick-link-icon {
  color: #94a3b8;
  font-size: 10px;
}

.home-secondary-actions-footer {
  margin-top: 6px;
  padding: 0 8px 8px;
}

.quick-links-customize-shell {
  max-width: 620px;
}

.quick-links-customize-grid {
  display: grid;
  gap: 8px;
}

.quick-links-customize-item {
  border: 1px solid var(--lt-border-muted);
  border-radius: 10px;
  padding: 8px;
  display: grid;
  gap: 6px;
}

.quick-links-customize-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
}

.home-quick-track {
  background: linear-gradient(135deg, #ecfeff, #eff6ff);
  border: 1px solid #bfdbfe;
  border-radius: 14px;
  padding: 12px;
}

.home-mode-chip {
  margin: 0;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 800;
  color: var(--lt-badge-neutral-text);
  background: var(--lt-badge-neutral-bg);
}

.home-mode-chip-office {
  color: var(--lt-nav-active-text);
  background: var(--lt-nav-active-bg);
}

.home-feature-card-title {
  margin: 0;
  color: var(--lt-text-strong);
  font-size: clamp(1.05rem, 4.6vw, 1.25rem);
}

.home-feature-card-description {
  margin: 2px 0 0;
  color: #334155;
  font-size: 13px;
  line-height: 1.25;
}

.home-quick-track-actions {
  margin-top: 12px;
}

.home-quick-track-compact {
  margin-top: 2px;
  padding: 8px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.home-quick-track-content {
  min-width: 0;
}

.home-quick-track-button {
  font-size: 13px;
  padding: 8px 11px;
  white-space: nowrap;
}

.home-command-kpi-grid {
  margin-top: 8px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}

.home-command-kpi-grid .stat-card {
  border-radius: 10px;
  padding: 9px;
  min-height: 0;
}

.home-command-kpi-grid .stat-card-label {
  margin: 0;
  font-size: 11px;
  line-height: 1.2;
}

.home-command-kpi-grid .stat-card-value {
  margin-top: 4px;
  font-size: clamp(1rem, 3.5vw, 1.3rem);
}

.home-command-kpi-grid .metric-detail {
  margin: 2px 0 0;
  font-size: 10px;
  line-height: 1.25;
}

.home-command-kpi-grid-compact {
  margin-top: 8px;
}


.home-command-attention {
  margin-top: 8px;
}

.home-pro-crew-hub {
  margin-top: 18px;
}

.home-mode-chip-pro {
  color: var(--lt-link);
  background: color-mix(in srgb, var(--lt-accent-bg) 56%, var(--lt-surface) 44%);
}

.home-pro-crew-hub .home-feature-card-title {
  color: var(--lt-text-primary);
  font-size: 30px;
}

.home-pro-crew-hub .home-feature-card-description {
  color: #374151;
  font-size: 17px;
}

.home-pro-crew-actions {
  margin-top: 10px;
}

.home-setup-checklist {
  margin-top: 18px;
  border: 1px solid #bfdbfe;
  background: linear-gradient(180deg, #f8fbff 0%, #eef6ff 100%);
  border-radius: 18px;
  padding: 14px;
}

.home-mode-chip-setup {
  color: var(--lt-badge-neutral-text);
  background: var(--lt-badge-neutral-bg);
}

.home-setup-title {
  margin: 8px 0 6px;
  color: var(--lt-text-strong);
}

.home-setup-description {
  margin: 0;
  color: #334155;
}

.home-setup-progress {
  margin-top: 10px;
  height: 8px;
  border-radius: 999px;
  background: #dbeafe;
  overflow: hidden;
}

.home-setup-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, #2563eb, #0ea5e9);
  border-radius: 999px;
}

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

.home-setup-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  align-items: center;
  border: 1px solid #dbeafe;
  border-radius: 12px;
  background: #ffffff;
  padding: 8px 10px;
}

.home-setup-item.is-complete {
  border-color: #bbf7d0;
  background: #f0fdf4;
}

.home-setup-item-status {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  color: #1d4ed8;
  background: #dbeafe;
}

.home-setup-item.is-complete .home-setup-item-status {
  color: #15803d;
  background: #dcfce7;
}

.home-setup-item-title {
  margin: 0;
  font-weight: 700;
  color: var(--lt-text-primary);
}

.home-setup-item-description {
  margin: 3px 0 0;
  color: var(--lt-text-muted);
  font-size: 14px;
}

.home-setup-item-action {
  white-space: nowrap;
}

.home-setup-optional {
  margin-left: 6px;
  border-radius: 999px;
  background: var(--lt-badge-neutral-bg);
  color: var(--lt-badge-neutral-text);
  padding: 2px 8px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.home-bottom-actions {
  justify-content: center;
  align-items: stretch;
}

.home-bottom-actions > * {
  flex: 1 1 220px;
  max-width: 320px;
  text-align: center;
}

.home-priority-card {
  margin-top: 10px;
}

.home-priority-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.home-priority-item {
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  padding: 8px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  background: var(--lt-surface-muted);
}

.home-priority-title {
  margin: 0;
  font-weight: 700;
  color: var(--lt-text-strong);
}

.home-priority-description {
  margin: 2px 0 0;
  color: var(--lt-text-muted);
  font-size: 12px;
}

.home-priority-list-compact {
  gap: 6px;
}

.home-priority-list-compact .home-priority-item {
  padding: 8px;
}

.home-core-links-grid {
  margin-top: 8px;
}

.operations-metrics {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 10px;
}

.business-overview-redesign h2 {
  margin: 0;
  color: var(--lt-text-primary);
}

.action-center-grid {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

.action-center-button {
  padding: 14px 16px;
  text-align: center;
  font-weight: 800;
}

.snapshot-block {
  margin-top: 22px;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  padding: 16px;
  background: var(--lt-surface-muted);
}

.snapshot-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

.snapshot-item {
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: 12px;
}

.snapshot-value {
  margin: 8px 0 4px;
  font-size: 30px;
  line-height: 1.1;
  font-weight: 800;
  color: var(--lt-text-strong);
}

.snapshot-value-danger {
  color: #b91c1c;
}

.snapshot-detail {
  margin: 0;
  font-size: 14px;
  color: var(--lt-text-muted);
}

.secondary-info-details > summary {
  margin-bottom: 8px;
}

.secondary-info-grid {
  margin-top: 14px;
}

.hub-shell .actions-row > * {
  flex: 1 1 180px;
  text-align: center;
}

.metric-card-link {
  display: block;
  color: inherit;
  text-decoration: none;
}

.metric-card-link:hover {
  color: inherit;
}

.metric-card-link .metric-card {
  height: 100%;
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.metric-card-link:hover .metric-card {
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.08);
  border-color: #94a3b8;
}

.metric-card-link:focus-visible {
  outline: 3px solid #2563eb;
  outline-offset: 3px;
  border-radius: 18px;
}

.metric-card-detail-link {
  display: inline-block;
  margin-top: 10px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid #cbd5e1;
  font-size: 12px;
  font-weight: 700;
  color: #334155;
  text-decoration: none;
  background: rgba(255, 255, 255, 0.6);
}

.metric-card-detail-link:hover {
  color: var(--lt-text-strong);
  border-color: #94a3b8;
}

.metric-card {
  border-radius: 18px;
  border: 1px solid var(--lt-border-muted);
  padding: 14px;
  background: var(--lt-surface-muted);
}

.metric-card-danger {
  background: #fef2f2;
  border-color: #fecaca;
}

.metric-card-success {
  background: #ecfdf5;
  border-color: #86efac;
}

.metric-card-info {
  background: #eff6ff;
  border-color: #bfdbfe;
}

.metric-card-neutral {
  background: var(--lt-surface-muted);
  border-color: #dbe4f0;
}

.pricing-shell {
  max-width: 1060px;
  margin: 0 auto;
}

.pricing-context-banner {
  margin-bottom: 16px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid #bae6fd;
  background: #f0f9ff;
  color: #0c4a6e;
}

.pricing-context-banner p {
  margin: 0;
}

.pricing-web-notice {
  margin-bottom: 16px;
  border: 1px solid #bfdbfe;
  background: #eff6ff;
}

.pricing-web-notice p {
  color: #1e3a8a;
}

.pricing-web-notice .pricing-web-notice-detail {
  margin-top: 8px;
  color: #1e40af;
  font-size: 0.9rem;
}

.pricing-status-card {
  margin-bottom: 16px;
}

.pricing-status-card.is-paid {
  border-color: #86efac;
}

.pricing-status-card.is-free {
  border-color: #bfdbfe;
}

.pricing-status-subtle {
  color: #4b5563;
}

.pricing-status-success {
  color: #166534;
}

.pricing-status-upgrade {
  color: #1e3a8a;
}

.pricing-crew-callout {
  margin-bottom: 16px;
  border: 1px solid #f59e0b;
}

.pricing-crew-callout p {
  margin: 0;
  color: #92400e;
}

.pricing-grid {
  margin-top: 24px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
}

.pricing-card {
  border-radius: 18px;
  border: 1px solid #dbe4f0;
  background: var(--lt-surface-muted);
  padding: 20px;
  box-shadow: var(--lt-shadow-sm);
}

.pricing-card.is-current {
  border-color: #86efac;
  background: #ecfdf5;
}

.pricing-card.is-recommended {
  border-color: #16a34a;
  background: #f0fdf4;
  box-shadow: var(--lt-shadow-md);
}

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

.pricing-badge {
  display: inline-flex;
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--lt-brand-700);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 700;
}

.pricing-badge-current {
  background: #0f766e;
}

.pricing-value {
  margin-top: 10px;
}

.pricing-summary {
  font-size: 0.98rem;
}

.pricing-feature-list {
  margin: 12px 0 0;
  padding-left: 18px;
  color: #374151;
  display: grid;
  gap: 6px;
}

.pricing-card-actions {
  margin-top: 14px;
  display: grid;
  gap: 8px;
}

.pricing-card-actions .btn-primary,
.pricing-card-actions .btn-secondary {
  width: 100%;
  text-align: center;
}

.pricing-action-note {
  margin: 0;
  font-size: 0.85rem;
  color: var(--lt-text-muted);
}

.pricing-early-access-card {
  margin-top: 14px;
  padding: 12px 14px;
  border: 1px solid #bfdbfe;
  background: #f8fbff;
}

.pricing-early-access-title {
  margin: 0;
  font-size: 1rem;
  color: #1e3a8a;
}

.pricing-early-access-copy {
  margin: 6px 0 10px;
  font-size: 0.9rem;
  color: #1f2937;
}

.pricing-early-access-button {
  width: auto;
}

.metric-label {
  margin: 0;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #334155;
}

.metric-value {
  margin: 14px 0 10px;
  font-size: 42px;
  line-height: 1;
  font-weight: 800;
  color: var(--lt-text-strong);
}

.home-overview-grid .metric-value {
  font-size: 34px;
}

.metric-value-small {
  font-size: 28px;
  line-height: 1.2;
}

.metric-value-line {
  margin: 0 0 4px;
  font-size: 22px;
  line-height: 1.2;
  font-weight: 700;
  color: #166534;
}

.metric-supporting-text {
  margin: 0 0 12px;
  font-size: 13px;
  line-height: 1.35;
  color: #16a34a;
}

.metric-detail {
  margin: 0;
  color: var(--lt-text-muted);
  font-size: 18px;
  line-height: 1.45;
}

.tax-disclaimer {
  margin: 10px 0 0;
  font-size: 12px;
  line-height: 1.45;
  color: #64748b;
}

.deduction-breakdown-grid {
  margin-top: 16px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 12px;
}

.deduction-breakdown-card {
  border: 1px solid #dbe4f0;
  border-radius: 14px;
  background: var(--lt-surface-muted);
  padding: 14px;
}

.metric-card-clickable,
.deduction-breakdown-card-clickable {
  cursor: pointer;
}

.metric-card-clickable summary,
.deduction-breakdown-card-clickable summary {
  list-style: none;
}

.metric-card-clickable summary::-webkit-details-marker,
.deduction-breakdown-card-clickable summary::-webkit-details-marker {
  display: none;
}

.metric-card-clickable summary:focus-visible,
.deduction-breakdown-card-clickable summary:focus-visible {
  outline: 3px solid #2563eb;
  outline-offset: 4px;
  border-radius: 12px;
}

.metric-card-clickable summary::after,
.deduction-breakdown-card-clickable summary::after {
  content: "Tap for details";
  display: inline-block;
  margin-top: 10px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid #cbd5e1;
  font-size: 12px;
  font-weight: 700;
  color: #334155;
  background: rgba(255, 255, 255, 0.6);
}

.metric-card-clickable[open] summary::after,
.deduction-breakdown-card-clickable[open] summary::after {
  content: "Tap to hide";
}

.metric-breakdown-content {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px dashed #cbd5e1;
  color: #334155;
  font-size: 14px;
  line-height: 1.45;
}

.metric-breakdown-content p {
  margin: 0 0 8px;
}

.metric-breakdown-content p:last-child {
  margin-bottom: 0;
}

.deduction-breakdown-value {
  margin: 8px 0;
  font-size: 30px;
  font-weight: 800;
  line-height: 1.1;
  color: var(--lt-text-strong);
}

.projection-grid,
.tax-info-grid {
  margin-top: 16px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 12px;
}

.tax-info-grid .metric-label {
  display: flex;
  align-items: center;
  gap: 6px;
}

.missing-deduction-box {
  margin-top: 16px;
  border-radius: 14px;
  border: 1px solid #bfdbfe;
  background: #eff6ff;
  padding: 16px;
}

.missing-deduction-box h2,
.missing-deduction-box h3 {
  margin: 0 0 8px;
  color: #1e3a8a;
}

.missing-deduction-box ul {
  margin: 0;
  padding-left: 18px;
  color: #1e40af;
}

.planning-highlight-box {
  border-color: #86efac;
  background: #f0fdf4;
}

.planning-highlight-box .metric-detail {
  font-size: 14px;
}

.planning-highlight-box ul {
  color: #166534;
}

.tax-strategy-planner-card {
  border: 1px solid #bfdbfe;
  background: #f8fbff;
}

.tax-strategy-empty-state {
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px dashed #cbd5e1;
  color: var(--lt-text-muted);
  font-size: 14px;
}

.tax-strategy-entries {
  margin-top: 12px;
  display: grid;
  gap: 12px;
}

.tax-strategy-entry {
  border: 1px solid #dbe4f0;
  border-radius: 12px;
  padding: 12px;
  background: var(--lt-surface);
}

.tax-strategy-entry-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

.tax-strategy-grid {
  margin-top: 8px;
}

.tax-strategy-other-description .field-help {
  font-size: 11px;
}

.tax-strategy-annualized {
  margin: 0;
  padding: 12px;
  border-radius: 10px;
  border: 1px solid var(--lt-border-muted);
  background: var(--lt-surface-muted);
  font-weight: 700;
}

.tax-strategy-remove {
  width: auto;
  padding: 8px 10px;
  min-height: 40px;
}

.table-subtext {
  margin-top: 4px;
  font-size: 12px;
  color: var(--lt-text-muted);
}

.business-tools-dashboard .page-header {
  margin-bottom: 10px;
}

.business-tools-upgrade-banner {
  margin-top: 8px;
  margin-bottom: 10px;
  border: 1px solid #86efac;
  background: linear-gradient(135deg, #ecfdf5, #f0fdf4);
  border-radius: 14px;
  padding: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.business-tools-upgrade-eyebrow {
  margin: 0 0 4px;
  color: #166534;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.business-tools-upgrade-copy {
  margin: 0;
  color: #14532d;
  font-weight: 700;
}

.business-tools-quick-actions {
  margin-top: 0;
}

.business-tools-command-center {
  margin-top: 0;
}

.business-tools-command-center .page-subtitle {
  margin-top: 8px;
}

.business-tools-ops-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.business-tools-ops-grid--lean {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.business-tools-ops-card {
  border: 1px solid #dbe4ee;
  border-radius: 12px;
  background: var(--lt-surface);
  padding: 10px;
  text-decoration: none;
}

.business-tools-ops-card-danger {
  border-color: #fecaca;
  background: #fff7ed;
}

.business-tools-ops-card-info {
  border-color: #bfdbfe;
  background: #eff6ff;
}

.business-tools-ops-card-success {
  border-color: #bbf7d0;
  background: #f0fdf4;
}

.business-tools-ops-label {
  margin: 0;
  color: var(--lt-text-muted);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.business-tools-ops-value {
  margin: 6px 0 0;
  color: var(--lt-text-strong);
  font-size: 21px;
  font-weight: 800;
}

.business-tools-ops-detail {
  margin: 6px 0 0;
  color: #334155;
  font-size: 13px;
}

.business-tools-command-grid {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.business-tools-command-card {
  border: 1px solid #dbe4ee;
  border-radius: 12px;
  padding: 12px;
  background: var(--lt-surface);
}

.business-tools-command-card h3 {
  margin: 0;
  color: var(--lt-text-primary);
}

.business-tools-command-list {
  margin: 10px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}

.business-tools-command-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  border-bottom: 1px solid #eef2f7;
  padding-bottom: 8px;
}

.business-tools-command-list li:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.business-tools-command-primary {
  margin: 0;
  color: var(--lt-text-strong);
  font-weight: 700;
}

.business-tools-command-secondary {
  margin: 2px 0 0;
  color: #64748b;
  font-size: 13px;
}

.business-tools-status-chip {
  border-radius: 999px;
  padding: 4px 8px;
  border: 1px solid #dbe4ee;
  background: var(--lt-surface-muted);
  color: #334155;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.business-tools-empty-copy {
  margin: 10px 0 0;
  color: #64748b;
}

.business-tools-inline-link {
  margin: 10px 0 0;
  font-size: 13px;
}

.business-tools-inline-link a {
  color: #166534;
  font-weight: 700;
}

.business-tools-command-actions-title {
  margin-top: 10px;
}

.business-tools-section-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.business-tools-section-title-row h2 {
  margin: 0;
  color: var(--lt-text-primary);
}

.business-tools-section-hint {
  background: #dcfce7;
  color: #166534;
  font-size: 12px;
  font-weight: 800;
  border-radius: 999px;
  padding: 4px 10px;
}

.business-tools-quick-grid {
  margin-top: 8px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.business-tools-quick-btn {
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 0.88rem;
  font-weight: 800;
  border-radius: 12px;
}

.business-tools-quick-icon {
  font-size: 16px;
  line-height: 1;
}

.business-tools-sections {
  margin-top: 10px;
  display: grid;
  gap: 8px;
}

.business-tools-collapsible {
  padding: 10px;
  background: var(--lt-surface-muted);
}

.business-tools-collapsible summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.business-tools-collapsible summary::-webkit-details-marker {
  display: none;
}

.business-tools-collapsible summary::after {
  content: "▾";
  color: var(--lt-text-muted);
  font-size: 14px;
  font-weight: 700;
}

.business-tools-collapsible--compact summary {
  align-items: center;
}

.business-tools-collapsible--compact summary .business-tools-section-title-row {
  width: 100%;
  padding-right: 12px;
}

.business-tools-compact-copy {
  margin-top: 6px;
}

.business-tools-collapsible:not([open]) summary::after {
  content: "▸";
}

.business-tools-collapsible h3 {
  margin: 0;
  color: var(--lt-text-primary);
}

.business-tools-collapsible .page-subtitle {
  margin-bottom: 6px;
}

.business-tools-link-groups {
  margin-top: 6px;
  display: grid;
  gap: 8px;
}

.business-tools-link-group-title {
  margin: 0;
  color: #334155;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.business-tools-inline-panel h4 {
  margin: 0;
  color: var(--lt-text-primary);
}

.business-tools-insights-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.business-tools-insight-card {
  background: #ffffff;
  border: 1px solid #dbe4ee;
  border-radius: 12px;
  padding: 12px;
}

.business-tools-insight-card--highlight {
  grid-column: 1 / -1;
  border-color: #bfdbfe;
  background: #eff6ff;
}

.business-tools-insight-label {
  margin: 0;
  font-size: 12px;
  color: var(--lt-text-muted);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.business-tools-insight-value {
  margin: 6px 0 0;
  font-size: 20px;
  font-weight: 800;
  color: var(--lt-text-strong);
}

.business-tools-upgrade-prompt {
  margin-top: 10px;
  border: 1px dashed #86efac;
  background: #f0fdf4;
  border-radius: 12px;
  padding: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.business-tools-upgrade-prompt p {
  margin: 0;
  color: #166534;
  font-weight: 700;
}

.business-tools-compact-grid {
  margin-top: 8px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.business-tools-compact-grid > * {
  width: 100%;
  box-sizing: border-box;
  text-align: center;
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 8px 11px;
}

.business-tools-compact-grid form {
  margin: 0;
}

.business-tools-compact-grid form .btn-primary,
.business-tools-compact-grid form .btn-secondary,
.business-tools-compact-grid form .btn-success,
.business-tools-compact-grid form .btn-info,
.business-tools-compact-grid form .btn-danger {
  width: 100%;
}

.business-tools-pro-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 2px 8px;
  background: #dbeafe;
  color: #1e3a8a;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.business-tools-pro-locked {
  border-style: dashed;
}

.business-tools-locked-note {
  margin: 6px 0 0;
  color: #92400e;
  font-weight: 700;
}

.business-tools-share-link-row {
  margin-top: 8px;
}

.business-hub-sections {
  margin-top: 14px;
  padding-top: 12px;
}

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

.business-hub-card {
  padding: 12px;
}

.business-hub-card h2 {
  margin: 0;
  color: var(--lt-text-primary);
  font-size: 1rem;
}

.business-hub-card .page-subtitle {
  margin: 4px 0 0;
  font-size: 0.9rem;
}

.business-hub-actions {
  margin-top: 9px;
}

.business-resources-shell .page-header {
  margin-bottom: 8px;
}

.business-resources-groups .business-resources-group {
  padding: 10px 12px;
}

.business-resources-summary {
  margin: -2px 0 0;
}

.business-tools-share-link-row .form-control {
  width: 100%;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.outstanding-balances-shell {
  display: grid;
  gap: 10px;
}

.reports-index-page {
  display: grid;
  gap: 8px;
}

.reports-index-header {
  margin-bottom: 2px;
}

.reports-index-subtitle {
  margin: 2px 0 0;
}

.reports-index-section {
  display: grid;
  gap: 5px;
}

.reports-index-heading {
  margin: 0;
  padding: 0 2px;
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
}

.reports-index-group {
  display: grid;
  gap: 0;
  border: 1px solid var(--lt-border-muted);
  border-radius: 12px;
  overflow: hidden;
}

.reports-index-section--money .reports-index-heading {
  color: #166534;
}

.reports-index-section--money .reports-index-group {
  background: #f0fdf4;
  border-color: #bbf7d0;
}

.reports-index-section--collections .reports-index-heading {
  color: #9f1239;
}

.reports-index-section--collections .reports-index-group {
  background: #fff1f2;
  border-color: #fecdd3;
}

.reports-index-section--operations .reports-index-heading {
  color: #1e3a8a;
}

.reports-index-section--operations .reports-index-group {
  background: #eff6ff;
  border-color: #bfdbfe;
}

.reports-index-row {
  text-decoration: none;
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  padding: 8px 10px;
  min-height: 52px;
  background: transparent;
}

.reports-index-row + .reports-index-row {
  border-top: 1px solid rgba(148, 163, 184, 0.26);
}

.reports-index-row:hover,
.reports-index-row:focus-visible {
  background: rgba(255, 255, 255, 0.5);
  box-shadow: inset 0 0 0 1px rgba(59, 130, 246, 0.2);
}

.reports-index-row-main {
  min-width: 0;
  display: grid;
  gap: 1px;
}

.reports-index-row-title {
  margin: 0;
  color: var(--lt-text-strong);
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1.25;
}

.reports-index-row-subtitle {
  margin: 0;
  font-size: 0.77rem;
  color: var(--lt-text-muted);
  line-height: 1.3;
}

.reports-index-row-metric {
  font-weight: 700;
  color: var(--lt-text-strong);
}

.reports-index-chevron {
  color: #64748b;
  font-size: 1rem;
  font-weight: 800;
}

.outstanding-balances-header {
  margin-bottom: 0;
  display: grid;
  gap: 8px;
}

.outstanding-balances-summary-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.outstanding-toolbar {
  display: grid;
  gap: 6px;
  justify-items: start;
}

.outstanding-primary-cta {
  min-height: 34px;
  font-size: 0.8rem;
  padding: 6px 10px;
}

.outstanding-tools-menu {
  position: relative;
}

.outstanding-tools-menu summary {
  list-style: none;
  cursor: pointer;
  border: 1px solid var(--lt-border-muted);
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 0.78rem;
  font-weight: 700;
  color: #1e40af;
  background: #eff6ff;
}

.outstanding-tools-menu summary::-webkit-details-marker {
  display: none;
}

.outstanding-tools-dropdown {
  margin-top: 6px;
  border: 1px solid var(--lt-border-muted);
  border-radius: 10px;
  background: var(--lt-surface);
  display: grid;
  min-width: 220px;
  overflow: hidden;
}

.outstanding-tools-link {
  font-size: 0.78rem;
  font-weight: 600;
  color: #1e293b;
  text-decoration: none;
  padding: 8px 10px;
  border-bottom: 1px solid var(--lt-border-muted);
}

.outstanding-tools-link:last-child {
  border-bottom: 0;
}

.outstanding-tools-link:hover,
.outstanding-tools-link:focus-visible {
  background: #f8fafc;
}

.outstanding-filter-form {
  margin: 0;
}

.compact-select {
  min-height: 34px;
  font-size: 0.8rem;
  padding-top: 5px;
  padding-bottom: 5px;
}

.outstanding-summary-pill {
  border: 1px solid var(--lt-border-muted);
  border-radius: 10px;
  background: var(--lt-surface);
  padding: 8px;
  min-height: 0;
}

.outstanding-summary-pill--danger {
  border-color: #fca5a5;
  background: #fff1f2;
}

.outstanding-summary-pill--success {
  border-color: #86efac;
  background: #f0fdf4;
}

.outstanding-summary-label {
  margin: 0;
  color: var(--lt-text-muted);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.outstanding-summary-value {
  margin: 3px 0 0;
  color: var(--lt-text-strong);
  font-size: clamp(0.95rem, 3.8vw, 1.2rem);
  font-weight: 800;
}

.outstanding-summary-detail {
  margin: 2px 0 0;
  color: var(--lt-text-muted);
  font-size: 0.72rem;
}

.outstanding-list-section {
  margin-top: 2px;
}

.outstanding-list {
  display: grid;
  gap: 6px;
}

.outstanding-row {
  border: 1px solid var(--lt-border-muted);
  border-radius: 10px;
  background: var(--lt-surface);
  padding: 9px 10px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 6px 10px;
  position: relative;
}

.outstanding-row-link {
  position: absolute;
  inset: 0;
  border-radius: 10px;
  z-index: 1;
}

.outstanding-row-link:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

.outstanding-row-main {
  display: grid;
  gap: 2px;
  min-width: 0;
  position: relative;
  z-index: 2;
}

.outstanding-row-side {
  text-align: right;
  display: grid;
  gap: 2px;
  align-content: start;
  justify-items: end;
  position: relative;
  z-index: 2;
}

.outstanding-customer-name {
  margin: 0;
  font-weight: 700;
  color: var(--lt-text-strong);
}

.outstanding-customer-supporting,
.outstanding-balance-label {
  margin: 0;
  color: var(--lt-text-muted);
  font-size: 0.8rem;
}

.outstanding-balance-value {
  margin: 0;
  font-size: 1rem;
  font-weight: 800;
  color: #b91c1c;
}

.outstanding-balance-value--success {
  color: #166534;
}

.outstanding-reminder-status {
  margin: 1px 0 0;
  font-size: 0.72rem;
  font-weight: 700;
}

.outstanding-reminder-status.is-ready {
  color: #166534;
}

.outstanding-reminder-status.is-unavailable {
  color: #92400e;
}

.outstanding-row-chevron {
  color: #64748b;
  font-size: 1rem;
  font-weight: 700;
}

.outstanding-row-actions {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  align-items: center;
  grid-column: 1 / -1;
  position: relative;
  z-index: 2;
  margin-top: 2px;
}

.outstanding-action-primary,
.outstanding-action-secondary {
  min-height: 31px;
  font-size: 0.74rem;
  padding: 5px 9px;
}

.outstanding-row-actions form {
  margin: 0;
}

.outstanding-footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 12px;
  margin-top: 2px;
}

.outstanding-footer-link {
  font-size: 0.84rem;
  font-weight: 700;
  color: #1d4ed8;
  text-decoration: none;
}

.outstanding-footer-link:hover,
.outstanding-footer-link:focus-visible {
  text-decoration: underline;
}

@media (max-width: 640px) {
  .outstanding-balances-summary-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .outstanding-tools-dropdown {
    min-width: 0;
    width: min(92vw, 300px);
  }
}

.outstanding-income-toolbar {
  display: flex;
  gap: 10px;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.outstanding-income-filter {
  display: flex;
  gap: 8px;
  align-items: flex-end;
  flex-wrap: wrap;
}

.outstanding-income-filter-label {
  font-weight: 700;
  font-size: 0.82rem;
}

.outstanding-income-filter .form-control {
  min-width: 120px;
}

.outstanding-income-value {
  font-weight: 700;
  color: var(--lt-success-text);
}

@media (max-width: 960px) {
  .business-tools-ops-grid,
  .business-tools-command-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .business-tools-ops-grid--lean {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .business-tools-quick-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 700px) {
  .business-tools-ops-grid,
  .business-tools-command-grid,
  .business-tools-quick-grid {
    grid-template-columns: 1fr;
  }

  .business-tools-quick-btn {
    justify-content: flex-start;
    padding-left: 12px;
  }

  .business-hub-grid {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 700px) {
  .outstanding-balances-header {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
  }

  .outstanding-toolbar {
    justify-items: end;
  }

  .outstanding-row {
    grid-template-columns: minmax(0, 1.3fr) auto minmax(0, 1.4fr);
    align-items: center;
    gap: 10px;
  }

  .outstanding-row-actions {
    justify-content: flex-end;
  }
}

.expense-form-grid {
  margin-top: 14px;
  display: grid;
  gap: 10px;
}

.field-label {
  display: block;
  margin-bottom: 4px;
  font-weight: 700;
  color: var(--lt-text-primary);
  font-size: 14px;
}

.field-input {
  width: 100%;
  padding: 10px 11px;
  border: 1px solid var(--lt-field-border);
  border-radius: var(--lt-radius-sm);
  font: inherit;
  min-height: 42px;
  background: var(--lt-field-bg);
  color: var(--lt-text-primary);
}

.field-input:focus,
.form-control:focus {
  border-color: #16a34a;
  box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.16);
  outline: none;
}

.segmented-tabs {
  display: inline-grid;
  grid-auto-flow: column;
  gap: 4px;
  padding: 4px;
  border: 1px solid #d6e2dc;
  border-radius: 999px;
  background: #edf4ef;
}

.segmented-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 7px 12px;
  border-radius: 999px;
  color: #334155;
  text-decoration: none;
  font-weight: 700;
}

.segmented-tab.is-active {
  background: var(--lt-surface);
  color: #14532d;
  box-shadow: var(--lt-shadow-sm);
}

.app-alert {
  border: 1px solid #bfdbfe;
  background: #eff6ff;
  color: #1e3a8a;
  border-radius: var(--lt-radius-md);
  padding: 10px 12px;
}

.app-alert--success {
  border-color: #86efac;
  background: #ecfdf5;
  color: #166534;
}

.app-alert--danger {
  border-color: #fecaca;
  background: #fef2f2;
  color: #991b1b;
}

.empty-state {
  text-align: center;
  border: 1px dashed var(--lt-empty-border);
  background: var(--lt-empty-bg);
  border-radius: var(--lt-radius-lg);
  padding: 13px 12px;
}

.empty-state-title {
  margin: 0;
  font-size: 1.1rem;
  color: var(--lt-text-strong);
}

.empty-state-text {
  margin: 4px 0 0;
  color: var(--lt-text-muted);
}
.empty-state-actions {
  margin-top: 8px;
  display: inline-flex;
  justify-content: center;
}

.empty-state-actions form {
  margin: 0;
}


.modal-panel {
  background: var(--lt-card-bg);
  border-radius: var(--lt-radius-lg);
  border: 1px solid var(--lt-card-border);
  box-shadow: var(--lt-shadow-lg);
  padding: clamp(13px, 2.4vw, 18px);
}

.field-help {
  margin: 6px 0 0;
  font-size: 12px;
  line-height: 1.4;
  color: var(--lt-text-muted);
}

@media (max-width: 768px) {
  .app-topbar-inner {
    min-height: 48px;
    width: min(1100px, calc(100% - 20px));
    grid-template-columns: 38px minmax(0, 1fr) 38px;
    gap: 5px;
  }

  .app-menu-button,
  .app-drawer-close,
  .app-topbar-spacer {
    width: 38px;
    height: 38px;
  }

  .app-title {
    font-size: 0.92rem;
  }

  .app-topbar-action {
    min-height: 28px;
    padding: 4px 8px;
    font-size: 0.7rem;
  }

  .app-topbar-action--icon {
    width: 32px;
    min-height: 32px;
    font-size: 1rem;
  }

  .page-wrap {
    width: min(1100px, calc(100% - 22px));
    margin-top: 6px;
  }

  .page-header {
    gap: 7px;
    margin-bottom: 4px;
  }

  .page-header h1 {
    font-size: clamp(1.22rem, 4.8vw, 1.5rem);
  }

  .page-subtitle {
    font-size: 0.82rem;
  }

  .workflow-actions .btn-primary,
  .workflow-actions .btn-secondary,
  .workflow-actions .btn-success,
  .workflow-actions .btn-info,
  .workflow-actions .btn-danger {
    min-height: 32px;
    padding: 6px 9px;
    font-size: 0.8rem;
  }

  .hide-mobile {
    display: none !important;
  }

  .hide-desktop {
    display: block;
  }

  .btn-primary,
  .btn-secondary,
  .btn-success,
  .btn-info,
  .btn-danger {
    width: 100%;
    text-align: center;
  }

  .workflow-actions,
  .actions-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .business-tools-quick-grid,
  .business-tools-compact-grid,
  .business-tools-insights-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .business-tools-upgrade-banner {
    flex-direction: column;
    align-items: flex-start;
  }

  .business-tools-upgrade-prompt {
    flex-direction: column;
    align-items: flex-start;
  }

  .tax-strategy-entry-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .tax-strategy-remove {
    width: 100%;
  }

  .customer-edit-grid--address {
    grid-template-columns: 1fr;
  }

  .topbar-inner {
    padding-top: env(safe-area-inset-top, 0px);
  }

  .owner-nav {
    width: min(560px, 100%);
    margin-inline: auto;
  }

  .owner-nav-link,
  .owner-nav-more-toggle {
    min-height: 44px;
    font-size: 0.92rem;
  }

  .owner-nav-dropdown {
    width: 100%;
    min-width: 0;
    padding: 10px;
    gap: 6px;
  }

  .owner-nav-dropdown-link,
  .logout-button-inline {
    min-height: 40px;
    padding: 10px 12px;
    font-size: 0.95rem;
  }

  .crew-nav {
    display: grid;
    grid-template-columns: 1fr;
  }

  .nav-links {
    width: 100%;
  }

  .nav-link,
  .logout-button {
    flex: 1 1 calc(50% - 10px);
    text-align: center;
  }
}

@media (max-width: 700px) {
  .topbar-inner {
    padding-top: env(safe-area-inset-top, 0px);
  }

  .nav-links-primary {
    width: 100%;
    justify-content: flex-start;
  }

  .page-header h1 {
    font-size: 28px;
  }

  .brand-title {
    font-size: 2rem;
  }

  .metric-value-line {
    font-size: 18px;
  }

  .metric-supporting-text {
    font-size: 12px;
  }

  .brand-logo {
    width: 78px;
  }

  .business-overview-shell .actions-row,
  .home-quick-track-actions,
  .home-pro-crew-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .business-overview-shell .actions-row > *,
  .home-quick-track-actions > *,
  .home-pro-crew-actions > *,
  .hub-shell .actions-row > * {
    width: 100%;
    box-sizing: border-box;
    text-align: center;
  }

  .business-overview-shell .table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .business-overview-shell table {
    min-width: 680px;
  }

  .business-overview-shell table.data-table,
  .business-overview-shell table.assignment-table {
    min-width: 0;
  }

  .home-quick-track { padding: 10px; }

  .home-quick-track-compact {
    flex-direction: column;
    align-items: stretch;
  }

  .home-secondary-actions .btn-small {
    flex: 1 1 calc(50% - 6px);
  }

  .quick-links-customize-item {
    padding: 7px;
  }

  .home-field-snapshot {
    gap: 8px;
  }

  .home-field-snapshot-action {
    width: auto;
    display: inline-flex;
  }

  .home-field-snapshot-note {
    padding: 4px 6px;
    font-size: 10px;
  }

  .home-command-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .home-feature-card-title {
    font-size: 1rem;
  }

  .home-feature-card-description {
    font-size: 13px;
  }

  .home-pro-crew-hub .home-feature-card-title {
    font-size: 26px;
  }

  .home-pro-crew-hub .home-feature-card-description {
    font-size: 15px;
  }

  .home-bottom-actions > * {
    max-width: none;
  }

  .home-setup-checklist { padding: 12px; }

  .home-setup-item {
    grid-template-columns: auto 1fr;
  }

  .home-setup-item-action {
    grid-column: 1 / -1;
    width: 100%;
    text-align: center;
  }

  .home-priority-item {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }

  .home-priority-item .btn-secondary,
  .home-priority-item .btn-danger {
    width: 100%;
    text-align: center;
  }

  .route-templates-wrap {
    overflow: visible;
  }

  .route-templates-table,
  .crew-members-table {
    min-width: 0 !important;
    margin-top: 0;
    background: transparent;
  }

  .route-templates-table thead,
  .crew-members-table thead {
    display: none;
  }

  .route-templates-table tbody,
  .route-templates-table tr,
  .route-templates-table td,
  .crew-members-table tbody,
  .crew-members-table tr,
  .crew-members-table td {
    display: block;
    width: 100%;
    box-sizing: border-box;
  }

  .route-templates-table tr,
  .crew-members-table tr {
    background: #ffffff;
    border: 1px solid #dbe3ec;
    border-radius: 14px;
    padding: 10px 12px;
    margin-bottom: 12px;
  }

  .route-templates-table td,
  .crew-members-table td {
    border: 0;
    border-bottom: 1px solid #eef2f7;
    padding: 10px 0;
    margin: 0;
  }

  .route-templates-table td:last-child,
  .crew-members-table td:last-child {
    border-bottom: 0;
    padding-bottom: 0;
  }

  .route-templates-table td::before,
  .crew-members-table td::before {
    content: attr(data-label);
    display: block;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: #64748b;
    margin-bottom: 4px;
  }

  .data-table,
  .assignment-table {
    min-width: 0 !important;
    margin-top: 0;
    background: transparent;
  }

  .data-table thead,
  .assignment-table thead {
    display: none;
  }

  .data-table tbody,
  .data-table tr,
  .data-table td,
  .assignment-table tbody,
  .assignment-table tr,
  .assignment-table td {
    display: block;
    width: 100%;
    box-sizing: border-box;
  }

  .data-table tr,
  .assignment-table tr {
    background: #ffffff;
    border: 1px solid #dbe3ec;
    border-radius: 14px;
    padding: 10px 12px;
    margin-bottom: 12px;
  }

  .data-table td,
  .assignment-table td {
    border: 0;
    border-bottom: 1px solid #eef2f7;
    padding: 10px 0;
    margin: 0;
  }

  .data-table td:last-child,
  .assignment-table td:last-child {
    border-bottom: 0;
    padding-bottom: 0;
  }

  .data-table td::before,
  .assignment-table td::before {
    content: attr(data-label);
    display: block;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: #64748b;
    margin-bottom: 4px;
  }

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

.auth-shell {
  width: min(100%, 660px);
  margin: 0 auto;
}

.auth-card {
  background: var(--lt-surface);
  border: 1px solid var(--lt-border-muted);
  border-radius: 18px;
  padding: clamp(14px, 3vw, 26px);
}

.form-grid {
  display: grid;
  gap: 10px;
}

.form-row {
  display: grid;
  gap: 6px;
}

.form-row label {
  font-weight: 700;
}

.form-control {
  width: 100%;
  border: 1px solid var(--lt-field-border);
  border-radius: 10px;
  padding: 10px 11px;
  font-size: 16px;
  background: var(--lt-field-bg);
  color: var(--lt-text-primary);
}

.business-profile-shell {
  width: min(100%, 760px);
  margin: 0 auto;
}

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

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

.business-profile-panel-title {
  margin: 0;
  font-size: 1rem;
  color: var(--lt-text-strong);
}

.business-profile-location-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.business-profile-state-input {
  text-transform: uppercase;
}

.business-profile-checkbox-row {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
}

.business-profile-legacy-address {
  margin: 0;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--lt-border-muted);
  background: var(--lt-surface-muted);
  color: #374151;
  font-size: 0.9rem;
}

.business-profile-gps-card {
  border: 1px solid #dbe5df;
  border-radius: 12px;
  background: #f8fbf9;
  padding: 12px;
  display: grid;
  gap: 8px;
}

.business-profile-gps-title {
  margin: 0;
  font-weight: 700;
  color: var(--lt-text-strong);
}

.business-profile-gps-copy,
.business-profile-home-base-help {
  margin: 0;
  color: var(--lt-text-muted);
  font-size: 0.9rem;
}

.business-profile-home-base-status {
  margin: 2px 0 0;
  font-weight: 700;
  color: var(--lt-text-primary);
}

.business-profile-error-banner {
  border: 1px solid #fecaca;
  border-radius: 12px;
  background: #fef2f2;
  color: #991b1b;
  padding: 12px;
}

.business-profile-error-title {
  margin: 0;
  font-weight: 700;
}

.business-profile-error-list {
  margin: 10px 0 0 18px;
  padding: 0;
}

.appearance-shell {
  width: min(100%, 680px);
  margin: 0 auto;
}

.appearance-form {
  display: grid;
  gap: 14px;
}

.appearance-options {
  margin: 0;
  padding: 0;
  border: 0;
  display: grid;
  gap: 10px;
}

.appearance-options legend {
  margin-bottom: 4px;
  font-weight: 700;
  color: var(--lt-text-primary);
}

.appearance-option {
  border: 1px solid var(--lt-border);
  border-radius: 12px;
  background: var(--lt-surface-muted);
  padding: 10px 12px;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
}

.appearance-option:has(input:checked) {
  border-color: var(--lt-accent-border);
  background: var(--lt-accent-bg);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--lt-brand-700) 18%, transparent);
}

.appearance-option input {
  margin-top: 3px;
  accent-color: var(--lt-brand-700);
}

.appearance-option span {
  display: grid;
  gap: 4px;
}

.appearance-option strong {
  color: var(--lt-text-primary);
}

.appearance-option small {
  color: var(--lt-text-muted);
  font-size: 0.85rem;
}

@media (max-width: 640px) {
  .business-profile-location-grid {
    grid-template-columns: 1fr;
  }
}

.password-field-wrap {
  position: relative;
}

.password-field-wrap .form-control {
  padding-right: 88px;
}

.password-toggle-button {
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
  border: 1px solid var(--lt-field-border);
  background: var(--lt-field-bg);
  color: var(--lt-text-primary);
  border-radius: 10px;
  padding: 5px 9px;
  font-weight: 700;
  min-width: 58px;
}

[data-theme-resolved="dark"] .field-input::placeholder,
[data-theme-resolved="dark"] .form-control::placeholder {
  color: color-mix(in srgb, var(--lt-text-muted) 92%, transparent);
}

.footer-links {
  margin-top: 22px;
  padding-top: 14px;
  border-top: 1px solid var(--lt-border-muted);
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.invoice-page { min-height: 100vh; padding: 20px 14px 34px; background: #eef2f7; }
.invoice-shell { width: min(100%, 980px); margin: 0 auto; background: #ffffff; border: 1px solid var(--lt-border-muted); border-radius: 20px; box-shadow: 0 18px 45px rgba(15, 23, 42, 0.10); padding: clamp(16px, 3vw, 36px); }
.invoice-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 20px; margin-bottom: 24px; }
.invoice-heading { margin: 0; font-size: clamp(30px, 5vw, 40px); line-height: 1.1; color: var(--lt-text-primary); }
.invoice-meta { margin-top: 12px; display: grid; gap: 8px; color: var(--lt-text-muted); font-size: 15px; }
.invoice-meta-row { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.invoice-meta-label { font-weight: 700; color: var(--lt-text-primary); }
.invoice-actions { display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.invoice-button { min-height: 46px; min-width: 126px; }
.invoice-button-send { background: var(--lt-brand-700); color: #ffffff; }
.invoice-button-send:hover { background: var(--lt-brand-700); }
.invoice-button-print { background: #2563eb; color: #ffffff; }
.invoice-button-print:hover { background: #1d4ed8; }
.invoice-party-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; margin-bottom: 24px; }
.invoice-panel { border: 1px solid var(--lt-border-muted); border-radius: 16px; background: var(--lt-surface-muted); padding: 16px; }
.invoice-panel-title { margin: 0 0 10px; font-size: 13px; text-transform: uppercase; letter-spacing: 0.08em; color: #4b5563; }
.invoice-panel p { margin: 0 0 6px; }
.invoice-panel p:last-child { margin-bottom: 0; }
.invoice-preserve-lines { white-space: pre-line; }
.invoice-items-wrap { margin-top: 8px; }
.invoice-table-shell { border: 1px solid var(--lt-border-muted); border-radius: 14px; overflow: hidden; }
.invoice-items-table { width: 100%; border-collapse: collapse; table-layout: fixed; }
.invoice-items-table th, .invoice-items-table td { padding: 12px; border-bottom: 1px solid var(--lt-border-muted); vertical-align: top; }
.invoice-items-table th { background: #111827; color: #f9fafb; font-size: 12px; letter-spacing: 0.04em; text-transform: uppercase; text-align: left; }
.invoice-items-table tbody tr:last-child td { border-bottom: none; }
.invoice-col-address { width: 48%; }
.invoice-col-cuts { width: 10%; }
.invoice-col-rate, .invoice-col-total { width: 21%; }
.invoice-line-address { font-weight: 700; color: var(--lt-text-primary); margin-bottom: 8px; overflow-wrap: anywhere; }
.invoice-cut-dates { margin: 0; padding-left: 18px; color: var(--lt-text-muted); font-size: 13px; }
.invoice-cut-dates li { margin-bottom: 3px; }
.invoice-cut-dates li:last-child { margin-bottom: 0; }
.invoice-money, .invoice-cuts-value { text-align: right; white-space: nowrap; font-variant-numeric: tabular-nums; }
.invoice-total-card { margin-top: 18px; margin-left: auto; width: min(100%, 330px); border-radius: 16px; border: 1px solid #bfdbfe; background: linear-gradient(180deg, #eff6ff 0%, #f8fafc 100%); padding: 16px; }
.invoice-total-label { margin: 0; font-size: 13px; text-transform: uppercase; letter-spacing: 0.08em; color: #374151; }
.invoice-total-amount { margin: 6px 0 0; font-size: clamp(26px, 5vw, 34px); line-height: 1.1; color: var(--lt-text-strong); font-variant-numeric: tabular-nums; }
.invoice-note { margin-top: 14px; color: #4b5563; font-size: 14px; }
.invoice-footer { margin-top: 22px; border-top: 1px solid var(--lt-border-muted); padding-top: 18px; }
.invoice-mobile-cards { display: none; gap: 12px; }
.invoice-mobile-item { border: 1px solid var(--lt-border-muted); border-radius: 14px; padding: 14px; background: var(--lt-surface); }
.invoice-mobile-row { display: flex; justify-content: space-between; gap: 12px; padding: 4px 0; }
.invoice-mobile-label { color: var(--lt-text-muted); font-size: 13px; }
.invoice-mobile-value { text-align: right; font-weight: 700; font-variant-numeric: tabular-nums; white-space: nowrap; }

.deduction-tool-shell {
  border: 1px solid #dbeafe;
  border-radius: 16px;
  padding: 16px;
  background: #f8fbff;
}

.deduction-tool-help {
  margin: 8px 0 14px;
}

.tax-projection-input-grid {
  margin-top: 12px;
}

#tax-projection .field-input {
  max-width: 220px;
}

#tax-projection .deduction-breakdown-value {
  font-size: 26px;
}

.vehicle-method-grid {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

#tax-projection .metric-detail strong {
  color: var(--lt-text-strong);
}

@media (max-width: 760px) {
  #tax-projection .field-input {
    max-width: 100%;
  }
}

@media (max-width: 900px) {
  .invoice-page { padding-left: 10px; padding-right: 10px; }
  .invoice-header { flex-direction: column; }
  .invoice-actions { justify-content: flex-start; width: 100%; }
}

@media (max-width: 760px) {
  .card-shell { padding: 16px 14px; }
  .page-wrap { width: calc(100% - 32px); padding: 16px 0 28px; }
  .invoice-party-grid { grid-template-columns: 1fr; }
  .invoice-table-shell { display: none; }
  .invoice-mobile-cards { display: grid; }
  .invoice-total-card { width: 100%; }
}

@media print {
  @page { size: auto; margin: 0.55in; }
  nav, header, .topbar, .page-back-link, .no-print, .invoice-actions, .invoice-note, .invoice-footer { display: none !important; }
  body, body.app-body { background: #ffffff !important; margin: 0 !important; padding: 0 !important; }
  .page-wrap { max-width: none !important; padding: 0 !important; margin: 0 !important; }
  .invoice-page { background: #fff !important; padding: 0 !important; min-height: auto !important; }
  .invoice-shell { width: 100% !important; border: none !important; border-radius: 0 !important; box-shadow: none !important; padding: 0 !important; }
  .invoice-panel, .invoice-table-shell, .invoice-mobile-item, .invoice-total-card, .invoice-items-table tr, .invoice-items-table td, .invoice-items-table th { break-inside: avoid; page-break-inside: avoid; background: #fff !important; }
  .invoice-items-table th { color: var(--lt-text-primary); border-bottom: 1px solid #111827; }
  .invoice-mobile-cards { display: none !important; }
}

.customers-shell {
  display: grid;
  gap: 10px;
}

.customers-summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

.customers-summary-card {
  border: 1px solid var(--lt-border-muted);
  border-radius: 14px;
  padding: 14px;
  background: var(--lt-surface-muted);
}

.customers-summary-card-action {
  text-decoration: none;
  color: inherit;
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.customers-summary-card-action:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

.customers-summary-card-action:hover,
.customers-summary-card-action:active {
  transform: translateY(-1px);
  border-color: #bfdbfe;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08);
}

.customers-summary-action {
  margin: 10px 0 0;
  color: var(--lt-text-muted);
  font-size: 12px;
  font-weight: 700;
}

.customers-summary-label {
  margin: 0;
  color: var(--lt-text-muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 700;
}

.customers-summary-value {
  margin: 6px 0 0;
  font-size: 24px;
  font-weight: 800;
  color: var(--lt-text-strong);
}

.customers-summary-value-warning {
  color: #b91c1c;
}

.customers-control-shell {
  display: grid;
  gap: 8px;
  border-bottom: 1px solid #e2e8f0;
  padding: 8px 0 12px;
  background: transparent;
}

.customers-search-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 6px;
}

.customers-search-input,
.customers-select-input {
  width: 100%;
  border: 1px solid var(--lt-field-border);
  border-radius: 10px;
  padding: 8px 10px;
  font: inherit;
  background: #ffffff;
  color: var(--lt-text-primary);
}

.customers-search-submit {
  white-space: nowrap;
  min-height: 40px;
  padding: 0 12px;
}

.customers-filters,
.customers-view-toggle {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 2px;
}

.customers-chip {
  border: 1px solid var(--lt-field-border);
  border-radius: 999px;
  padding: 5px 10px;
  text-decoration: none;
  color: var(--lt-text-primary);
  font-size: 11px;
  font-weight: 700;
  background: var(--lt-surface-muted);
  white-space: nowrap;
  transition: all 0.15s ease;
}

.customers-chip.is-active {
  color: var(--lt-nav-active-text);
  border-color: var(--lt-nav-active-border);
  background: var(--lt-nav-active-bg);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--lt-nav-active-border) 55%, transparent);
}

.customers-chip:hover {
  border-color: var(--lt-border);
  background: var(--lt-surface);
}

.customers-toolbar-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.customers-select-form {
  display: flex;
  align-items: center;
  gap: 8px;
}

.customers-select-label {
  font-size: 13px;
  font-weight: 700;
  color: #334155;
}

.customers-empty-state {
  border: 1px dashed var(--lt-empty-border);
  border-radius: 16px;
  padding: 26px 22px;
  background: radial-gradient(circle at top right, color-mix(in srgb, var(--lt-nav-active-bg) 75%, transparent) 0%, var(--lt-empty-bg) 45%, var(--lt-card-bg) 100%);
}

.customers-results-header {
  display: flex;
  gap: 8px;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}

.customers-results-count {
  margin: 0;
  color: var(--lt-text-muted);
  font-size: 14px;
}

.customers-results-count strong {
  color: var(--lt-text-strong);
}

.customers-add-cta {
  box-shadow: 0 8px 16px rgba(37, 99, 235, 0.15);
}

.customers-empty-state h3 {
  margin: 0 0 8px;
}

.customers-empty-state p {
  margin-top: 0;
  color: var(--lt-text-muted);
}

.customers-card {
  border: 1px solid var(--lt-border-muted);
  border-radius: 16px;
  padding: 20px;
  background: var(--lt-surface);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.05);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.customers-card:hover {
  border-color: #cbd5e1;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

.customers-card.is-owing,
.customers-group-row.is-owing {
  border-color: #fca5a5;
  background: linear-gradient(180deg, #fff, #fffbfb);
}

.customers-card-header {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: flex-start;
}

.customers-name {
  margin: 0;
  font-size: 17px;
  font-weight: 800;
  color: var(--lt-text-strong);
}

.customers-contact-line {
  margin: 6px 0 0;
  color: var(--lt-text-muted);
  font-size: 14px;
}

.customers-balance-block {
  text-align: right;
}

.customers-balance-label {
  margin: 0;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--lt-text-muted);
}

.customers-balance-value {
  margin: 6px 0 0;
  font-size: 24px;
  font-weight: 900;
  color: var(--lt-text-strong);
}

.customers-balance-value.is-owing,
.customers-balance-inline.is-owing {
  color: #b91c1c;
}

.customers-contact-meta {
  margin-top: 12px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.customers-contact-pill,
.customers-balance-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 700;
}

.customers-contact-pill.is-present {
  background: #ecfdf5;
  color: #166534;
}

.customers-contact-pill.is-missing {
  background: #fff7ed;
  color: #c2410c;
}

.customers-balance-pill.is-owing {
  background: #fee2e2;
  color: #991b1b;
}

.customers-balance-pill.is-clear {
  background: #dcfce7;
  color: #166534;
}

.customers-actions-row {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid #e2e8f0;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.customer-detail-shell .workflow-header {
  gap: 8px;
}

.customer-detail-shell .workflow-actions {
  gap: 6px;
}

.customer-priority-strip {
  display: flex;
  gap: 10px;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
}

.customer-priority-balance {
  min-width: 220px;
}

.customer-priority-label {
  margin: 0;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--lt-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.customer-priority-amount {
  margin: 2px 0;
  font-size: clamp(1.5rem, 5vw, 2rem);
  line-height: 1.1;
  font-weight: 900;
  color: var(--lt-text-strong);
}

.customer-priority-support {
  margin: 0;
  font-size: 0.85rem;
  color: var(--lt-text-muted);
}

.customer-priority-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.customer-priority-actions .btn-success,
.customer-priority-actions .btn-primary,
.customer-priority-actions .btn-secondary {
  min-height: 40px;
}

.customer-actions-row {
  margin-top: 8px;
  padding-top: 0;
  border-top: 0;
}

.customer-actions-row--primary {
  margin-top: 12px;
}

.customer-actions-row--tight {
  margin-top: 6px;
}

.customer-actions-row .btn-primary,
.customer-actions-row .btn-secondary,
.customer-actions-row .btn-success,
.customer-actions-row .btn-danger,
.customer-actions-row button {
  min-height: 34px;
  padding: 6px 10px;
  font-size: 0.82rem;
}

.customer-section-title {
  margin: 0;
  font-size: 1.1rem;
}

.customer-section-heading {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.customer-compact-list {
  margin-top: 8px;
  border-top: 1px solid var(--lt-border-muted);
}

.customer-list-row {
  padding: 10px 2px;
  border-bottom: 1px solid var(--lt-border-muted);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

.customer-row-title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--lt-text-strong);
}

.customer-row-detail {
  margin: 2px 0 0;
  font-size: 0.85rem;
  color: var(--lt-text-muted);
}

.customer-row-link {
  text-decoration: none;
  font-weight: 700;
}

.customer-row-emphasis {
  margin: 0;
  font-size: 1rem;
  font-weight: 800;
  color: var(--lt-text-strong);
}

.customer-row-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.customer-inline-action {
  min-height: 32px;
  padding: 5px 9px;
  font-size: 0.78rem;
}

.customer-inline-form {
  margin-top: 7px;
  display: flex;
  gap: 7px;
  flex-wrap: wrap;
  align-items: center;
}

.customer-inline-form .field-input {
  min-width: 230px;
}

.customer-more-details {
  margin-top: 8px;
}

.customer-more-details > summary {
  color: var(--lt-text-strong);
  font-size: 0.85rem;
  font-weight: 700;
  margin-bottom: 8px;
}


.customer-edit-form {
  display: grid;
  gap: 4px;
}

.customer-new-shell {
  max-width: 760px;
  margin: 0 auto;
}

.customer-new-form {
  display: grid;
  gap: 2px;
}

.customer-edit-grid {
  margin-top: 8px;
  display: grid;
  gap: 10px;
}

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

.customer-edit-yards {
  margin-top: 10px;
  display: grid;
  gap: 10px;
}

.customer-edit-yard-card {
  border: 1px solid var(--lt-border-muted);
  border-radius: var(--lt-radius-md);
  padding: 10px;
  background: var(--lt-surface-muted);
}

.customer-edit-yard-card .field-label {
  margin-top: 8px;
}

.customer-new-shell .customer-edit-yard-card .field-label:first-of-type {
  margin-top: 6px;
}

.customer-danger-zone {
  margin-top: 16px;
}

.customer-danger-card {
  border-color: #fecaca;
  background: #fff7f7;
}

.customer-danger-card h2 {
  margin: 0 0 8px;
  color: #991b1b;
}

.customer-danger-card p {
  margin: 0;
  color: #7f1d1d;
}

.customer-danger-card .customer-actions-row {
  margin-top: 10px;
}

.customers-action-primary {
  padding: 10px 14px;
}

.customers-action-secondary {
  padding: 10px 12px;
}

.customers-compact-table-wrap {
  overflow-x: auto;
}

.customers-compact-table th,
.customers-compact-table td {
  vertical-align: middle;
}

.customers-compact-table tr.is-owing td {
  background: #fffbfb;
}

.customers-row-name {
  font-weight: 800;
  text-decoration: none;
  color: var(--lt-text-strong);
}

.customers-inline-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.customers-grouped-list {
  display: grid;
  gap: 18px;
}

.customers-group-section > h3 {
  margin: 0 0 10px;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--lt-text-muted);
}

.customers-group-row {
  border: 1px solid var(--lt-border-muted);
  border-radius: 14px;
  padding: 14px;
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
  background: var(--lt-surface);
}

.customers-balance-inline {
  margin: 0 0 8px;
  font-size: 18px;
  font-weight: 800;
  text-align: right;
}

@media (max-width: 768px) {
  .customers-control-shell {
    padding: 12px;
  }

  .customers-search-form {
    grid-template-columns: 1fr;
  }

  .customers-toolbar-row,
  .customers-select-form {
    display: grid;
    width: 100%;
  }

  .customers-card-header,
  .customers-group-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .customers-balance-block,
  .customers-balance-inline,
  .customers-inline-actions {
    text-align: left;
    justify-content: flex-start;
  }

  .customers-action-primary,
  .customers-action-secondary {
    flex: 1 1 calc(50% - 6px);
    text-align: center;
  }

  .customers-compact-table {
    min-width: 760px;
  }

  .customers-add-cta {
    width: 100%;
    text-align: center;
  }

  .customer-actions-row > * {
    flex: 1 1 calc(50% - 6px);
    text-align: center;
  }

  .customer-list-row {
    align-items: flex-start;
    flex-direction: column;
  }

  .customer-row-actions {
    justify-content: flex-start;
  }
}

/* Pro Crew Operations Dashboard compact command center */
.operations-hub-shell .workflow-header { gap: 8px; }
.operations-hub-shell .page-back-link { margin-bottom: 4px; font-size: 0.9rem; }
.operations-hub-shell .page-subtitle { margin-top: 4px; margin-bottom: 0; }
.operations-hub-shell .section-divider { margin-top: 14px; padding-top: 14px; }
.compact-section-header h2 { margin: 0; font-size: 1.15rem; color: var(--lt-text-primary); }
.compact-section-header p { margin: 4px 0 0; font-size: 0.9rem; color: var(--lt-text-muted); }
.operations-quick-actions { padding: 10px; }
.quick-actions-grid { margin-top: 8px; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 7px; }
.quick-actions-grid a, .quick-actions-grid summary { text-align: center; font-size: 0.82rem; padding: 7px; min-height: 36px; }
.quick-action-primary { font-weight: 800; }
.quick-actions-more { grid-column: 1 / -1; }
.quick-actions-more summary { list-style: none; cursor: pointer; border: 1px solid var(--lt-border-muted); border-radius: 10px; background: var(--lt-surface); color: #374151; font-weight: 700; }
.quick-actions-more summary::-webkit-details-marker { display: none; }
.quick-actions-more-grid { margin-top: 6px; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 7px; }
.operations-kpi-grid { margin-top: 14px; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
.metric-card-compact { border-radius: 12px; padding: 12px; }
.metric-value-compact { margin: 8px 0 0; font-size: clamp(1.2rem, 3.8vw, 1.8rem); line-height: 1.15; }
.metric-empty-note { font-size: 0.8rem; color: var(--lt-text-muted); }
.operations-accordion-stack { margin-top: 8px; gap: 7px; padding-bottom: 72px; }
.operations-accordion { padding: 10px; }
.operations-accordion > summary { list-style: none; cursor: pointer; }
.operations-accordion > summary::-webkit-details-marker { display: none; }
.operations-accordion > summary::after { content: "Expand"; margin-top: 8px; display: inline-block; font-size: 0.75rem; font-weight: 700; color: var(--lt-text-muted); border: 1px solid #cbd5e1; border-radius: 999px; padding: 2px 8px; }
.operations-accordion[open] > summary::after { content: "Collapse"; }
.compact-cards-grid { margin-top: 8px; display: grid; gap: 6px; }
.compact-data-card { border: 1px solid #dbe3ec; border-radius: 12px; padding: 9px; background: var(--lt-surface); }
.compact-data-card h3 { margin: 0 0 4px; font-size: 1rem; color: var(--lt-text-primary); }
.compact-card-subtitle { margin: 0 0 8px; font-size: 0.82rem; color: #64748b; }
.compact-stats-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 6px 10px; }
.compact-stats-grid p { margin: 0; display: flex; flex-direction: column; gap: 2px; }
.compact-stats-grid span { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.03em; color: var(--lt-text-muted); }
.compact-stats-grid strong { font-size: 0.92rem; color: var(--lt-text-primary); }
.text-danger { color: #b91c1c; }
.compact-inline-meta { margin: 8px 0 0; font-size: 0.88rem; color: #334155; }
.empty-state-card { margin-top: 6px; border: 1px dashed #cbd5e1; border-radius: 10px; background: var(--lt-surface); padding: 8px 9px; display: flex; flex-wrap: wrap; gap: 7px; justify-content: space-between; align-items: center; }
.issues-list { margin-top: 10px; display: grid; gap: 8px; }
.issue-row { display: flex; justify-content: space-between; align-items: center; gap: 8px; text-decoration: none; border: 1px solid var(--lt-border-muted); border-radius: 10px; background: var(--lt-surface); color: var(--lt-text-primary); padding: 8px 9px; }
.issue-row strong { font-size: 1rem; }
.issue-row.has-issue { border-color: #fca5a5; background: #fef2f2; color: #991b1b; }
.issue-row.is-clear { border-color: #bbf7d0; background: #f0fdf4; color: #166534; }
.mobile-sticky-actions { position: fixed; left: 10px; right: 10px; bottom: 10px; display: none; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; padding: 8px; background: rgba(255, 255, 255, 0.95); border: 1px solid #dbe3ec; border-radius: 14px; box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12); z-index: 30; }
.mobile-sticky-actions a { text-align: center; padding: 8px 10px; }

@media (max-width: 760px) {
  .mobile-sticky-actions { display: grid; }
}

.deduction-tabs {
  margin-top: 6px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 4px;
}

.deduction-tab {
  border: 1px solid #cbd5e1;
  background: var(--lt-surface-muted);
  color: #334155;
  border-radius: 8px;
  padding: 6px 8px;
  font-weight: 700;
  font-size: 12px;
}

.deduction-tab.is-active {
  background: #0f766e;
  border-color: #0f766e;
  color: #f0fdfa;
}

.deduction-soft-cta {
  margin-top: 6px;
  padding: 8px;
  border: 1px solid #dbe4f0;
  border-radius: 10px;
  background: var(--lt-surface-muted);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.deduction-soft-cta p {
  margin: 0;
  color: #334155;
}

.deduction-upgrade-prompt {
  margin-top: 6px;
  padding: 8px;
  border: 1px solid #a7f3d0;
  border-radius: 10px;
  background: #ecfdf5;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.deduction-upgrade-prompt p {
  margin: 0;
  color: #065f46;
}

.deduction-locked-card {
  border: 1px solid #dbe4f0;
  border-radius: 10px;
  background: var(--lt-surface-muted);
  padding: 10px;
}

.deduction-locked-badge {
  margin: 0 0 6px;
  font-size: 12px;
  font-weight: 700;
  color: #0f766e;
  text-transform: uppercase;
}

.deduction-locked-card h3 {
  margin: 0;
}

.deduction-locked-preview {
  margin: 12px 0;
  height: 72px;
  border-radius: 10px;
  background: linear-gradient(120deg, #e2e8f0, #f1f5f9, #e2e8f0);
  filter: blur(1px);
}

.deduction-breakdown-card-compact {
  padding: 8px;
}

.deduction-breakdown-card-compact .deduction-breakdown-value {
  margin: 2px 0 0;
  font-size: clamp(0.95rem, 3.6vw, 1.2rem);
}

.deduction-breakdown-card-compact .metric-detail {
  font-size: 13px;
  line-height: 1.35;
}

.tax-plan-accordion {
  margin-top: 8px;
  border: 1px solid #dbe4f0;
  border-radius: 10px;
  background: var(--lt-surface-muted);
}

.tax-plan-accordion summary {
  cursor: pointer;
  list-style: none;
  padding: 9px 10px;
  font-weight: 700;
  color: var(--lt-text-strong);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.tax-plan-accordion summary::-webkit-details-marker {
  display: none;
}

.tax-plan-accordion[open] summary {
  border-bottom: 1px solid #dbe4f0;
}

.tax-plan-accordion summary::after {
  content: "▸";
  color: #64748b;
  font-size: 14px;
  font-weight: 700;
}

.tax-plan-accordion[open] summary::after {
  content: "▾";
}

.tax-plan-content {
  padding: 9px 10px;
}

.deduction-expense-card summary {
  list-style: none;
}

.deduction-expense-card summary::-webkit-details-marker {
  display: none;
}

.deduction-summary-mini {
  padding: 9px;
}

.summary-section {
  margin-top: 10px;
}

.summary-section-title {
  margin: 0 0 6px;
  font-size: 14px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--lt-text-muted);
}

.summary-big-picture-grid {
  margin-top: 0;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.summary-big-metric {
  background: #f0f9ff;
  border-color: #bfdbfe;
  padding: 14px;
}

.summary-big-metric .deduction-breakdown-value {
  font-size: 30px;
}

.summary-compact-grid {
  margin-top: 0;
  gap: 10px;
}

.summary-insight-card {
  border-color: #a7f3d0;
  background: #ecfdf5;
  padding: 8px;
}

.summary-insight-card .metric-detail {
  font-size: 14px;
}

.deduction-tracker-shell {
  padding: 4px 0;
}

.deduction-header-compact {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 4px;
  flex-wrap: wrap;
}

.deduction-header-compact h1 {
  margin: 0;
  font-size: clamp(1.1rem, 4.6vw, 1.35rem);
}

.deduction-top-actions {
  margin-top: 0;
  gap: 4px;
}

.deduction-top-actions .btn-success,
.deduction-top-actions .btn-secondary {
  min-height: 30px;
  padding: 4px 8px;
  font-size: 0.78rem;
}

.deduction-soft-cta--compact,
.deduction-upgrade-prompt--compact {
  align-items: flex-start;
}

.deduction-panel {
  margin-top: 6px;
}

.deduction-top-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  margin-bottom: 6px;
}

.deduction-top-stat {
  border: 1px solid var(--lt-border-muted);
  border-radius: 10px;
  padding: 7px 8px;
  background: #fff;
}

.deduction-top-stat .metric-label {
  margin: 0;
  font-size: 0.68rem;
}

.deduction-top-stat .deduction-breakdown-value {
  margin: 2px 0 0;
  font-size: clamp(0.9rem, 3.2vw, 1.05rem);
}

.deduction-panel[hidden] {
  display: none !important;
}

.tab-intro {
  margin: 0 0 6px;
  font-size: 0.8rem;
  color: var(--lt-text-muted);
}

.deduction-kpi-grid {
  gap: 8px;
}

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

.deduction-summary-tile {
  width: 100%;
  text-align: left;
  cursor: pointer;
  padding: 7px;
  border-radius: 999px;
}

.deduction-summary-tile.is-active {
  border-color: #0f766e;
  background: #ecfeff;
  box-shadow: 0 0 0 1px #0f766e;
}

.deduction-drilldown {
  margin-top: 2px;
}

.deduction-expense-card--collapsed {
  margin-top: 6px;
  border: 1px solid var(--lt-border-muted);
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
}

.deduction-expense-card--collapsed > summary {
  font-size: 0.82rem;
  background: var(--lt-surface-muted);
  border: 0;
  border-radius: 0;
}

.deduction-expense-card--collapsed > summary:hover {
  background: #eef2ff;
}

.deduction-expense-card--collapsed > summary:active {
  background: #dbeafe;
}

.deduction-expense-card--collapsed > summary:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: -2px;
}

.deduction-expense-card--collapsed > summary::after {
  font-size: 0.84rem;
}

.deduction-expense-card--collapsed[open] > summary {
  border-bottom: 1px solid var(--lt-border-muted);
  background: #fff;
}

.deduction-expense-card--collapsed[open] > summary::after {
  transform: rotate(180deg);
}

.deduction-drilldown-body {
  padding-top: 4px;
}

.deduction-drilldown-intro,
.deduction-drilldown-empty {
  margin-bottom: 4px;
}

.expense-compact-list {
  list-style: none;
  margin: 6px 0 0;
  padding: 0;
  border-top: 1px solid var(--lt-border-muted);
}

.expense-compact-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 6px;
  padding: 6px 0;
  border-bottom: 1px solid var(--lt-border-muted);
}

.expense-compact-main {
  min-width: 0;
}

.expense-compact-line {
  margin: 0;
  font-size: 0.78rem;
  color: #334155;
}

.expense-compact-line--primary {
  font-size: 0.82rem;
  font-weight: 700;
  color: #0f172a;
}

.expense-compact-line--amounts {
  margin-top: 2px;
}

.expense-compact-note {
  margin-top: 2px;
  color: var(--lt-text-muted);
}

.expense-compact-actions {
  display: flex;
  flex-direction: row;
  gap: 4px;
  align-items: flex-end;
}

.expense-compact-actions form {
  margin: 0;
}

.expense-compact-actions .btn-secondary,
.expense-compact-actions .btn-danger {
  width: auto;
  min-height: 28px;
  font-size: 0.72rem;
  padding: 3px 7px;
}

.summary-mini-table {
  margin-top: 8px;
  border: 1px solid var(--lt-border-muted);
  border-radius: 8px;
  padding: 7px;
}

.summary-mini-table ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.summary-mini-table li {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 6px;
  padding: 5px 0;
  border-bottom: 1px solid #e2e8f0;
  font-size: 0.78rem;
}

.summary-mini-table li:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.deduction-tool-shell--compact {
  margin-top: 0;
  padding: 0;
  border: 0;
}

.deduction-kpi-grid--tax .deduction-breakdown-value--label {
  font-size: 0.98rem;
  line-height: 1.25;
}

.business-tools-header-actions .btn-secondary {
  min-width: 170px;
}

.footer-links a {
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}

.crew-dashboard-quick-action {
  display: block;
  text-align: center;
  font-size: 1.1rem;
  padding: 16px 14px;
}

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

.crew-dashboard-form-field {
  margin: 0;
}

.crew-dashboard-upcoming-list {
  margin: 8px 0 0 18px;
}

.invoice-settings-layout {
  display: grid;
  gap: 16px;
}

.invoice-settings-panel {
  border: 1px solid var(--lt-border-muted);
}

.invoice-settings-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.invoice-settings-panel-header h2 {
  margin: 0;
  color: var(--lt-text-primary);
}

.invoice-settings-status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 700;
  background: #dcfce7;
  color: #166534;
}

.invoice-settings-status-badge--soon {
  background: #e0e7ff;
  color: #3730a3;
}

.invoice-settings-help {
  margin: 6px 0 0;
  font-size: 13px;
  color: var(--lt-text-muted);
}

.invoice-settings-placeholder-list {
  display: grid;
  gap: 10px;
}

.invoice-settings-placeholder-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  border: 1px dashed #cbd5e1;
  border-radius: 12px;
  background: var(--lt-surface-muted);
}

.invoice-settings-placeholder-title {
  margin: 0;
  font-weight: 700;
  color: var(--lt-text-strong);
}

.invoice-settings-placeholder-copy {
  margin: 4px 0 0;
  color: #64748b;
  font-size: 14px;
}

.invoice-settings-switch {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: #64748b;
}

@media (max-width: 768px) {
  .card-shell {
    padding: 10px 10px;
    border-radius: 16px;
  }

  .page-header h1 {
    font-size: 30px;
    line-height: 1.15;
  }

  .legal-section {
    margin-top: 18px;
  }

  .legal-section h2 {
    font-size: 18px;
  }

  .footer-links {
    flex-direction: column;
    gap: 10px;
  }

  .deduction-tab {
    font-size: 11px;
    padding: 6px 5px;
  }

  .deduction-soft-cta,
  .deduction-upgrade-prompt {
    flex-direction: column;
    align-items: flex-start;
  }

  .deduction-breakdown-card-compact .deduction-breakdown-value {
    font-size: 18px;
  }


  .deduction-header-compact .page-subtitle {
    margin: 2px 0 0;
    font-size: 0.78rem;
    line-height: 1.2;
  }

  .deduction-top-actions {
    width: 100%;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .deduction-top-actions .btn-success,
  .deduction-top-actions .btn-secondary {
    min-height: 30px;
    font-size: 0.74rem;
    padding: 4px 6px;
  }

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

  .deduction-breakdown-card-compact {
    padding: 7px;
  }

  .expense-compact-row {
    grid-template-columns: 1fr;
    gap: 4px;
    padding: 6px 0;
  }

  .expense-compact-actions {
    justify-content: flex-start;
    align-items: center;
  }

  .crew-dashboard-queue-tabs {
    grid-template-columns: 1fr;
  }

  .invoice-settings-placeholder-item {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 768px) {
  .jobs-board-stats {
    grid-template-columns: 1fr;
  }

  .jobs-board-search,
  .jobs-board-card-actions {
    grid-template-columns: 1fr;
  }
}

.jobs-board-compact {
  gap: 10px;
}

.jobs-board-compact-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--lt-border);
  border-radius: 14px;
  background: var(--lt-surface);
}

.jobs-board-compact-header h1 {
  margin: 0;
  font-size: 1.05rem;
}

.jobs-board-eyebrow {
  margin: 0 0 2px;
  font-size: 0.68rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--lt-text-muted);
  font-weight: 700;
}

.jobs-board-header-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.jobs-board-calendar,
.jobs-board-day-section {
  border: 1px solid var(--lt-border);
  border-radius: 14px;
  background: var(--lt-surface);
  padding: 10px;
}

.jobs-board-calendar-head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}

.jobs-board-calendar-head h2 {
  margin: 0;
  text-align: center;
  font-size: 0.9rem;
}

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

.jobs-board-day {
  min-height: 64px;
  border: 1px solid var(--lt-border-muted);
  border-radius: 10px;
  text-decoration: none;
  color: inherit;
  background: var(--lt-surface);
  padding: 6px;
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 1px;
}

.jobs-board-day.is-selected {
  border-color: var(--lt-brand-700);
  background: var(--lt-brand-700);
  color: #ffffff;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.22);
}

.jobs-board-day.has-jobs {
  border-color: var(--lt-accent-border);
  background: #e8f9ec;
}

.jobs-board-day.has-jobs .jobs-board-day-indicator {
  color: #14532d;
  font-weight: 700;
}

.jobs-board-day.is-selected .jobs-board-day-indicator,
.jobs-board-day.is-selected .jobs-board-day-weekname {
  color: #d1fae5;
}

.jobs-board-day-number {
  font-weight: 700;
  font-size: 0.92rem;
}

.jobs-board-day-weekname {
  font-size: 0.66rem;
  color: var(--lt-text-muted);
  text-transform: uppercase;
}

.jobs-board-day-indicator {
  font-size: 0.64rem;
  color: var(--lt-success-text);
}

.jobs-board-day-indicator-empty {
  color: var(--lt-text-muted);
}

.jobs-board-day-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}

.jobs-board-day-label {
  margin: 0;
  font-size: 0.72rem;
  text-transform: uppercase;
  color: var(--lt-text-muted);
}

.jobs-board-day-header h3 {
  margin: 2px 0 0;
  font-size: 0.98rem;
}

.jobs-board-day-count {
  border: 1px solid var(--lt-border);
  background: var(--lt-surface-muted);
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 0.73rem;
  font-weight: 700;
}

.jobs-board-day-list {
  display: grid;
  gap: 8px;
}

.jobs-board-day-item {
  border: 1px solid var(--lt-card-border);
  border-radius: 12px;
  padding: 9px;
  background: var(--lt-card-bg);
}

.jobs-board-day-item-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  text-decoration: none;
  color: inherit;
}

.jobs-board-day-item-main h4 {
  margin: 0;
  font-size: 0.92rem;
}

.jobs-board-day-item-main p {
  margin: 2px 0 0;
  font-size: 0.78rem;
  color: var(--lt-text-muted);
}

.jobs-board-day-item-meta {
  text-align: right;
  display: grid;
  gap: 4px;
  justify-items: end;
}

.jobs-board-day-item-meta strong {
  font-size: 0.88rem;
}

.jobs-board-day-item-links {
  margin-top: 6px;
  display: flex;
  gap: 10px;
}

.jobs-board-inline-link {
  font-size: 0.74rem;
  font-weight: 700;
  text-decoration: none;
}

.jobs-board-empty-compact {
  min-height: 160px;
  gap: 6px;
}

.jobs-board-status-assigned {
  border-color: #fcd34d;
  background: #fef3c7;
  color: #854d0e;
}

.jobs-board-status-completed {
  border-color: var(--lt-accent-border);
  background: var(--lt-accent-bg);
  color: var(--lt-success-text);
}

.jobs-board-status-skipped {
  border-color: #fca5a5;
  background: #fee2e2;
  color: #991b1b;
}

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

.jobs-schedule-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.jobs-schedule-top h1 {
  margin: 0;
  font-size: 1.15rem;
}

.jobs-schedule-top p {
  margin: 2px 0 0;
  color: var(--lt-text-muted);
  font-size: 0.82rem;
}

.jobs-schedule-top-action {
  padding: 10px 12px;
  white-space: nowrap;
}

.jobs-week-strip {
  position: sticky;
  top: 8px;
  z-index: 3;
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 6px;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(6px);
  padding: 6px;
  border-radius: 12px;
  border: 1px solid var(--lt-card-border);
}

.jobs-week-day {
  text-decoration: none;
  color: inherit;
  border: 1px solid var(--lt-card-border);
  border-radius: 10px;
  padding: 6px 4px;
  text-align: center;
  display: grid;
  gap: 2px;
  background: #ffffff;
}

.jobs-week-day.is-selected {
  border-color: var(--lt-accent-border);
  background: var(--lt-accent-bg);
}

.jobs-week-day-label {
  font-size: 0.68rem;
  color: var(--lt-text-muted);
}

.jobs-week-day-number {
  font-size: 0.9rem;
  line-height: 1;
}

.jobs-week-day-count {
  font-size: 0.7rem;
  color: var(--lt-text-muted);
}

.jobs-schedule-context {
  margin: 0;
  font-size: 0.8rem;
  color: var(--lt-text-muted);
}

.jobs-list {
  display: grid;
  gap: 6px;
}

.jobs-row {
  border: 1px solid var(--lt-card-border);
  border-radius: 12px;
  background: #fff;
  padding: 8px 10px;
  display: grid;
  gap: 6px;
}

.jobs-row.is-completed {
  border-left: 4px solid #22c55e;
  padding-left: 7px;
}

.jobs-row.is-pending {
  border-left: 4px solid #f59e0b;
  padding-left: 7px;
}

.jobs-row-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: inherit;
  text-decoration: none;
}

.jobs-row-customer {
  margin: 0;
  font-size: 0.92rem;
  font-weight: 700;
}

.jobs-row-location {
  margin: 1px 0 0;
  color: var(--lt-text-muted);
  font-size: 0.76rem;
}

.jobs-row-meta {
  text-align: right;
  display: grid;
  justify-items: end;
  gap: 2px;
  flex-shrink: 0;
  font-size: 0.78rem;
}

.jobs-row-status {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid transparent;
  padding: 2px 7px;
  font-size: 0.68rem;
  font-weight: 700;
}

.jobs-row-status-assigned {
  color: #854d0e;
  border-color: #fcd34d;
  background: #fef3c7;
}

.jobs-row-status-completed {
  color: #166534;
  border-color: #86efac;
  background: #dcfce7;
}

.jobs-row-status-skipped {
  color: #991b1b;
  border-color: #fca5a5;
  background: #fee2e2;
}

.jobs-row-secondary {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  color: var(--lt-text-muted);
  font-size: 0.72rem;
}

.jobs-row-secondary-details {
  border-top: 1px solid var(--lt-border-muted);
  padding-top: 4px;
}

.jobs-row-secondary-summary {
  cursor: pointer;
  font-size: 0.75rem;
  color: var(--lt-text-muted);
  font-weight: 600;
}

.jobs-row-notes summary {
  cursor: pointer;
  font-size: 0.72rem;
  color: var(--lt-text-muted);
}

.jobs-row-notes p {
  margin: 4px 0 0;
  font-size: 0.78rem;
}

.jobs-empty-day {
  border: 1px dashed var(--lt-border);
  border-radius: 10px;
  padding: 12px;
  display: grid;
  gap: 8px;
}

.jobs-empty-day p {
  margin: 0;
  font-size: 0.85rem;
}

.jobs-empty-compact {
  margin-top: 4px;
}

@media (max-width: 768px) {
  .jobs-board-compact-header {
    align-items: flex-start;
    flex-direction: column;
  }

  .jobs-board-header-actions {
    width: 100%;
  }

  .jobs-board-day-item-main {
    align-items: flex-start;
    flex-direction: column;
  }

  .jobs-board-day-item-meta {
    width: 100%;
    justify-items: start;
    text-align: left;
  }

  .jobs-schedule-top {
    align-items: center;
  }

  .jobs-schedule-top-action {
    padding: 8px 10px;
  }

  .jobs-week-strip {
    top: 4px;
  }
}

.customers-list {
  border-top: 1px solid #e2e8f0;
  border-bottom: 1px solid #e2e8f0;
  overflow: hidden;
  background: #ffffff;
}

.customers-list-row {
  align-items: center;
  border-bottom: 1px solid #e2e8f0;
  color: inherit;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  min-height: 72px;
  padding: 12px 14px;
  text-decoration: none;
  transition: background-color 0.2s ease;
}

.customers-list-row:last-child {
  border-bottom: none;
}

.customers-list-row:hover,
.customers-list-row:focus-visible {
  background: #f8fafc;
  outline: none;
}

.customers-list-row.customers-status-owing {
  box-shadow: inset 3px 0 0 #fca5a5;
}

.customers-list-row.customers-status-current {
  box-shadow: inset 3px 0 0 #86efac;
}

.customers-list-row.customers-status-attention {
  box-shadow: inset 3px 0 0 #fcd34d;
}

.customers-list-main {
  min-width: 0;
}

.customers-list-meta {
  color: #475569;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 3px 0 0;
  font-size: 12px;
  line-height: 1.3;
}

.customers-secondary {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.customers-list-right {
  align-items: center;
  display: flex;
  flex-shrink: 0;
  gap: 8px;
}

.customers-status-badge {
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.01em;
  padding: 3px 7px;
}

.customers-status-badge-owing {
  background: #fee2e2;
  color: #991b1b;
}

.customers-status-badge-current {
  background: #dcfce7;
  color: #166534;
}

.customers-status-badge-attention {
  background: #fef3c7;
  color: #92400e;
}

.customers-balance-due {
  color: #b91c1c;
  font-size: 13px;
  font-weight: 800;
  margin: 0;
}

.customers-row-chevron {
  color: #64748b;
  font-size: 18px;
  font-weight: 700;
}

@media (max-width: 640px) {
  .customers-list-row {
    align-items: center;
    flex-direction: row;
  }

  .customers-name {
    font-size: 16px;
  }

  .customers-list-meta {
    gap: 5px;
  }
}

.customer-balance-shell .workflow-header {
  gap: 6px;
}

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

.customer-balance-tile {
  min-height: 0;
  padding: 12px;
}

.customer-balance-tile h2 {
  margin: 0;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.customer-balance-tile-value {
  margin: 6px 0 0;
  font-size: clamp(1.05rem, 3.8vw, 1.4rem);
  font-weight: 800;
  color: var(--lt-text-strong);
}

.customer-balance-tile.is-charges {
  background: #eff6ff;
  border-color: #bfdbfe;
}

.customer-balance-tile.is-payments {
  background: #ecfdf5;
  border-color: #86efac;
}

.customer-balance-tile.is-due {
  background: #fef2f2;
  border-color: #fecaca;
}

.customer-balance-list-stack {
  margin-top: 8px;
  gap: 8px;
}

.customer-balance-row {
  padding: 10px 12px;
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: flex-start;
}

.customer-balance-row-main {
  min-width: 0;
}

.customer-balance-row-title {
  margin: 0;
  font-weight: 800;
  color: var(--lt-text-strong);
}

.customer-balance-row-main p {
  margin: 0;
  color: var(--lt-text-muted);
  font-size: 0.9rem;
}

.customer-balance-row-main p + p {
  margin-top: 4px;
}

.customer-balance-row-links {
  margin-top: 6px;
}

.customer-balance-inline-link {
  font-size: 0.82rem;
  font-weight: 700;
  color: #1d4ed8;
  text-decoration: none;
}

.customer-balance-row-side {
  text-align: right;
  flex-shrink: 0;
}

.customer-balance-amount {
  margin: 0;
  font-weight: 800;
}

.customer-balance-amount.is-charge {
  color: #991b1b;
}

.customer-balance-amount.is-payment {
  color: #166534;
}

.customer-balance-running {
  margin: 4px 0 0;
  font-size: 0.8rem;
  color: var(--lt-text-muted);
}

.customer-balance-empty {
  margin-top: 8px;
  padding: 10px 12px;
  font-size: 0.9rem;
}

.customer-balance-actions {
  padding-top: 12px;
}

@media (max-width: 720px) {
  .customer-balance-summary {
    grid-template-columns: 1fr;
  }

  .customer-balance-row {
    flex-direction: column;
  }

  .customer-balance-row-side {
    width: 100%;
    text-align: left;
  }
}

.public-billing-payment-card h2 {
  margin: 0 0 10px;
}

.public-billing-payment-name,
.public-billing-payment-handle {
  margin-bottom: 8px;
}

.public-billing-payment-card .actions-row {
  margin-top: 6px;
}

.home-route-header {
  margin-bottom: 8px;
}


.home-route-sort-row {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 6px;
}

.home-route-sort-chip {
  font-size: 11px;
  font-weight: 700;
  color: #1d4ed8;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 999px;
  padding: 2px 8px;
}

.home-route-sort-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.home-route-sort-menu {
  width: 100%;
}

.home-route-sort-summary {
  list-style: none;
  border: 1px solid var(--lt-border-muted);
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 700;
  color: var(--lt-text-strong);
  background: #fff;
  cursor: pointer;
  text-align: center;
}

.home-route-sort-summary::-webkit-details-marker {
  display: none;
}

.home-route-sort-menu[open] .home-route-sort-summary {
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
}

.home-route-sort-menu .home-route-sort-actions {
  margin-top: 6px;
}

.btn-small {
  padding: 6px 10px;
  font-size: 12px;
}

.home-route-item-actions {
  display: grid;
  gap: 6px;
  justify-items: end;
}

.home-route-distance,
.home-route-note {
  margin: 4px 0 0;
  color: var(--lt-text-muted);
  font-size: 11px;
}
.home-route-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  overflow: hidden;
}

.home-route-item {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 9px 10px;
  background: #fff;
  align-items: flex-start;
}

.home-route-item + .home-route-item {
  border-top: 1px solid #e2e8f0;
}

.home-route-customer {
  margin: 0;
  color: var(--lt-text-strong);
  font-weight: 700;
  font-size: 13px;
}

.home-route-address {
  margin: 2px 0 0;
  color: var(--lt-text-muted);
  font-size: 12px;
}

.home-route-status {
  border-radius: 999px;
  border: 1px solid #d1d5db;
  padding: 2px 8px;
  font-size: 11px;
  font-weight: 700;
  color: #374151;
  white-space: nowrap;
}

.home-route-status-assigned {
  border-color: #bfdbfe;
  background: #eff6ff;
  color: #1d4ed8;
}

.home-route-status-completed {
  border-color: #bbf7d0;
  background: #f0fdf4;
  color: #15803d;
}

.home-route-status-skipped {
  border-color: #fecaca;
  background: #fef2f2;
  color: #b91c1c;
}

.home-route-footer {
  margin-top: 10px;
}


.home-route-card-compact {
  padding: 9px;
}

.home-route-card-compact .home-priority-description {
  font-size: 11px;
}
.invoice-settings-payment-methods {
  display: grid;
  gap: 10px;
  margin-top: 10px;
}

.invoice-settings-payment-method {
  display: grid;
  gap: 10px;
  border: 1px solid var(--lt-border-muted);
  border-radius: 12px;
  padding: 12px;
  background: var(--lt-surface-muted);
}

.invoice-settings-logo-preview-wrap {
  margin-top: 10px;
}

.invoice-settings-logo-preview {
  display: block;
  max-width: 180px;
  max-height: 88px;
  width: auto;
  height: auto;
  object-fit: contain;
  border: 1px solid var(--lt-border-muted);
  border-radius: 10px;
  background: #fff;
  padding: 8px;
}

.invoice-settings-checkbox-line {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: var(--lt-text-primary);
}

.invoice-brand-logo {
  display: block;
  max-width: 180px;
  max-height: 88px;
  width: auto;
  height: auto;
  object-fit: contain;
}

.invoice-brand-logo--public {
  max-width: 160px;
  max-height: 72px;
}

.public-billing-payment-list {
  display: grid;
  gap: 10px;
}

.public-billing-payment-item {
  border: 1px solid var(--lt-border-muted);
  border-radius: 12px;
  padding: 12px;
  background: #ffffff;
}

.public-billing-payment-provider {
  margin: 0 0 4px;
}

.public-billing-payment-instructions {
  margin: 8px 0 0;
  color: var(--lt-text-muted);
  font-size: 0.9rem;
}

/* Mileage report compact layout */
.mileage-report-shell .workflow-header {
  gap: 3px;
  margin-bottom: 2px;
}

.mileage-report-shell .page-back-link {
  margin-bottom: 3px;
  font-size: 0.78rem;
  font-weight: 600;
  gap: 4px;
}

.mileage-report-shell .page-header {
  margin-bottom: 2px;
}

.mileage-report-shell .page-header h1 {
  font-size: clamp(1.1rem, 3.8vw, 1.35rem);
  line-height: 1.1;
}

.mileage-range-controls {
  padding: 8px 10px;
}

.mileage-primary-stats {
  border: 1px solid var(--lt-border-muted);
  border-radius: 12px;
  padding: 8px 10px;
  background: #fff;
}

.mileage-stat-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
  padding: 3px 0;
  border-bottom: 1px solid var(--lt-border-muted);
}

.mileage-stat-row:last-of-type {
  border-bottom: 0;
}

.mileage-stat-label {
  margin: 0;
  font-size: 0.78rem;
  color: var(--lt-text-muted);
}

.mileage-stat-value {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--lt-text-strong);
  text-align: right;
}

.mileage-helper-line {
  margin: 5px 0 0;
  font-size: 0.74rem;
  color: var(--lt-text-muted);
}

.mileage-expandable-card {
  margin-top: 6px;
  border: 1px solid var(--lt-border-muted);
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
}

.mileage-expandable-card > summary {
  list-style: none;
  cursor: pointer;
  padding: 9px 10px;
  font-weight: 700;
  font-size: 0.84rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--lt-surface-muted);
}

.mileage-expandable-card > summary::-webkit-details-marker {
  display: none;
}

.mileage-expandable-card > summary::after {
  content: "▸";
  color: var(--lt-text-muted);
}

.mileage-expandable-card[open] > summary {
  border-bottom: 1px solid var(--lt-border-muted);
  background: #fff;
}

.mileage-expandable-card[open] > summary::after {
  content: "▾";
}

.mileage-expandable-card > summary:active {
  background: #e2e8f0;
}

.mileage-range-controls .page-header h2 {
  margin: 0;
  font-size: 0.84rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--lt-text-muted);
}

.mileage-range-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
  gap: 4px;
  align-items: end;
}

.mileage-label {
  display: block;
  margin-bottom: 1px;
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--lt-text-primary);
}

.mileage-input {
  width: 100%;
  min-height: 32px;
  padding: 5px 7px;
  border: 1px solid var(--lt-border);
  border-radius: 7px;
  font-size: 0.8rem;
  font: inherit;
}

.mileage-range-apply {
  min-height: 30px;
  padding: 5px 8px;
  font-size: 0.78rem;
}

.mileage-quick-filters {
  margin-top: 4px;
  gap: 4px;
}

.mileage-quick-filters .btn-secondary {
  min-height: 28px;
  padding: 4px 8px;
  font-size: 0.74rem;
}

.mileage-summary-grid {
  margin-top: 4px;
  display: grid;
  gap: 5px;
}

.mileage-summary-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 2px 8px;
  align-items: center;
  padding: 7px 9px;
  text-decoration: none;
  border: 1px solid var(--lt-border-muted);
  border-radius: 10px;
  color: var(--lt-text-primary);
  transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}

.mileage-summary-row span {
  margin: 0;
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--lt-text-muted);
  font-weight: 700;
}

.mileage-summary-row strong {
  margin: 0;
  font-size: 0.95rem;
  text-align: right;
}

.mileage-summary-row small {
  grid-column: 1 / -1;
  margin: 0;
  font-size: 0.75rem;
  color: var(--lt-text-muted);
}

.mileage-summary-row:hover,
.mileage-summary-row:active {
  border-color: #93c5fd;
  transform: translateY(-1px);
}

.mileage-summary-row:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

.mileage-summary-row.is-active {
  border-color: #60a5fa;
  box-shadow: inset 0 0 0 1px #bfdbfe;
}

.mileage-summary-label {
  margin: 0;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--lt-text-muted);
  font-weight: 700;
}

.mileage-summary-value {
  margin: 2px 0;
  font-size: clamp(1rem, 3.4vw, 1.2rem);
  line-height: 1.1;
  font-weight: 800;
  color: var(--lt-text-strong);
}

.mileage-summary-card .metric-detail {
  margin: 0;
  font-size: 0.76rem;
  line-height: 1.2;
}

.mileage-actions-card {
  margin-top: 6px;
}

.mileage-actions-row {
  padding: 8px 10px 10px;
  gap: 6px;
}

.mileage-actions-card .btn-primary,
.mileage-actions-card .btn-info {
  min-height: 32px;
  padding: 5px 9px;
  font-size: 0.84rem;
}

.invoices-screen .compact-section {
  border-radius: 14px;
}

.invoices-form-grid {
  gap: 10px;
}

.invoices-note {
  margin: 0;
  color: var(--lt-text-muted);
  font-size: 0.86rem;
}

.invoices-date-range {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

.invoices-actions .btn-primary,
.invoices-actions .btn-secondary {
  min-height: 42px;
}

.mileage-summary-disclaimer {
  margin: 8px 0 0;
  font-size: 0.72rem;
  line-height: 1.2;
  color: var(--lt-text-muted);
}

.mileage-report-alert {
  margin-top: 8px;
  margin-bottom: 0;
}

.mileage-warning-stack {
  margin-top: 8px;
  display: grid;
  gap: 4px;
}

.mileage-warning-line {
  margin: 0;
  padding: 6px 8px;
  border-radius: 8px;
  background: var(--lt-bg-subtle);
  font-size: 0.82rem;
  color: var(--lt-text-muted);
}

.mileage-nested-details {
  margin-top: 10px;
}

.mileage-compact-table th,
.mileage-compact-table td {
  padding: 6px 8px;
  vertical-align: top;
  font-size: 0.86rem;
}

.mileage-route-label {
  display: inline-block;
  font-size: 0.84rem;
  color: var(--lt-text-muted);
}

.mileage-route-details summary {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--lt-text-strong);
  padding: 6px 9px;
  border: 1px solid var(--lt-border-muted);
  border-radius: 10px;
  background: var(--lt-surface);
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

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

.mileage-route-details summary::after {
  content: "▾";
  color: var(--lt-text-muted);
  font-size: 0.78rem;
  transition: transform 0.16s ease;
}

.mileage-route-details[open] summary::after {
  transform: rotate(180deg);
}

.mileage-route-details summary:hover {
  background: #eef2ff;
}

.mileage-route-details summary:active {
  background: #dbeafe;
}

.mileage-route-details p {
  margin: 4px 0 0;
  font-size: 0.8rem;
  color: var(--lt-text-muted);
  word-break: break-word;
}

.mileage-log-card p {
  margin-bottom: 4px;
}

.mileage-log-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
}

.payment-task-shell {
  display: grid;
  gap: 10px;
  width: min(100%, 620px);
}

.payment-task-balance {
  border: 1px solid var(--lt-border-muted);
  border-radius: 12px;
  background: var(--lt-surface);
  padding: 10px 12px;
}

.payment-task-balance__label {
  margin: 0;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--lt-text-muted);
  font-weight: 700;
}

.payment-task-balance__value {
  margin: 4px 0 0;
  font-size: clamp(1.15rem, 4vw, 1.4rem);
  font-weight: 800;
  color: var(--lt-text-strong);
}

.payment-task-form {
  display: grid;
  gap: 9px;
}

.payment-task-form .form-row {
  gap: 5px;
}

.payment-task-form label {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--lt-text-primary);
}

.payment-task-form .form-control {
  min-height: 42px;
  padding: 9px 11px;
}

.payment-task-notes-row textarea.form-control {
  min-height: 96px;
  resize: vertical;
}

.payment-task-optional {
  color: var(--lt-text-muted);
  font-weight: 600;
}

.payment-task-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 2px;
}

.payment-task-actions .btn-primary,
.payment-task-actions .btn-secondary {
  min-height: 40px;
  padding: 8px 12px;
}

@media (max-width: 560px) {
  .payment-task-shell {
    width: 100%;
  }

  .payment-task-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .payment-task-actions .btn-primary,
  .payment-task-actions .btn-secondary {
    text-align: center;
  }
}

.business-tools-extra-services-plan {
  margin-top: 12px;
}

.business-tools-plan-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.business-tools-plan-card {
  border: 1px solid var(--lt-border-muted);
  border-radius: 12px;
  background: var(--lt-surface);
  padding: 10px;
}

.business-tools-plan-card ol {
  margin: 6px 0 0;
  padding-left: 18px;
  display: grid;
  gap: 4px;
  color: var(--lt-text-muted);
  font-size: 0.88rem;
}

.business-tools-plan-title {
  margin: 0;
  font-weight: 700;
  color: var(--lt-text-strong);
}

.business-tools-plan-billing-note {
  margin-top: 10px;
  margin-bottom: 0;
  color: #0f5132;
  font-weight: 600;
}

.quick-yard-tracker {
  display: grid;
  gap: 10px;
}

.quick-yard-tracker__header {
  margin-bottom: 0;
}

.quick-yard-tracker__section {
  padding: 10px;
}

.quick-yard-tracker__section-title {
  margin: 0 0 6px;
  font-size: 1rem;
  color: var(--lt-text-strong);
}

.quick-yard-tracker__status-chip {
  margin: 0 0 8px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border: 1px solid #bbf7d0;
  background: #f0fdf4;
  color: #166534;
  font-size: 0.82rem;
}

.quick-yard-tracker__status-chip--warning {
  border-color: #fdba74;
  background: #fff7ed;
  color: #9a3412;
}

.quick-yard-tracker__location-form {
  margin-top: 8px;
}

.quick-yard-tracker__primary-action {
  width: 100%;
}

.quick-yard-tracker__fallback {
  margin-top: 8px;
  padding: 10px;
  border: 1px solid var(--lt-border-muted);
  border-radius: 12px;
  background: var(--lt-surface);
}

.quick-yard-tracker__fallback p {
  margin-bottom: 8px;
}

.quick-yard-tracker__section--success {
  border-color: #86efac;
  background: #f0fdf4;
}

.quick-yard-tracker__section--warning {
  border-color: #fdba74;
  background: #fff7ed;
}

.quick-yard-tracker__section--empty {
  border-style: dashed;
}

.quick-yard-tracker__yard-list {
  margin-top: 8px;
  display: grid;
  gap: 8px;
}

.quick-yard-tracker__yard-card {
  border: 1px solid var(--lt-border-muted);
  border-radius: 12px;
  padding: 10px;
  background: var(--lt-surface);
}

.quick-yard-tracker__yard-actions {
  margin-top: 8px;
  display: grid;
  gap: 8px;
}

.quick-yard-tracker__mark-form {
  display: grid;
  gap: 6px;
}

.profit-loss-shell .outstanding-balances-summary-strip {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 640px) {
  .profit-loss-shell .outstanding-balances-summary-strip {
    grid-template-columns: 1fr;
  }
}
