:root {
  --bg: #07101d;
  --bg-soft: #0d1b2a;
  --panel: #10233c;
  --panel-2: #122742;
  --card: rgba(255, 255, 255, 0.055);
  --card-strong: rgba(255, 255, 255, 0.085);
  --text: #eef4ff;
  --muted: #b5c7df;
  --line: rgba(255, 255, 255, 0.13);
  --primary: #ff7a18;
  --primary-2: #ffb347;
  --accent: #1fd1f9;
  --success: #24d17e;
  --danger: #ff5f6d;
  --warning: #ffd166;
  --shadow: 0 24px 70px rgba(0, 0, 0, 0.34);
  --radius-xl: 26px;
  --radius-lg: 20px;
  --radius-md: 14px;
  --sidebar-w: 292px;
}

* { box-sizing: border-box; }
html { min-height: 100%; }
body {
  margin: 0;
  min-height: 100vh;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 5% 5%, rgba(31, 209, 249, 0.16), transparent 26%),
    radial-gradient(circle at 92% 4%, rgba(255, 122, 24, 0.18), transparent 22%),
    linear-gradient(180deg, #07101d 0%, #091728 55%, #07101d 100%);
  line-height: 1.5;
}

button, input, select, textarea { font: inherit; }
button { border: 0; }
input, select, textarea {
  width: 100%;
  color: var(--text);
  background: rgba(255,255,255,0.065);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px 14px;
  outline: none;
  min-height: 48px;
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
textarea { min-height: 108px; resize: vertical; }
select { color-scheme: dark; }
option { background: #10233c; color: var(--text); }
input:focus, select:focus, textarea:focus {
  border-color: rgba(255,179,71,.62);
  box-shadow: 0 0 0 4px rgba(255,179,71,.13);
  background: rgba(255,255,255,0.085);
}
label { color: #d6e4f7; font-weight: 800; font-size: .92rem; }
code { color: var(--primary-2); }

.app-shell { display: grid; grid-template-columns: var(--sidebar-w) 1fr; min-height: 100vh; }
.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  padding: 24px 18px;
  border-right: 1px solid rgba(255,255,255,.1);
  background: rgba(8,17,31,.82);
  backdrop-filter: blur(18px);
  overflow-y: auto;
}
.brand { padding: 16px; border-radius: var(--radius-lg); background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.08); margin-bottom: 18px; }
.brand h1 { margin: 0 0 6px; font-size: 1.45rem; letter-spacing: -.03em; }
.brand p { margin: 0; color: var(--muted); font-size: .92rem; }
.nav { display: grid; gap: 8px; }
.nav-btn {
  min-height: 46px;
  border-radius: 14px;
  padding: 0 14px;
  background: transparent;
  color: var(--muted);
  border: 1px solid transparent;
  text-align: left;
  cursor: pointer;
  font-weight: 800;
  transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
}
.nav-btn:hover { color: var(--text); background: rgba(255,255,255,.06); transform: translateX(2px); }
.nav-btn.active { color: #07101d; background: linear-gradient(135deg, var(--primary-2), var(--primary)); border-color: rgba(255,179,71,.34); }

.main { padding: 24px; min-width: 0; }
.topbar {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
  margin-bottom: 22px;
  padding: 18px 20px;
  border-radius: var(--radius-xl);
  background: rgba(255,255,255,.045);
  border: 1px solid rgba(255,255,255,.1);
  box-shadow: var(--shadow);
}
.topbar h2 { margin: 0 0 4px; font-size: clamp(1.45rem, 3vw, 2.2rem); letter-spacing: -.04em; }
.topbar p { margin: 0; color: var(--muted); }
.topbar-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.status-pill { display: inline-flex; align-items: center; justify-content: center; min-height: 36px; padding: 0 12px; border-radius: 999px; font-weight: 900; font-size: .86rem; }
.status-pill.online { color: #d9ffea; background: rgba(36,209,126,.11); border: 1px solid rgba(36,209,126,.28); }

.view { display: none; }
.view.active { display: block; }
.panel, .stat-card, .employee-header {
  border-radius: var(--radius-xl);
  background: rgba(16,35,60,.72);
  border: 1px solid rgba(255,255,255,.105);
  box-shadow: var(--shadow);
}
.panel { padding: 22px; margin-bottom: 18px; }
.panel h3 { margin: 0 0 8px; letter-spacing: -.02em; }
.panel p { color: var(--muted); }
.panel-header { display: flex; justify-content: space-between; gap: 16px; align-items: flex-start; margin-bottom: 18px; }
.panel-header h3, .panel-header h4 { margin: 0 0 4px; }
.panel-header p { margin: 0; color: var(--muted); }
.panel-header.mini { align-items: center; }

.stats-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; margin-bottom: 18px; }
.stat-card { padding: 22px; background: rgba(255,255,255,.052); }
.stat-card span { display: block; color: var(--muted); font-weight: 800; margin-bottom: 8px; }
.stat-card strong { display: block; font-size: 2.2rem; line-height: 1; color: var(--primary-2); }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  cursor: pointer;
  font-weight: 900;
  color: var(--text);
  background: rgba(255,255,255,.075);
  border: 1px solid rgba(255,255,255,.12);
  transition: transform .2s ease, opacity .2s ease, background .2s ease;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); background: rgba(255,255,255,.105); }
.btn.primary { color: #07101d; background: linear-gradient(135deg, var(--primary-2), var(--primary)); border-color: rgba(255,179,71,.3); }
.btn.secondary { background: rgba(255,255,255,.065); }
.btn.danger { background: rgba(255,95,109,.13); border-color: rgba(255,95,109,.35); color: #ffe2e6; }
.btn.small { min-height: 36px; padding: 0 12px; font-size: .86rem; }
.btn:disabled { opacity: .55; cursor: not-allowed; transform: none; }

.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.form-grid.compact { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.field { display: grid; gap: 7px; min-width: 0; }
.field.full, .full { grid-column: 1 / -1; }
.button-field, .vin-button-field { align-self: end; }
.form-actions { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.help-text { margin: 0 0 12px; color: var(--muted); font-size: .92rem; }
.subsection { padding: 18px; border-radius: var(--radius-lg); background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.09); }
.subsection h4 { margin: 0 0 8px; }
.history-panel summary, .profile-manager summary { cursor: pointer; font-weight: 900; color: var(--primary-2); }

.card-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.card, .request-card, .job-card, .profile-box, .vehicle-record-card, .record-customer-card, .quick-card {
  padding: 16px;
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.052);
  border: 1px solid rgba(255,255,255,.1);
}
.card h4, .request-card h4, .job-card h4, .vehicle-record-card h4, .record-customer-card h4, .quick-card h4 { margin: 0 0 8px; }
.card p, .request-card p, .job-card p, .vehicle-record-card p, .record-customer-card p, .quick-card p { margin: 4px 0; color: var(--muted); }
.card-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.meta-line { color: var(--muted); font-size: .92rem; }
.badge { display: inline-flex; align-items: center; gap: 6px; padding: 5px 9px; border-radius: 999px; font-weight: 900; font-size: .78rem; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.07); }
.badge.pending { color: #fff2cf; background: rgba(255,209,102,.12); border-color: rgba(255,209,102,.27); }
.badge.good { color: #d9ffea; background: rgba(36,209,126,.1); border-color: rgba(36,209,126,.25); }
.badge.danger { color: #ffe2e6; background: rgba(255,95,109,.11); border-color: rgba(255,95,109,.26); }

.profile-manager { margin-top: 14px; }
.profile-manager-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 14px; margin-top: 14px; }
.profile-box { display: grid; gap: 12px; align-content: start; }
.vin-decode-row { display: grid; grid-template-columns: 1fr auto; gap: 12px; }
#vinDecodeStatus { padding: 10px 12px; border-radius: 12px; background: rgba(31,209,249,.08); border: 1px solid rgba(31,209,249,.18); }
.vehicle-check-list, .employee-check-list { display: grid; gap: 10px; }
.check-card {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 12px;
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.1);
}
.check-card input { width: auto; min-height: auto; margin-top: 4px; }
.check-card strong { display: block; }
.check-card span { display: block; color: var(--muted); font-size: .9rem; }
.selected-vehicle-summary {
  margin-top: 10px;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  background: rgba(31,209,249,.08);
  border: 1px solid rgba(31,209,249,.18);
  color: #d9f8ff;
}
.compliance-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.compliance-section textarea { min-height: 92px; }

.line-item { display: grid; grid-template-columns: 2fr .7fr 1fr .7fr auto; gap: 10px; align-items: end; padding: 12px; border-radius: var(--radius-md); background: rgba(0,0,0,.12); border: 1px solid rgba(255,255,255,.08); margin-top: 10px; }
.line-item .checkbox-field { display: flex; align-items: center; gap: 8px; padding-bottom: 13px; }
.line-item input[type="checkbox"] { width: auto; min-height: auto; }

.job-filters { display: grid; grid-template-columns: 1fr 260px; gap: 12px; margin-bottom: 18px; }
.employee-header { padding: 22px; margin-bottom: 18px; }
.employee-header h3 { margin: 0 0 4px; }
.employee-header p { margin: 0; color: var(--muted); }
.employee-job-list { display: grid; gap: 12px; }
.mileage-entry { display: grid; grid-template-columns: 1fr auto; gap: 10px; margin-top: 12px; }

.records-layout { display: grid; grid-template-columns: 360px 1fr; gap: 18px; align-items: start; }
.record-search-row { margin-bottom: 12px; }
.record-list { display: grid; gap: 10px; }
.record-customer-card { cursor: pointer; transition: border-color .2s ease, transform .2s ease; }
.record-customer-card:hover, .record-customer-card.active { border-color: rgba(255,179,71,.34); transform: translateY(-1px); }
.record-detail { min-height: 360px; }
.record-section { padding: 16px; border-radius: var(--radius-lg); background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.09); margin-bottom: 14px; }
.record-section h4 { margin: 0 0 8px; }
.record-detail-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.vehicle-record-card { margin-bottom: 12px; }
.history-table { width: 100%; border-collapse: collapse; overflow: hidden; border-radius: 14px; }
.history-table th, .history-table td { padding: 10px; text-align: left; border-bottom: 1px solid rgba(255,255,255,.08); color: var(--muted); vertical-align: top; }
.history-table th { color: var(--text); font-size: .85rem; background: rgba(255,255,255,.055); }
.timeline-list { display: grid; gap: 10px; }
.timeline-item { padding: 12px; border-radius: 14px; background: rgba(0,0,0,.12); border: 1px solid rgba(255,255,255,.08); }
.timeline-item strong { display: block; }
.timeline-item span { color: var(--muted); font-size: .92rem; }
.empty-state { padding: 24px; border-radius: var(--radius-lg); background: rgba(255,255,255,.04); border: 1px dashed rgba(255,255,255,.18); color: var(--muted); }

.quick-estimate-grid { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 18px; align-items: start; }
.quick-list-panel { margin-bottom: 0; }
.quick-total { padding: 16px; border-radius: var(--radius-lg); background: linear-gradient(135deg, rgba(255,122,24,.13), rgba(31,209,249,.09)); border: 1px solid rgba(255,255,255,.1); display: grid; gap: 4px; }
.quick-total span { color: var(--muted); font-weight: 800; }
.quick-total strong { font-size: 2rem; color: var(--primary-2); }
.quick-total small { color: var(--muted); }

.document-preview {
  color: #0d1b2a;
  background: #fff;
  border-radius: 12px;
  padding: 30px;
  min-height: 520px;
  overflow-x: auto;
}
.document-preview h1, .document-preview h2, .document-preview h3 { color: #0d1b2a; margin-top: 0; }
.document-preview p, .document-preview td, .document-preview th, .document-preview li { color: #1b2b3f; }
.doc-header { display: flex; justify-content: space-between; gap: 22px; border-bottom: 2px solid #0d1b2a; padding-bottom: 14px; margin-bottom: 18px; }
.doc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.doc-box { border: 1px solid #d8e0ea; border-radius: 10px; padding: 12px; margin-bottom: 14px; }
.doc-table { width: 100%; border-collapse: collapse; margin: 14px 0; }
.doc-table th, .doc-table td { border: 1px solid #d8e0ea; padding: 9px; text-align: left; }
.doc-table th { background: #eef4ff; }
.doc-total-table { margin-left: auto; width: min(360px, 100%); }
.draft-watermark { padding: 8px 12px; border-radius: 999px; background: #fff2cf; color: #7a4b00; display: inline-block; font-weight: 900; margin-bottom: 12px; }

@media (max-width: 1180px) {
  .app-shell { grid-template-columns: 1fr; }
  .sidebar { position: relative; height: auto; }
  .nav { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .main { padding: 16px; }
  .stats-grid, .records-layout, .quick-estimate-grid { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
  .topbar, .panel-header, .doc-header { flex-direction: column; align-items: stretch; }
  .stats-grid, .card-grid, .form-grid, .form-grid.compact, .profile-manager-grid, .compliance-grid, .record-detail-grid, .doc-grid, .job-filters, .line-item, .vin-decode-row, .mileage-entry, .nav { grid-template-columns: 1fr; }
  .topbar-actions, .form-actions, .card-actions { align-items: stretch; }
  .btn { width: 100%; }
  .sidebar { padding: 14px; }
  .panel { padding: 16px; }
  .document-preview { padding: 16px; }
}

@media print {
  body { background: #fff; color: #000; }
  .sidebar, .topbar, .panel-header, .view:not(.active) { display: none !important; }
  .app-shell { display: block; }
  .main { padding: 0; }
  .panel { box-shadow: none; border: 0; padding: 0; margin: 0; }
  .document-preview { border-radius: 0; padding: 0; }
}

.checkbox-card {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 48px;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.1);
  color: var(--muted);
  font-weight: 900;
}
.checkbox-card input { width: auto; min-height: auto; }
.availability-toggle { align-self: end; }
.check-card.available { border-color: rgba(36,209,126,.24); }
.check-card.unavailable { opacity: .72; border-color: rgba(255,95,109,.24); }
.availability-reason { margin-top: 4px; font-weight: 800; }
.availability-reason.good { color: #d9ffea; }
.availability-reason.bad { color: #ffe2e6; }
.manual-record-panel { box-shadow: none; background: rgba(255,255,255,.035); }
.manual-record-panel summary { cursor: pointer; font-weight: 900; color: var(--primary-2); margin-bottom: 14px; }
.manual-record-grid { margin-top: 14px; }
.availability-settings-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.availability-card { padding: 16px; border-radius: var(--radius-lg); background: rgba(255,255,255,.052); border: 1px solid rgba(255,255,255,.1); }
.availability-card h4 { margin: 0 0 6px; }
.availability-card p { margin: 0 0 12px; color: var(--muted); }
.availability-days { display: flex; flex-wrap: wrap; gap: 8px; margin: 12px 0; }
.day-chip { display: inline-flex; align-items: center; gap: 6px; padding: 8px 10px; border-radius: 999px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); color: var(--muted); }
.day-chip input { width: auto; min-height: auto; }
.line-item { grid-template-columns: 2fr .65fr 1fr 1fr .7fr auto; }
.doc-legal-notice { border: 2px solid #0d1b2a; border-radius: 10px; padding: 14px; margin: 16px 0; background: #f8fbff; }
.doc-legal-notice p { margin: 6px 0; }
.signature-row { display: flex; justify-content: space-between; gap: 18px; flex-wrap: wrap; margin-top: 18px; font-weight: 800; }
.signature-block { margin-top: 18px; }
.florida-doc-header h1 { font-size: 1.7rem; }
@media (max-width: 900px) { .availability-settings-grid { grid-template-columns: 1fr; } }
@media (max-width: 760px) { .line-item { grid-template-columns: 1fr; } }

/* Round 3: role-based workspaces and cleaner layout */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(110deg, rgba(255,255,255,.035), transparent 38%),
    radial-gradient(circle at 78% 18%, rgba(31,209,249,.10), transparent 26%);
  opacity: .9;
}
.app-shell { position: relative; z-index: 1; }
.sidebar {
  background:
    linear-gradient(180deg, rgba(8,17,31,.94), rgba(8,17,31,.82)),
    radial-gradient(circle at 30% 0%, rgba(255,122,24,.12), transparent 34%);
}
.workspace-switcher {
  padding: 14px;
  margin-bottom: 16px;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, rgba(255,122,24,.10), rgba(31,209,249,.07));
  border: 1px solid rgba(255,255,255,.10);
}
.workspace-label,
.nav-label {
  display: block;
  margin: 0 0 8px;
  color: var(--muted);
  font-size: .74rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .12em;
}
.role-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.role-btn {
  min-height: 40px;
  border-radius: 12px;
  cursor: pointer;
  color: var(--muted);
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.10);
  font-weight: 950;
  transition: transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.role-btn:hover { transform: translateY(-1px); color: var(--text); background: rgba(255,255,255,.085); }
.role-btn.active { color: #07101d; background: linear-gradient(135deg, var(--primary-2), var(--primary)); border-color: rgba(255,179,71,.34); }
.workspace-switcher p { margin: 10px 0 0; color: var(--muted); font-size: .86rem; }
.nav { gap: 14px; }
.nav-group {
  display: grid;
  gap: 7px;
  padding: 10px;
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(255,255,255,.06);
}
.nav-btn[hidden], .nav-group[hidden] { display: none !important; }
.nav-btn { position: relative; }
.nav-btn.active::after {
  content: "";
  position: absolute;
  right: 12px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #07101d;
  opacity: .75;
}
.role-pill {
  color: #d9f8ff;
  background: rgba(31,209,249,.11);
  border: 1px solid rgba(31,209,249,.28);
}
.topbar {
  background:
    linear-gradient(135deg, rgba(255,255,255,.065), rgba(255,255,255,.035)),
    radial-gradient(circle at right, rgba(255,122,24,.10), transparent 40%);
}
.role-overview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 18px;
}
.role-overview-card {
  padding: 18px;
  border-radius: var(--radius-xl);
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 18px 50px rgba(0,0,0,.18);
}
.role-overview-card span {
  display: inline-flex;
  margin-bottom: 10px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 950;
  color: #07101d;
  background: linear-gradient(135deg, var(--primary-2), var(--primary));
}
.role-overview-card h3 { margin: 0 0 8px; }
.role-overview-card p { margin: 0; color: var(--muted); }
.employee-card span { background: linear-gradient(135deg, #8deaff, var(--accent)); }
.manager-card span { background: linear-gradient(135deg, #d7ffea, var(--success)); }
.panel, .stat-card, .employee-header, .request-card, .job-card, .profile-box, .vehicle-record-card, .record-customer-card, .quick-card {
  backdrop-filter: blur(14px);
}
.view.active { animation: fadeSlide .18s ease both; }
@keyframes fadeSlide {
  from { opacity: 0; transform: translateY(5px); }
  to { opacity: 1; transform: translateY(0); }
}
#recordVinDecodeStatus,
#vinDecodeStatus {
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(31,209,249,.08);
  border: 1px solid rgba(31,209,249,.18);
}
body[data-role-mode="employee"] .sidebar {
  background:
    linear-gradient(180deg, rgba(6,22,30,.94), rgba(8,17,31,.84)),
    radial-gradient(circle at 30% 0%, rgba(31,209,249,.16), transparent 34%);
}
body[data-role-mode="manager"] .sidebar {
  background:
    linear-gradient(180deg, rgba(8,24,20,.94), rgba(8,17,31,.84)),
    radial-gradient(circle at 30% 0%, rgba(36,209,126,.14), transparent 34%);
}
body[data-role-mode="employee"] .main {
  max-width: 980px;
  margin: 0 auto;
  width: 100%;
}
body[data-role-mode="employee"] .stats-grid,
body[data-role-mode="employee"] .role-overview-grid { display: none; }
body[data-role-mode="employee"] .employee-header,
body[data-role-mode="employee"] .panel {
  border-color: rgba(31,209,249,.16);
}

@media (max-width: 1180px) {
  .role-overview-grid { grid-template-columns: 1fr; }
  .nav-group { padding: 8px; }
}

@media (max-width: 760px) {
  .role-grid { grid-template-columns: 1fr; }
  .role-overview-grid { gap: 12px; }
}

.availability-explainer {
  margin: 10px 0 12px;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  background: rgba(255, 179, 71, .08);
  border: 1px solid rgba(255, 179, 71, .2);
  color: #fff3d9;
}
.check-card.outside-filter {
  border-style: dashed;
  background: rgba(255, 255, 255, .035);
}
.availability-card-note {
  font-size: .86rem;
  color: var(--muted);
}

.field-note {
  display: block;
  margin-top: 7px;
  color: var(--muted);
  font-size: .84rem;
}

.pricing-explainer {
  padding: 13px 15px;
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, rgba(31, 209, 249, .09), rgba(255, 179, 71, .08));
  border: 1px solid rgba(255, 255, 255, .12);
  color: #e8f4ff;
  font-size: .92rem;
}

.pricing-explainer strong {
  color: var(--primary-2);
}

#flatRateServiceSelect,
#quickFlatRateServiceSelect,
#laborTaxMode,
#quickTaxMode {
  border-color: rgba(255, 179, 71, .22);
  background: rgba(255, 179, 71, .07);
}

.quick-total small {
  display: block;
  line-height: 1.45;
}

.panel-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
}

.documents-layout {
  display: grid;
  grid-template-columns: minmax(280px, 0.9fr) minmax(360px, 1.25fr);
  gap: 18px;
  align-items: start;
}

.document-flow-note {
  margin: 14px 0;
  padding: 14px 16px;
  border-radius: var(--radius-md);
  color: #d9f8ff;
  background: rgba(31, 209, 249, 0.08);
  border: 1px solid rgba(31, 209, 249, 0.18);
}

.document-request-list {
  max-height: 70vh;
  overflow: auto;
  padding-right: 4px;
}

.document-request-card {
  padding: 15px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.055);
  cursor: pointer;
  transition: border-color .2s ease, transform .2s ease, background .2s ease;
}

.document-request-card + .document-request-card { margin-top: 10px; }
.document-request-card:hover, .document-request-card.active {
  border-color: rgba(255, 179, 71, .42);
  background: rgba(255,255,255,.075);
  transform: translateY(-1px);
}
.document-request-card h4 { margin: 6px 0; }
.document-request-card p { margin: 4px 0; color: var(--muted); }

.document-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.document-detail-grid .record-section.full { grid-column: 1 / -1; }
.copy-link-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: end;
  margin: 12px 0;
}
.copy-link-row input { min-width: 0; }

.signature-portal.hidden { display: none; }
.signature-portal {
  min-height: 100vh;
  padding: 24px;
  background:
    radial-gradient(circle at 10% 5%, rgba(31,209,249,.15), transparent 28%),
    radial-gradient(circle at 90% 5%, rgba(255,122,24,.14), transparent 26%),
    var(--bg);
}
.signature-shell {
  width: min(1100px, 100%);
  margin: 0 auto;
}
.signature-header {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  margin-bottom: 18px;
  padding: 18px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: rgba(255,255,255,.045);
}
.signature-header h1 { margin: 0 0 4px; }
.signature-header p { margin: 0; color: var(--muted); }
.signature-card {
  margin-top: 18px;
  padding: 20px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: rgba(255,255,255,.055);
}
.signature-card h2 { margin-top: 0; }
#signatureCanvas {
  width: 100%;
  max-width: 100%;
  height: 220px;
  display: block;
  margin: 14px 0;
  border-radius: var(--radius-md);
  border: 1px dashed rgba(255,255,255,.28);
  background: rgba(255,255,255,.92);
  cursor: crosshair;
}
.signature-consent { margin: 12px 0; }
.signed-stamp {
  padding: 12px;
  border-radius: 12px;
  border: 1px solid rgba(36,209,126,.28);
  background: rgba(36,209,126,.09);
  color: #d7ffea;
}
.signed-image {
  display: block;
  max-width: 320px;
  max-height: 120px;
  margin-top: 8px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid #d8d8d8;
}
.backend-status-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.backend-status-item {
  padding: 12px;
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.09);
}
.backend-status-item strong { display:block; }
.backend-status-item span { color: var(--muted); font-size: .92rem; }

@media (max-width: 900px) {
  .documents-layout,
  .document-detail-grid,
  .backend-status-grid,
  .copy-link-row {
    grid-template-columns: 1fr;
  }
  .panel-actions { justify-content: flex-start; }
  .signature-portal { padding: 12px; }
  .signature-header { flex-direction: column; align-items: flex-start; }
}

@media print {
  .panel-actions,
  .document-flow-note,
  .document-request-list,
  .signature-card,
  .signature-header,
  .sidebar,
  .topbar {
    display: none !important;
  }
}

/* v5: document signing + easier availability controls */
.mini-label {
  display: block;
  margin: 12px 0 8px;
  color: var(--muted);
  font-size: .86rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.days-off-manager {
  margin-top: 12px;
  padding: 12px;
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.085);
}
.days-off-row {
  display: grid;
  grid-template-columns: minmax(160px, 240px) auto;
  gap: 10px;
  align-items: end;
}
.days-off-chip-list {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 10px;
}
.day-off-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 9px;
  border-radius: 999px;
  background: rgba(255, 179, 71, .12);
  border: 1px solid rgba(255, 179, 71, .24);
  color: #fff2cf;
  font-weight: 800;
  font-size: .86rem;
}
.chip-remove {
  width: 22px;
  height: 22px;
  padding: 0;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.18);
  color: #fff;
  line-height: 1;
}
.muted-small {
  color: var(--muted);
  font-size: .9rem;
}
.employee-self-availability .availability-card {
  margin-top: 0;
}
.estimate-signature-choice {
  margin: 16px 0;
  padding: 16px;
  border-radius: var(--radius-lg);
  background: rgba(255, 179, 71, .08);
  border: 1px solid rgba(255, 179, 71, .25);
}
.estimate-signature-choice.hidden {
  display: none;
}
.estimate-signature-choice h3 {
  margin: 0 0 6px;
}
.estimate-signature-choice p {
  color: var(--muted);
  margin: 0 0 10px;
}
.radio-card {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 11px 12px;
  margin: 8px 0;
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.045);
  border: 1px solid rgba(255,255,255,.09);
  color: var(--text);
  cursor: pointer;
  transition: border-color .18s ease, background .18s ease, box-shadow .18s ease;
}
.radio-card:hover {
  border-color: rgba(255,179,71,.35);
  background: rgba(255,179,71,.08);
}
.radio-card.selected {
  border-color: rgba(255,179,71,.72);
  background: rgba(255,179,71,.14);
  box-shadow: 0 0 0 3px rgba(255,179,71,.08);
}
.radio-card input {
  width: auto;
  min-height: auto;
  margin-top: 4px;
  accent-color: var(--primary);
}
.signed-stamp {
  border-color: rgba(36,209,126,.42) !important;
  background: rgba(36,209,126,.08) !important;
}
.signed-stamp h3 {
  color: #d7ffea;
}
.signed-image {
  max-width: 340px;
  max-height: 130px;
  background: #fff;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 12px;
  padding: 6px;
}
.estimate-limit-field {
  max-width: 280px;
  margin-left: 26px;
}
.estimate-choice-stamp {
  border-color: #ffb347 !important;
  background: #fff8ec !important;
}

@media (max-width: 640px) {
  .days-off-row {
    grid-template-columns: 1fr;
  }
  .estimate-limit-field {
    max-width: none;
    margin-left: 0;
  }
}

/* v7 workflow, catalog, archive, and backup additions */
.job-packet-layout { align-items: start; }
.job-packet-detail { display: grid; gap: 16px; }
.packet-hero {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  padding: 18px;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, rgba(255,122,24,.12), rgba(31,209,249,.08));
  border: 1px solid rgba(255,255,255,.12);
}
.packet-hero h3 { margin: 8px 0 4px; font-size: 1.45rem; }
.packet-hero p { color: var(--muted); margin: 0; }
.packet-total { text-align: right; min-width: 160px; }
.packet-total span, .packet-total small { color: var(--muted); display: block; }
.packet-total strong { display: block; font-size: 1.55rem; color: var(--primary-2); }
.workflow-progress { height: 12px; border-radius: 999px; overflow: hidden; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.08); }
.workflow-progress span { display: block; height: 100%; border-radius: inherit; background: linear-gradient(135deg, var(--primary-2), var(--primary)); }
.workflow-checklist { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.workflow-step {
  display: flex;
  gap: 10px;
  padding: 12px;
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.045);
  border: 1px solid rgba(255,255,255,.09);
}
.workflow-step > span { width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; flex: 0 0 auto; background: rgba(255,255,255,.08); font-weight: 900; }
.workflow-step.done { border-color: rgba(36,209,126,.28); background: rgba(36,209,126,.07); }
.workflow-step.done > span { color: #07101d; background: var(--success); }
.workflow-step strong, .workflow-step small { display: block; }
.workflow-step small { color: var(--muted); }
.packet-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.packet-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.service-catalog-layout { display: grid; grid-template-columns: 1.05fr .95fr; gap: 18px; align-items: start; }
.catalog-form { align-content: start; }
.catalog-list-panel { margin-bottom: 0; }
.catalog-item-card, .backup-card {
  padding: 16px;
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.045);
  border: 1px solid rgba(255,255,255,.1);
  margin-bottom: 12px;
}
.catalog-item-card h4, .backup-card h4 { margin: 8px 0 6px; }
.catalog-item-card p, .backup-card p { margin: 6px 0; color: var(--muted); }
.document-archive-panel { margin-top: 18px; background: rgba(255,255,255,.035); }
.history-table-wrap { overflow-x: auto; }
.backup-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.backup-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 10px; }
.availability-card .field { margin-top: 10px; }
.badge.danger { color: #ffe2e6; background: rgba(255,95,109,.14); border: 1px solid rgba(255,95,109,.28); }

@media (max-width: 1100px) {
  .service-catalog-layout, .backup-grid, .packet-grid { grid-template-columns: 1fr; }
  .workflow-checklist { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
  .packet-hero { display: block; }
  .packet-total { text-align: left; margin-top: 14px; }
}

/* v8 parts search + selected job card improvements */
.record-list-item {
  width: 100%;
  text-align: left;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.055);
  color: var(--text);
  padding: 14px;
  cursor: pointer;
  display: grid;
  gap: 5px;
  box-shadow: 0 12px 24px rgba(0,0,0,.14);
  transition: transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}
.record-list-item strong { color: var(--text); font-size: 1rem; }
.record-list-item span { color: var(--muted); font-size: .9rem; }
.record-list-item:hover {
  transform: translateY(-1px);
  border-color: rgba(255,179,71,.32);
  background: rgba(255,255,255,.075);
}
.record-list-item.active {
  border-color: rgba(255,179,71,.72);
  background: linear-gradient(135deg, rgba(255,122,24,.22), rgba(31,209,249,.11));
  box-shadow: 0 16px 34px rgba(255,122,24,.13), inset 4px 0 0 var(--primary-2);
}
.record-list-item.active::after {
  content: "Selected";
  justify-self: start;
  margin-top: 4px;
  padding: 4px 9px;
  border-radius: 999px;
  background: rgba(255,179,71,.18);
  border: 1px solid rgba(255,179,71,.34);
  color: #ffe5bc;
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .02em;
}
.parts-search-callout {
  background: linear-gradient(135deg, rgba(31,209,249,.08), rgba(255,122,24,.08));
}
.parts-search-layout {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(340px, 1.05fr);
  gap: 18px;
  align-items: start;
}
.panel-soft {
  padding: 16px;
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
}
.parts-search-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 14px;
}
.parts-results-panel {
  display: grid;
  gap: 14px;
}
.parts-link-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}
.parts-vendor-card {
  display: grid;
  gap: 6px;
  padding: 14px;
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.11);
  color: var(--text);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
  min-height: 122px;
}
.parts-vendor-card:hover {
  transform: translateY(-2px);
  border-color: rgba(31,209,249,.36);
  background: rgba(31,209,249,.08);
}
.parts-vendor-card strong { color: var(--primary-2); font-size: 1.05rem; }
.parts-vendor-card span { color: var(--muted); font-size: .92rem; }
.parts-vendor-card small {
  color: #9eb4d1;
  overflow-wrap: anywhere;
  font-size: .78rem;
}
.parts-search-tips ol {
  margin: 8px 0 0 20px;
  color: var(--muted);
}
.parts-search-tips li + li { margin-top: 6px; }
.parts-mini-panel { border-color: rgba(31,209,249,.2); }

@media (max-width: 980px) {
  .parts-search-layout { grid-template-columns: 1fr; }
  .parts-link-grid { grid-template-columns: 1fr; }
}

/* v9 owner accounting + analytics */
.accounting-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, .8fr);
  gap: 16px;
  align-items: start;
  margin-top: 16px;
}
.accounting-card {
  padding: 18px;
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.045);
  border: 1px solid rgba(255,255,255,.1);
}
.accounting-card h4 { margin: 0 0 12px; }
.accounting-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}
.file-btn { cursor: pointer; }
.sr-only-file {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}
.error-note {
  border-color: rgba(255,95,109,.35) !important;
  background: rgba(255,95,109,.1) !important;
  color: #ffe1e6 !important;
}
.rule-list {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}
.rule-chip {
  padding: 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.1);
  display: grid;
  gap: 4px;
}
.rule-chip strong { color: var(--primary-2); }
.rule-chip span { color: var(--muted); font-size: .9rem; }
.accounting-summary-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
  margin: 16px 0;
}
.mini-stat { min-height: 112px; }
.accounting-columns,
.analytics-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-items: start;
}
.report-filters {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin: 14px 0 16px;
}
.history-table td .btn { margin-right: 4px; }

@media (max-width: 1180px) {
  .accounting-summary-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .accounting-layout,
  .accounting-columns,
  .analytics-grid { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .accounting-summary-grid,
  .report-filters { grid-template-columns: 1fr; }
}

/* v10 payroll / time clock additions */
.clock-panel,
.payroll-panel,
.payroll-rate-box {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.045);
  padding: 14px;
  margin-top: 14px;
}

.clock-status-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.045);
  padding: 12px 14px;
}

.clock-status-card.clock-open {
  border-color: rgba(36, 209, 126, 0.35);
  background: rgba(36, 209, 126, 0.09);
}

.clock-status-card strong,
.clock-status-card span {
  display: block;
}

.clock-status-card span,
.clock-today-grid {
  color: var(--muted);
  font-size: 0.92rem;
}

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

.clock-today-grid span {
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  padding: 10px 12px;
  background: rgba(0, 0, 0, 0.14);
}

.employee-accepted-card {
  border-color: rgba(255, 179, 71, 0.22);
}

.job-card-header-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-bottom: 8px;
}

.badge.success {
  background: rgba(36, 209, 126, 0.16);
  color: #d7ffea;
  border-color: rgba(36, 209, 126, 0.32);
}

.employee-job-update {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.employee-job-update textarea {
  min-height: 96px;
}

.mini-note-list {
  margin: 12px 0 0;
  padding-left: 18px;
  color: var(--muted);
  font-size: 0.9rem;
}

.payroll-filters {
  margin-bottom: 12px;
}

.payroll-details-panel {
  margin-top: 14px;
}

.payroll-rate-box {
  grid-column: 1 / -1;
}

.payroll-rate-box h5 {
  margin: 0 0 10px;
  color: var(--text);
  font-size: 0.98rem;
}

.btn.ghost:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

@media (max-width: 760px) {
  .clock-action-grid,
  .clock-today-grid {
    grid-template-columns: 1fr;
  }

  .clock-status-card {
    align-items: stretch;
    flex-direction: column;
  }
}

/* v10.1: cleaner Settings organization */
.settings-layout {
  display: grid;
  gap: 18px;
}

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

.settings-card,
.settings-accordion {
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, .045);
  border: 1px solid rgba(255, 255, 255, .10);
  box-shadow: 0 14px 38px rgba(0, 0, 0, .18);
}

.settings-card {
  padding: 18px;
}

.settings-card h4,
.employee-settings-intro h4 {
  margin: 6px 0 8px;
}

.settings-card p,
.employee-settings-intro p {
  color: var(--muted);
}

.settings-kicker {
  display: inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  color: #08111f;
  background: linear-gradient(135deg, var(--primary-2), var(--primary));
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.settings-accordion {
  overflow: hidden;
}

.settings-accordion summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 18px;
  border-bottom: 1px solid rgba(255, 255, 255, .09);
  background: linear-gradient(135deg, rgba(31, 209, 249, .08), rgba(255, 179, 71, .06));
}

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

.settings-accordion summary strong {
  display: block;
  font-size: 1.05rem;
}

.settings-accordion summary small {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-weight: 700;
}

.employee-settings-intro {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  padding: 18px 18px 0;
}

.settings-mini-stats {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.settings-mini-stats span {
  min-width: 110px;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, .055);
  border: 1px solid rgba(255, 255, 255, .10);
  color: var(--muted);
  text-align: center;
  font-weight: 800;
}

.settings-mini-stats strong {
  display: block;
  color: var(--text);
  font-size: 1.25rem;
}

.employee-settings-grid {
  padding: 18px;
}

.employee-settings-grid .availability-card {
  background: rgba(10, 21, 38, .72);
}

@media (max-width: 900px) {
  .settings-card-grid,
  .employee-settings-intro {
    grid-template-columns: 1fr;
    display: grid;
  }

  .settings-mini-stats {
    justify-content: stretch;
  }

  .settings-mini-stats span {
    flex: 1;
  }
}

/* v11 management controls */
.billing-panel,
.employee-add-panel {
  margin-top: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.035);
  padding: 18px;
}

.badge.bad {
  background: rgba(255, 95, 109, 0.13);
  color: #ffd4da;
  border-color: rgba(255, 95, 109, 0.28);
}

.record-customer-card.active,
.record-list-item.active {
  border-color: rgba(255, 179, 71, 0.58);
  box-shadow: 0 0 0 2px rgba(255, 179, 71, 0.14), var(--shadow-sm, 0 10px 28px rgba(0,0,0,.18));
}

.availability-card .form-grid.compact .field.full,
.employee-add-panel .form-grid.compact .field.full {
  grid-column: 1 / -1;
}

.billing-panel .history-table td:last-child {
  min-width: 180px;
}

.employee-settings-panel summary {
  cursor: pointer;
}

.employee-add-panel h4,
.billing-panel h4 {
  margin-top: 0;
}


/* Tax statement and bill/tiller matching helpers */
.tax-statement-panel {
  margin-top: 18px;
}

.tax-filters .check-field {
  align-content: end;
}

.check-row {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 44px;
  color: var(--text);
  font-weight: 700;
}

.check-row input[type="checkbox"] {
  width: auto;
  min-height: auto;
  accent-color: var(--primary);
}

.tax-statement-output {
  margin-top: 14px;
}

.tax-statement-document {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 18px;
  background: rgba(255, 255, 255, 0.035);
}

.tax-statement-title {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 14px;
  flex-wrap: wrap;
}

.tax-statement-title h3 {
  margin: 0;
}

.tax-statement-title p,
.tax-statement-footnote {
  color: var(--muted);
  margin: 4px 0 0;
}

.history-table small {
  color: var(--muted);
}

@media print {
  .tax-statement-document {
    background: white;
    color: #111;
    border-color: #ccc;
  }
}

/* v13: high-use navigation, owner dashboard refresh, and employee request center */
.nav-btn.priority-nav,
.nav-btn[data-view="quickEstimateView"],
.nav-btn[data-view="jobPacketView"] {
  color: #fff4df;
  background: linear-gradient(135deg, rgba(255, 179, 71, .18), rgba(255, 122, 24, .10));
  border-color: rgba(255, 179, 71, .28);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .035), 0 10px 26px rgba(255, 122, 24, .08);
}
.nav-btn.priority-nav::before,
.nav-btn[data-view="quickEstimateView"]::before,
.nav-btn[data-view="jobPacketView"]::before {
  content: "★";
  margin-right: 8px;
  color: var(--primary-2);
}
.nav-btn.priority-nav.active,
.nav-btn[data-view="quickEstimateView"].active,
.nav-btn[data-view="jobPacketView"].active {
  color: #07101d;
  background: linear-gradient(135deg, #ffd166, var(--primary));
}

.dashboard-hero {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
  background:
    radial-gradient(circle at 12% 0%, rgba(255, 179, 71, .20), transparent 34%),
    radial-gradient(circle at 86% 15%, rgba(31, 209, 249, .15), transparent 30%),
    rgba(16, 35, 60, .82);
}
.dashboard-kicker {
  display: inline-flex;
  margin-bottom: 8px;
  padding: 7px 11px;
  border-radius: 999px;
  background: rgba(255, 179, 71, .13);
  color: var(--primary-2);
  border: 1px solid rgba(255, 179, 71, .28);
  font-weight: 950;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .12em;
}
.dashboard-hero h3 { margin: 0 0 6px; font-size: clamp(1.6rem, 4vw, 2.55rem); letter-spacing: -.045em; }
.dashboard-hero p { margin: 0; max-width: 72ch; }
.dashboard-quick-actions { display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-end; }
.owner-stats-grid .stat-card strong { color: var(--primary-2); }
.dashboard-money-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}
.money-card {
  padding: 18px;
  border-radius: var(--radius-xl);
  background: linear-gradient(135deg, rgba(255, 255, 255, .062), rgba(255, 255, 255, .035));
  border: 1px solid rgba(255, 255, 255, .105);
  box-shadow: 0 16px 45px rgba(0, 0, 0, .18);
}
.money-card span { display: block; color: var(--muted); font-weight: 900; margin-bottom: 4px; }
.money-card strong { display: block; font-size: clamp(1.25rem, 3vw, 2rem); color: #d9f8ff; line-height: 1.05; }
.money-card small { display: block; margin-top: 8px; color: var(--muted); font-size: .84rem; }
.dashboard-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.dashboard-panel { min-height: 280px; }
.dashboard-action-list, .dashboard-list, .employee-request-manager-list, .employee-request-list { display: grid; gap: 10px; }
.dashboard-action {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 12px;
  min-height: 58px;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  cursor: pointer;
  text-align: left;
  color: var(--text);
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.10);
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
}
.dashboard-action:hover { transform: translateY(-1px); background: rgba(255,255,255,.08); }
.dashboard-action span { font-weight: 900; }
.dashboard-action strong { font-size: 1.35rem; color: var(--primary-2); }
.dashboard-action.warning { border-color: rgba(255, 209, 102, .28); background: rgba(255, 209, 102, .075); }
.dashboard-action.good { border-color: rgba(36, 209, 126, .18); }
.dashboard-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 13px 14px;
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.052);
  border: 1px solid rgba(255,255,255,.10);
  cursor: pointer;
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
}
.dashboard-row:hover { transform: translateY(-1px); background: rgba(255,255,255,.075); border-color: rgba(255,179,71,.26); }
.dashboard-row strong, .dashboard-row span, .dashboard-row small { display: block; }
.dashboard-row span, .dashboard-row small { color: var(--muted); font-size: .9rem; }
.dashboard-row > div:last-child { text-align: right; display: grid; gap: 6px; justify-items: end; }
.dashboard-workflow-panel { border-color: rgba(31, 209, 249, .17); }

body[data-role-mode="owner"] .nav-group[data-role-group="owner"] {
  border-color: rgba(255, 179, 71, .18);
  background: rgba(255, 179, 71, .045);
}

.employee-header {
  background:
    radial-gradient(circle at 12% 0%, rgba(31,209,249,.16), transparent 34%),
    rgba(16,35,60,.72);
}
.employee-request-panel {
  border-color: rgba(255, 179, 71, .16);
}
.employee-request-form textarea { min-height: 86px; }
.employee-request-history-wrap {
  margin-top: 14px;
  padding: 14px;
  border-radius: var(--radius-lg);
  background: rgba(0,0,0,.12);
  border: 1px solid rgba(255,255,255,.08);
}
.employee-request-history-wrap h4 { margin: 0 0 10px; }
.employee-request-card, .manager-request-card {
  padding: 14px;
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.052);
  border: 1px solid rgba(255,255,255,.10);
}
.manager-request-card.urgent { border-color: rgba(255,95,109,.34); background: rgba(255,95,109,.075); }
.employee-request-card h4, .manager-request-card h4 { margin: 8px 0 5px; }
.employee-request-card p, .manager-request-card p { margin: 4px 0; color: var(--muted); }
.request-title-row { display: flex; flex-wrap: wrap; gap: 7px; align-items: center; }
.badge.success { color: #d9ffea; background: rgba(36,209,126,.1); border-color: rgba(36,209,126,.25); }
.btn.ghost { background: rgba(255,255,255,.04); }
.clock-action-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 14px 0;
}
.employee-job-update { margin-top: 12px; display: grid; gap: 10px; }
.mini-note-list { margin: 12px 0 0; color: var(--muted); }

@media (max-width: 1180px) {
  .dashboard-money-grid, .dashboard-grid { grid-template-columns: 1fr; }
  .dashboard-hero { align-items: stretch; flex-direction: column; }
  .dashboard-quick-actions { justify-content: flex-start; }
}
@media (max-width: 760px) {
  .dashboard-row, .dashboard-action { grid-template-columns: 1fr; }
  .dashboard-row > div:last-child { text-align: left; justify-items: start; }
  .clock-action-grid { grid-template-columns: 1fr; }
}

/* v14 employee view tabs + assignment notifications */
.employee-top-panel {
  border: 1px solid rgba(255,255,255,0.1);
}

.employee-top-grid {
  align-items: end;
}

.employee-clock-field .clock-panel {
  margin: 0;
}

.employee-tab-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 16px 0;
  padding: 8px;
  border-radius: 18px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.09);
}

.employee-tab-btn {
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.055);
  color: var(--muted);
  border-radius: 14px;
  padding: 12px 16px;
  font-weight: 800;
  cursor: pointer;
  transition: 0.18s ease;
}

.employee-tab-btn:hover,
.employee-tab-btn.active {
  color: var(--text);
  background: linear-gradient(135deg, rgba(255,122,24,0.22), rgba(31,209,249,0.14));
  border-color: rgba(255,179,71,0.36);
  box-shadow: 0 14px 28px rgba(0,0,0,0.18);
}

.employee-tab-panel {
  display: none;
}

.employee-tab-panel.active {
  display: block;
}

.employee-jobs-layout {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 16px;
  align-items: start;
}

.primary-work-panel {
  border-color: rgba(255,179,71,0.2);
}

.employee-focus-note {
  margin-bottom: 12px;
}

.employee-notification-list {
  display: grid;
  gap: 10px;
  margin-bottom: 14px;
}

.employee-notification-card {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 14px;
  border-radius: 18px;
  background: rgba(255,255,255,0.045);
  border: 1px solid rgba(255,255,255,0.1);
}

.employee-notification-card.unread {
  background: linear-gradient(135deg, rgba(255,122,24,0.12), rgba(31,209,249,0.08));
  border-color: rgba(255,179,71,0.32);
}

.employee-notification-card h4 {
  margin: 6px 0 4px;
}

.employee-notification-card p {
  margin: 2px 0;
  color: var(--muted);
}

.compact-clock-panel .clock-status-card {
  margin-top: 0;
}

@media (max-width: 960px) {
  .employee-jobs-layout,
  .employee-top-grid {
    grid-template-columns: 1fr;
  }
  .employee-notification-card {
    display: block;
  }
  .employee-notification-card .card-actions {
    margin-top: 10px;
  }
}

/* v15 manager dashboard + employee assignment notification polish */
body[data-role-mode="manager"] .dashboard-money-grid .money-card strong {
  color: var(--text);
}
.manager-kpi-card strong {
  font-size: clamp(1.8rem, 4vw, 2.75rem);
}
.manager-coverage-list .employee-coverage-row .badge.good {
  border-color: rgba(38, 208, 124, 0.35);
}
.manager-coverage-list .employee-coverage-row .badge.bad {
  border-color: rgba(255, 95, 109, 0.35);
}
.employee-notification-settings {
  border-color: rgba(31, 209, 249, 0.22);
  background: rgba(31, 209, 249, 0.06);
}
.employee-tab-bar {
  position: sticky;
  top: 0;
  z-index: 2;
}
body[data-role-mode="employee"] .employee-header + .panel,
body[data-role-mode="employee"] .employee-tab-panel#employeeJobsTab {
  scroll-margin-top: 20px;
}

/* v16 membership + cleaner builder */
.nav-btn.soft-priority {
  color: #d9f8ff;
  border-color: rgba(31,209,249,.22);
  background: linear-gradient(135deg, rgba(31,209,249,.10), rgba(255,179,71,.07));
}
.nav-btn.soft-priority:hover {
  border-color: rgba(31,209,249,.38);
  background: linear-gradient(135deg, rgba(31,209,249,.16), rgba(255,179,71,.11));
}
.builder-collapse {
  padding: 0;
  overflow: hidden;
}
.builder-collapse > summary {
  cursor: pointer;
  list-style: none;
  padding: 16px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  color: var(--primary-2);
  font-weight: 950;
  border-radius: var(--radius-lg);
}
.builder-collapse > summary::-webkit-details-marker { display: none; }
.builder-collapse > summary::after {
  content: "+";
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  color: #07101d;
  background: linear-gradient(135deg, var(--primary-2), var(--primary));
  flex: 0 0 auto;
}
.builder-collapse[open] > summary::after { content: "−"; }
.builder-collapse > summary small {
  display: block;
  color: var(--muted);
  font-weight: 700;
  font-size: .82rem;
  margin-top: 2px;
}
.builder-collapse-body {
  padding: 0 18px 18px;
}
.membership-dashboard {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}
.membership-layout {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  align-items: start;
  margin-bottom: 16px;
}
.membership-layout.two-wide { grid-template-columns: 1fr 1.2fr; }
.panel-soft {
  padding: 18px;
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.09);
}
.membership-box h4,
.panel-soft h4 { margin: 0 0 12px; }
.membership-card.membership-due {
  border-color: rgba(255,209,102,.45);
  box-shadow: 0 0 0 1px rgba(255,209,102,.12), 0 18px 40px rgba(255,209,102,.08);
}
.muted-record {
  opacity: .66;
}
.mini-record {
  padding: 12px;
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.052);
  border: 1px solid rgba(255,255,255,.09);
  margin-top: 8px;
}
.mini-record strong,
.mini-record small { display: block; }
.mini-record small { color: var(--muted); margin-top: 3px; }
@media (max-width: 980px) {
  .membership-dashboard,
  .membership-layout,
  .membership-layout.two-wide { grid-template-columns: 1fr; }
}

/* v17 sharpening: setup, today mode, audit, validation, communication, files */
.setup-summary-grid,
.today-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}
.setup-checklist {
  display: grid;
  gap: 16px;
}
.setup-group {
  border: 1px solid var(--line);
  background: var(--card);
  border-radius: var(--radius-lg);
  padding: 16px;
}
.setup-group h4 { margin: 0 0 12px; }
.setup-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px;
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.08);
  margin-bottom: 10px;
}
.setup-item > span {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: inline-grid;
  place-items: center;
  font-weight: 900;
  flex: 0 0 auto;
}
.setup-item.done > span { background: rgba(36, 209, 126, .18); color: #b8ffd9; }
.setup-item.todo > span { background: rgba(255, 179, 71, .18); color: #ffdc9a; }
.setup-item strong { display: block; }
.setup-item small { display: block; color: var(--muted); margin-top: 2px; }
.today-mode-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.backup-warning-box.warning,
.doc-readiness.warning {
  border-color: rgba(255, 179, 71, .38);
  background: rgba(255, 179, 71, .08);
}
.doc-readiness.good {
  border-color: rgba(36, 209, 126, .28);
  background: rgba(36, 209, 126, .06);
}
.doc-readiness-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.doc-readiness ul {
  margin: 8px 0 0 18px;
  color: var(--muted);
}
.good-text { color: #b8ffd9 !important; }
.communication-log-section .communication-form,
.attachment-section .form-grid {
  margin-bottom: 14px;
  padding: 12px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.12);
}
.timeline-list {
  display: grid;
  gap: 10px;
}
.timeline-item {
  border: 1px solid rgba(255,255,255,.09);
  background: rgba(255,255,255,.04);
  border-radius: var(--radius-md);
  padding: 12px;
}
.timeline-item strong,
.timeline-item span { display: block; }
.timeline-item span { color: var(--muted); font-size: .92rem; margin-top: 3px; }
.permission-card .mini-table td { vertical-align: top; }
@media (max-width: 900px) {
  .setup-summary-grid,
  .today-summary-grid,
  .today-mode-grid,
  .doc-readiness-grid {
    grid-template-columns: 1fr;
  }
}
