:root {
  --bg: #0b0b0c;
  --panel: #121214;
  --panel-2: #18181b;
  --text: #f5f5f5;
  --muted: #a1a1aa;
  --border: #27272a;
  --accent: #ffffff;
  --accent-text: #0b0b0c;
  --soft: #1f1f23;
  --success-bg: #1f2a22;
  --success-text: #d4f7dd;
  --danger: #7f1d1d;
  --shadow: 0 18px 40px rgba(0, 0, 0, 0.35);
  --radius: 18px;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
}

body {
  font-family: 'Figtree', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background:
    radial-gradient(circle at top left, #1a1a1f 0%, #0b0b0c 40%),
    linear-gradient(180deg, #0b0b0c 0%, #09090b 100%);
  color: var(--text);
}

.wrap {
  max-width: 1280px;
  margin: 0 auto;
  padding: 28px;
}

.topbar {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 24px;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 24px;
  padding: 22px;
  border: 1px solid var(--border);
  border-radius: 22px;
  background: rgba(18, 18, 20, 0.92);
  box-shadow: var(--shadow);
}

.topbar-copy {
  flex: 1 1 420px;
  min-width: 0;
}

.topbar-actions {
  margin-left: auto;
  justify-content: flex-end;
  align-self: center;
}

h1 {
  margin: 0;
  font-size: 30px;
  letter-spacing: -0.02em;
}

.sub {
  color: var(--muted);
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.5;
  max-width: 760px;
}

.tabs {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

button,
.tab-link,
.btn-link,
.primary-btn,
.ghost-btn,
.danger-btn {
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 12px 16px;
  cursor: pointer;
  font-weight: 700;
  font-size: 14px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: 0.18s ease;
}

button:hover,
.tab-link:hover,
.btn-link:hover,
.primary-btn:hover,
.ghost-btn:hover,
.danger-btn:hover {
  transform: translateY(-1px);
}

.tab-link,
.ghost-btn {
  background: var(--panel-2);
  color: var(--text);
}

.tab-link.active {
  background: var(--accent);
  color: var(--accent-text);
  border-color: var(--accent);
}

.primary-btn {
  background: var(--accent);
  color: var(--accent-text);
  border-color: var(--accent);
}

.danger-btn {
  background: #2a1111;
  color: #ffd7d7;
  border-color: #4b1d1d;
}

.grid {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(340px, 0.82fr);
  gap: 22px;
  align-items: start;
}

.card {
  background: rgba(18, 18, 20, 0.96);
  border: 1px solid var(--border);
  border-radius: 22px;
  box-shadow: var(--shadow);
  padding: 24px;
}

.card h2 {
  margin: 0 0 8px;
  font-size: 22px;
  letter-spacing: -0.01em;
}

.card p.helper {
  margin: 0 0 18px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.55;
}

.section {
  margin-top: 18px;
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(31,31,35,0.72) 0%, rgba(18,18,20,0.9) 100%);
}

.section:first-of-type {
  margin-top: 0;
}

.section h3 {
  margin: 0 0 14px;
  font-size: 16px;
  letter-spacing: -0.01em;
}

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

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

.field,
.line-item {
  display: flex;
  flex-direction: column;
  gap: 7px;
}

label {
  font-size: 13px;
  font-weight: 700;
  color: #e5e5e5;
}

input,
select,
textarea {
  width: 100%;
  border: 1px solid #313136;
  border-radius: 14px;
  padding: 12px 13px;
  font-size: 14px;
  background: #0f0f11;
  color: var(--text);
  outline: none;
  color-scheme: dark;
}

input[type="number"] {
  color-scheme: dark;
}

input::placeholder,
textarea::placeholder {
  color: #7b7b85;
}

input:focus,
select:focus,
textarea:focus {
  border-color: #66666f;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.08);
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus {
  -webkit-text-fill-color: var(--text) !important;
  caret-color: var(--text);
  -webkit-box-shadow: 0 0 0px 1000px #0f0f11 inset !important;
  box-shadow: 0 0 0px 1000px #0f0f11 inset !important;
  transition: background-color 99999s ease-in-out 0s;
  border: 1px solid #313136 !important;
  background-color: #0f0f11 !important;
}

textarea {
  min-height: 110px;
  resize: vertical;
}

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

.checkbox {
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid #2f2f34;
  border-radius: 16px;
  padding: 13px 14px;
  background: #101013;
  min-height: 52px;
  color: var(--text);
}

.checkbox input {
  width: auto;
  margin: 0;
  accent-color: #ffffff;
}

.results {
  position: sticky;
  top: 18px;
}

.summary-box {
  background: linear-gradient(180deg, #16161a 0%, #101012 100%);
}

.money {
  font-size: 36px;
  font-weight: 800;
  margin: 10px 0 6px;
  letter-spacing: -0.02em;
}

.small-muted {
  font-size: 13px;
  color: var(--muted);
}

.price-compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 16px;
}

.compare-card {
  border: 1px solid var(--border);
  border-radius: 16px;
  background: #101013;
  padding: 16px;
}

.compare-card-accent {
  background: #f5f5f5;
  color: #111111;
  border-color: #ffffff;
}

.compare-card-accent .compare-label,
.compare-card-accent .compare-note {
  color: #3f3f46;
}

.compare-label {
  font-size: 12px;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.compare-money {
  font-size: 28px;
  font-weight: 800;
  margin-top: 6px;
}

.compare-note {
  font-size: 12px;
  color: var(--muted);
  margin-top: 6px;
}

.breakdown {
  margin-top: 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.breakdown-row {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  font-size: 14px;
  padding-bottom: 10px;
  border-bottom: 1px dashed #2d2d32;
}

.breakdown-row.total {
  font-weight: 800;
  font-size: 16px;
  border-bottom: 0;
  padding-top: 8px;
}

.pill {
  display: inline-block;
  background: var(--success-bg);
  color: var(--success-text);
  padding: 8px 11px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  margin-top: 10px;
}

.hidden { display: none; }

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

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

.footer-note {
  margin-top: 18px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.6;
}

.quote-box {
  white-space: pre-wrap;
  background: #08080a;
  color: #ececf1;
  border: 1px solid #232327;
  border-radius: 16px;
  padding: 16px;
  font-size: 13px;
  line-height: 1.65;
  margin-top: 16px;
}

.invoice-print-area {
  display: none;
}

.invoice-sheet {
  background: #ffffff;
  color: #111827;
  padding: 32px;
  font-family: 'Figtree', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

.invoice-header {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: center;
  border-bottom: 2px solid #e5e7eb;
  padding-bottom: 16px;
  margin-bottom: 20px;
}

.invoice-title {
  font-size: 28px;
  font-weight: 800;
  margin: 0 0 8px;
}

.invoice-meta,
.invoice-block,
.invoice-total-row,
.invoice-line {
  font-size: 14px;
  line-height: 1.5;
}

.invoice-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-bottom: 20px;
}

.invoice-block-title {
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  color: #6b7280;
  letter-spacing: 0.04em;
  margin-bottom: 6px;
}

.invoice-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 16px;
}

.invoice-table th,
.invoice-table td {
  text-align: left;
  padding: 10px 8px;
  border-bottom: 1px solid #e5e7eb;
  font-size: 14px;
  vertical-align: top;
}

.invoice-table th:last-child,
.invoice-table td:last-child {
  text-align: right;
}

.invoice-totals {
  margin-top: 18px;
  margin-left: auto;
  width: 320px;
  max-width: 100%;
}

.invoice-total-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 0;
  border-bottom: 1px solid #e5e7eb;
}

.invoice-total-row.grand-total {
  font-size: 18px;
  font-weight: 800;
  border-bottom: 2px solid #111827;
}

.invoice-notes {
  margin-top: 24px;
  padding-top: 16px;
  border-top: 1px solid #e5e7eb;
  white-space: pre-wrap;
}



.dashboard-card-header-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 18px;
}

.dashboard-card-header-row-tight {
  margin-bottom: 16px;
}

.dashboard-card-header-row h2,
.dashboard-section-title {
  margin: 0 0 6px;
}

.workspace-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: #141418;
  border: 1px solid var(--border);
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.dashboard-tabs-card {
  overflow: hidden;
}

.dashboard-subtabs {
  display: flex;
  flex-wrap: nowrap;
  gap: 10px;
  margin-bottom: 18px;
  overflow-x: auto;
  scrollbar-width: thin;
}

.dashboard-subtab {
  border: 1px solid var(--border);
  background: #101013;
  color: var(--muted);
  border-radius: 999px;
  padding: 11px 15px;
  font-weight: 700;
  cursor: pointer;
}

.dashboard-subtab:hover,
.dashboard-subtab:focus-visible {
  color: var(--text);
  border-color: rgba(255,255,255,0.18);
}

.dashboard-subtab.active {
  background: var(--accent);
  color: var(--accent-text);
  border-color: transparent;
}

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

.dashboard-tab-panel.active {
  display: block;
  padding-top: 14px;
}

.dashboard-tab-panels .entity-list {
  margin-top: 16px;
}


.dashboard-inline-section {
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,0.08);
}

.dashboard-inline-section-head {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 12px;
}

.dashboard-inline-section-head h4 {
  margin: 0;
  font-size: 1rem;
}

.dashboard-activity-card {
  margin-top: 22px;
}

.activity-list-wide {
  max-height: none;
  padding-right: 0;
}

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

@media (max-width: 980px) {
  .topbar-actions {
    margin-left: 0;
    justify-content: flex-start;
  }
}

@media (max-width: 980px) {
  .grid,
  .fields,
  .fields.three,
  .settings-list,
  .inline-checks,
  .price-compare {
    grid-template-columns: 1fr;
  }

  .results {
    position: static;
  }

  .wrap {
    padding: 16px;
  }

  .topbar,
  .card {
    padding: 18px;
  }
}

@media print {
  body * {
    visibility: hidden !important;
  }

  #invoicePrintArea,
  #invoicePrintArea * {
    visibility: visible !important;
  }

  #invoicePrintArea {
    display: block !important;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    background: #ffffff;
  }

  .invoice-sheet {
    padding: 20px;
  }
}

.summary-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 14px 0 14px;
}

.mini-summary-card {
  min-width: 0;
  border: 1px solid var(--border);
  background: #101013;
  border-radius: 16px;
  padding: 14px;
}

.summary-cards .mini-summary-card:first-child {
  grid-column: 1 / -1;
  padding: 16px 18px;
}

.summary-cards .mini-summary-card:first-child .mini-summary-value {
  font-size: clamp(30px, 4vw, 42px);
}

.mini-summary-value {
  min-width: 0;
  font-size: clamp(24px, 3vw, 30px);
  font-weight: 800;
  margin-top: 6px;
  line-height: 1.08;
  letter-spacing: -0.02em;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.warning-box {
  margin: 0 0 14px;
  border: 1px solid #5c2e11;
  background: #2a180d;
  color: #ffd9b3;
  padding: 12px 14px;
  border-radius: 14px;
  font-size: 13px;
  font-weight: 700;
}

.conditional-group {
  margin-top: 16px;
  padding: 16px;
  border: 1px dashed #3a3a40;
  border-radius: 16px;
  background: rgba(12, 12, 14, 0.55);
}

.conditional-title {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 10px;
}

.conditional-checks {
  margin-top: 10px;
}

@media (max-width: 980px) {
  .summary-cards {
    grid-template-columns: 1fr;
  }

  .summary-cards .mini-summary-card:first-child {
    grid-column: auto;
  }
}
.section-helper {
  margin: 0 0 14px;
}

.alert {
  margin: 0 0 18px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid var(--border);
  font-size: 14px;
}

.alert-success {
  background: rgba(31, 42, 34, 0.95);
  color: var(--success-text);
  border-color: rgba(95, 140, 104, 0.45);
}

.alert-error {
  background: rgba(53, 20, 20, 0.92);
  color: #ffd7d7;
  border-color: rgba(127, 29, 29, 0.55);
}

.auth-wrap {
  max-width: 900px;
}

.auth-grid,
.auth-grid-single {
  display: grid;
  grid-template-columns: 1fr;
  gap: 22px;
}

.auth-card {
  max-width: 640px;
  margin: 0 auto;
}

.stack-form {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.inline-checkbox {
  display: inline-flex;
}

.auth-actions,
.workspace-actions {
  margin-top: 14px;
}

.quote-workspace-actions-grid,
.quote-summary-actions-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.quote-workspace-actions-grid > *,
.quote-summary-actions-grid > * {
  min-width: 0;
}

.quote-workspace-actions-grid .primary-btn,
.quote-workspace-actions-grid .ghost-btn,
.quote-workspace-actions-grid .danger-btn,
.quote-summary-actions-grid .primary-btn,
.quote-summary-actions-grid .ghost-btn,
.quote-summary-actions-grid .danger-btn,
.quote-workspace-actions-grid form,
.quote-summary-actions-grid form {
  width: 100%;
}

.quote-workspace-actions-grid form button,
.quote-summary-actions-grid form button {
  width: 100%;
}

.quote-workspace-actions-grid .primary-btn,
.quote-workspace-actions-grid .ghost-btn,
.quote-workspace-actions-grid .danger-btn,
.quote-summary-actions-grid .primary-btn,
.quote-summary-actions-grid .ghost-btn,
.quote-summary-actions-grid .danger-btn {
  justify-content: center;
}

.save-status-box {
  min-height: 48px;
  display: flex;
  align-items: center;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid #313136;
  background: #0f0f11;
  color: var(--muted);
  font-size: 14px;
}

.save-status-box.is-success {
  color: var(--success-text);
  border-color: rgba(95, 140, 104, 0.35);
}

.save-status-box.is-error {
  color: #ffd7d7;
  border-color: rgba(127, 29, 29, 0.55);
}

.saved-quotes-panel {
  margin-bottom: 18px;
}

.saved-quotes-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.saved-quote-item {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: #101013;
  color: var(--text);
  text-decoration: none;
}

.saved-quote-item.is-active {
  border-color: rgba(255,255,255,0.4);
  box-shadow: 0 0 0 1px rgba(255,255,255,0.08) inset;
}

.saved-quote-title {
  font-weight: 700;
  margin-bottom: 4px;
}

.saved-quote-meta,
.saved-quote-totals {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.saved-quote-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.dashboard-list .saved-quote-item {
  text-decoration: none;
}

.empty-state {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 16px;
  border-radius: 16px;
  border: 1px dashed #34343a;
  color: var(--muted);
  background: rgba(16,16,19,0.8);
}

@media (max-width: 900px) {
  .saved-quote-item {
    flex-direction: column;
    align-items: flex-start;
  }
}

body.modal-open {
  overflow: hidden;
}

button,
a,
select,
input[type="checkbox"] {
  cursor: pointer;
}

button,
.tab-link,
.primary-btn,
.ghost-btn,
.danger-btn,
.auth-modal-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  text-decoration: none;
  font: inherit;
  line-height: 1;
}

button.tab-link,
button.primary-btn,
button.ghost-btn,
button.danger-btn {
  appearance: none;
  -webkit-appearance: none;
}

.tabs form,
.actions form,
.saved-quote-actions form {
  margin: 0;
}

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

.topbar > :first-child {
  flex: 1 1 620px;
  min-width: 0;
}

.tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.topbar .tabs {
  flex: 0 0 auto;
  margin-left: auto;
  justify-content: flex-end;
  align-self: center;
}

.topbar .tab-link,
.actions .primary-btn,
.actions .ghost-btn,
.actions .danger-btn,
.saved-quote-actions .ghost-btn,
.full-width-btn {
  min-height: 44px;
}

.workspace-card {
  margin-bottom: 18px;
}

.saved-quote-open-badge {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #2f2f34;
  background: #141418;
  color: var(--muted);
  flex: 0 0 auto;
}

.saved-quote-item:hover .saved-quote-open-badge {
  color: var(--text);
  border-color: rgba(255,255,255,0.2);
}

.empty-state {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 16px;
  border-radius: 16px;
  background: #101013;
  border: 1px dashed #34343a;
  color: var(--muted);
}

.dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(340px, 0.8fr);
  gap: 22px;
  align-items: start;
}

.dashboard-side-stack {
  display: grid;
  gap: 22px;
}

.dashboard-quote-row {
  align-items: start;
}

.dashboard-quote-row > :first-child {
  flex: 1 1 0%;
  min-width: 0;
}

.entity-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 18px;
}

.entity-item {
  padding: 14px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: #101013;
}

.entity-item-title {
  font-weight: 700;
  margin-bottom: 4px;
}

.entity-item-meta {
  font-size: 13px;
  color: var(--muted);
}



.activity-list {
  max-height: 780px;
  overflow: auto;
  padding-right: 4px;
}

.activity-item {
  display: grid;
  gap: 10px;
}

.activity-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.activity-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: #141418;
  padding: 8px 12px;
  font-size: 12px;
  color: var(--muted);
}

.compact-empty-state {
  margin-top: 18px;
}

.full-width-btn {
  width: 100%;
}

.field-error {
  color: #ffbdbd;
  font-size: 12px;
  font-weight: 700;
}

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

.password-field-wrap input {
  padding-right: 52px;
}

.password-toggle-btn {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: none;
}

.password-toggle-btn:hover,
.password-toggle-btn:focus-visible {
  color: var(--text);
  background: transparent;
  border: 0;
  box-shadow: none;
  transform: translateY(-50%);
}

.password-toggle-btn:focus-visible {
  outline: 2px solid rgba(255,255,255,0.18);
  outline-offset: 2px;
  border-radius: 8px;
}

.password-toggle-btn i {
  pointer-events: none;
}

.auth-modal-root {
  position: fixed;
  inset: 0;
  z-index: 9999;
}

.auth-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(4, 4, 6, 0.58);
  backdrop-filter: blur(10px);
}

.auth-modal-dialog {
  position: relative;
  width: min(560px, calc(100vw - 28px));
  max-height: calc(100vh - 28px);
  overflow: auto;
  margin: 14px auto;
  top: 50%;
  transform: translateY(-50%);
}

.auth-modal-dialog.card {
  padding: 26px;
}

.auth-modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 2;
}

.auth-modal-close:hover,
.auth-modal-close:focus-visible {
  transform: none;
}

.icon-only-btn {
  width: 42px;
  height: 42px;
  padding: 0;
}

.auth-modal-switcher {
  display: inline-flex;
  gap: 8px;
  padding: 6px;
  border-radius: 999px;
  background: #101013;
  border: 1px solid var(--border);
  margin-bottom: 18px;
}

.auth-modal-tab {
  border: 1px solid transparent;
  background: transparent;
  color: var(--muted);
  border-radius: 999px;
  padding: 12px 18px;
}

.auth-modal-tab.active {
  background: var(--accent);
  color: var(--accent-text);
}

.auth-modal-panel h2 {
  margin: 0 0 8px;
}

@media (max-width: 980px) {
  .dashboard-grid {
    grid-template-columns: 1fr;
  }

  .dashboard-card-header-row {
    flex-direction: column;
  }

  .grid-2 {
    grid-template-columns: 1fr;
  }

  .topbar {
    flex-direction: column;
  }

  .tabs {
    width: 100%;
  }

  .tabs > * {
    flex: 1 1 auto;
  }
}


body,
button,
input,
select,
textarea {
  font-family: 'Figtree', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

.tabs form,
.actions form,
.saved-quote-actions form,
.workspace-actions form {
  display: inline-flex;
}

.tab-link i,
.primary-btn i,
.ghost-btn i,
.danger-btn i,
.btn-link i {
  font-size: 14px;
  line-height: 1;
}

.ghost-btn {
  background: var(--panel-2);
  color: var(--text);
}

.ghost-btn,
.primary-btn,
.danger-btn,
.tab-link {
  white-space: nowrap;
}


@media (min-width: 981px) {
  .topbar {
    flex-wrap: nowrap;
    align-items: flex-start;
  }

  .topbar-copy,
  .topbar > :first-child {
    flex: 1 1 auto;
    min-width: 0;
  }

  .topbar .tabs,
  .topbar-actions {
    flex: 0 0 auto;
    width: auto;
    margin-left: auto;
    justify-content: flex-end;
    align-self: flex-start;
    gap: 8px;
  }

  .topbar .tab-link,
  .topbar .tabs button.tab-link,
  .topbar .tabs a.tab-link {
    padding: 10px 14px;
    min-height: 42px;
    font-size: 0.98rem;
  }

  .topbar .tab-link span {
    white-space: nowrap;
  }
}


.status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid var(--border);
  background: #151519;
  color: var(--muted);
}

.status-badge.status-draft {
  background: #17171b;
  color: #d4d4d8;
}

.status-badge.status-sent {
  background: rgba(28, 50, 86, 0.45);
  color: #dbeafe;
  border-color: rgba(96, 165, 250, 0.35);
}

.status-badge.status-accepted {
  background: rgba(20, 83, 45, 0.35);
  color: #dcfce7;
  border-color: rgba(74, 222, 128, 0.35);
}

.status-badge.status-declined {
  background: rgba(127, 29, 29, 0.32);
  color: #fee2e2;
  border-color: rgba(248, 113, 113, 0.35);
}

.saved-quote-response-note {
  margin-top: 10px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 12px;
  font-size: 13px;
  line-height: 1.45;
  border: 1px solid var(--border);
}

.saved-quote-response-note.accepted-note {
  background: rgba(20, 83, 45, 0.18);
  color: #dcfce7;
}

.saved-quote-response-note.declined-note {
  background: rgba(127, 29, 29, 0.18);
  color: #fee2e2;
}

.response-state {
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 16px;
  background: #101013;
}

.response-state-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 800;
  margin-bottom: 8px;
}

.response-state-accepted {
  border-color: rgba(74, 222, 128, 0.25);
  background: rgba(20, 83, 45, 0.14);
}

.response-state-declined {
  border-color: rgba(248, 113, 113, 0.25);
  background: rgba(127, 29, 29, 0.14);
}

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

.saved-quote-title-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 4px;
}

.saved-quote-public-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  color: #d4d4d8;
  font-size: 13px;
  text-decoration: none;
}

.saved-quote-public-link:hover {
  color: #ffffff;
}


.public-shell-topbar {
  margin-bottom: 22px;
}

.public-doc-page-hero {
  margin-bottom: 22px;
}

.public-page-toolbar-actions {
  gap: 10px;
}

.public-page-toolbar-actions .tab-link,
.public-page-toolbar-actions .tab-button {
  min-height: 48px;
}

.document-main-stack {
  display: grid;
  gap: 22px;
}

.public-quote-wrap {
  max-width: 1280px;
}

.public-quote-hero {
  margin-bottom: 22px;
}

.public-quote-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(340px, 0.82fr);
  gap: 22px;
  align-items: start;
}

.public-summary-stack {
  display: grid;
  gap: 22px;
}

.snapshot-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.snapshot-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 10px;
  border-bottom: 1px dashed #2d2d32;
  font-size: 14px;
}

.snapshot-row strong {
  color: #f4f4f5;
}

.snapshot-row span:last-child {
  text-align: right;
}

.workspace-link-row {
  margin-top: 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

@media (max-width: 980px) {
  .public-quote-grid {
    grid-template-columns: 1fr;
  }
}

.status-badge.status-signed {
  background: rgba(20, 83, 45, 0.35);
  color: #dcfce7;
  border-color: rgba(74, 222, 128, 0.35);
}

.contract-document {
  display: grid;
  gap: 14px;
  color: #e4e4e7;
  line-height: 1.65;
}

.contract-document h3 {
  margin: 8px 0 0;
  font-size: 1rem;
  color: #fafafa;
}

.contract-document p,
.contract-document ul {
  margin: 0;
}

.contract-document ul {
  padding-left: 20px;
}

.contract-document li + li {
  margin-top: 6px;
}

.contract-scope-grid {
  display: grid;
  gap: 10px;
}

.checkbox-block {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-top: 8px;
}

.checkbox-block input {
  margin-top: 3px;
}

.entity-item-contract {
  gap: 10px;
}

.invoice-actions-stack,
.invoice-void-form {
  display: grid;
  gap: 10px;
}


.invoice-share-controls form {
  width: 100%;
}

.invoice-share-controls .saved-quote-public-link,
.invoice-share-controls .workspace-link-row,
.invoice-share-controls .invoice-void-form {
  margin-top: 14px;
}

.invoice-share-controls .workspace-link-row {
  display: grid;
  gap: 10px;
}

.invoice-doc-head {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.invoice-line-items {
  margin-top: 10px;
}

.invoice-line-item {
  align-items: flex-start;
  gap: 12px;
}

.invoice-total-box {
  border-top: 1px solid rgba(255,255,255,.08);
  margin-top: 18px;
  padding-top: 14px;
}

.invoice-note-block {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.08);
}

.invoice-note-row {
  margin-top: 8px;
}


.tab-button {
  appearance: none;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  cursor: pointer;
}

.print-only {
  display: none !important;
}

@page {
  margin: 0.35in;
}

@media print {
  html,
  body {
    background: #ffffff !important;
    color: #111827 !important;
  }

  body {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  body * {
    visibility: visible !important;
  }

  .print-hide,
  .topbar-actions,
  .actions,
  .footer-note,
  .alert,
  .auth-modal-overlay,
  .auth-modal-backdrop,
  .auth-modal-shell,
  .floating-auth-btn {
    display: none !important;
  }

  .wrap,
  .public-quote-wrap {
    max-width: none !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  .topbar,
  .public-quote-hero {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 0 14px !important;
    margin: 0 0 18px !important;
  }

  .topbar-copy h1,
  .topbar-copy .sub,
  .card h2,
  .card h3,
  .snapshot-row strong,
  .entity-item-title,
  .contract-document,
  .contract-document h3,
  .helper,
  .quote-box,
  .entity-item-meta,
  .small-muted,
  .mini-summary-value,
  .saved-quote-public-link,
  .saved-quote-public-link:hover {
    color: #111827 !important;
  }

  .topbar-copy .sub,
  .helper,
  .small-muted,
  .entity-item-meta {
    opacity: 1 !important;
    color: #4b5563 !important;
  }

  .public-quote-grid,
  .public-summary-stack,
  .summary-cards,
  .invoice-doc-head,
  .invoice-actions-stack,
  .workspace-link-row {
    display: block !important;
  }

  .card,
  .summary-box,
  .mini-summary-card,
  .quote-box,
  .entity-item {
    background: #ffffff !important;
    border: 1px solid #d1d5db !important;
    box-shadow: none !important;
    break-inside: avoid;
    page-break-inside: avoid;
  }

  .print-document-card {
    break-inside: auto !important;
    page-break-inside: auto !important;
    margin-top: 0 !important;
  }

  .print-document-card > * {
    break-inside: auto !important;
    page-break-inside: auto !important;
  }

  .card {
    padding: 18px !important;
    margin: 0 0 16px !important;
  }

  .print-document-card .helper:first-of-type,
  .print-document-card .section-helper {
    display: none !important;
  }

  .print-document-card h2 {
    margin-top: 0 !important;
  }

  .mini-summary-card {
    margin: 0 0 10px !important;
  }

  .snapshot-row,
  .invoice-total-row,
  .invoice-line-item {
    border-bottom-color: #d1d5db !important;
  }

  .status-badge {
    background: #ffffff !important;
    color: #111827 !important;
    border: 1px solid #9ca3af !important;
  }

  a {
    text-decoration: none !important;
  }

  .public-quote-hero,
  .topbar {
    display: none !important;
  }

  .print-document-card {
    padding: 0 !important;
    margin: 0 0 16px !important;
    border: 0 !important;
    box-shadow: none !important;
    background: #ffffff !important;
  }

  .print-document-card > h2,
  .print-document-card > .helper:first-of-type {
    display: none !important;
  }

  .print-document-card .section,
  .print-document-card .quote-box,
  .print-document-card .invoice-total-box,
  .print-document-card .invoice-note-block,
  .print-document-card .contract-scope-grid {
    margin-top: 14px !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    break-inside: auto !important;
    page-break-inside: auto !important;
  }

  .print-document-card .section:first-of-type,
  .print-document-card .invoice-doc-head:first-child,
  .print-document-card .invoice-total-box:first-child,
  .print-document-card .invoice-note-block:first-child {
    margin-top: 0 !important;
  }

  .print-document-card .quote-box,
  .print-document-card .invoice-total-box,
  .print-document-card .invoice-note-block {
    border-top: 1px solid #d1d5db !important;
    padding-top: 12px !important;
    border-radius: 0 !important;
  }

  .print-document-card .invoice-doc-head {
    margin-bottom: 12px !important;
  }

  .print-document-card .snapshot-row,
  .print-document-card .invoice-line-item {
    padding-bottom: 8px !important;
  }
}

.document-email-note {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  font-size: 13px;
  color: var(--muted);
}

.document-email-note-card {
  display: flex;
  width: 100%;
  margin: 0 0 12px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: #101013;
}

.inline-email-panel {
  margin-top: 12px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: #0f1116;
}

.inline-email-panel summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  padding: 12px 14px;
  cursor: pointer;
  font-weight: 700;
}

.inline-email-panel summary::-webkit-details-marker {
  display: none;
}

.inline-email-panel[open] summary {
  border-bottom: 1px solid var(--border);
}

.inline-email-form {
  padding: 14px;
  margin-top: 0;
}

.inline-email-form .field {
  margin-bottom: 12px;
}

.inline-email-form .field:last-of-type {
  margin-bottom: 14px;
}

.client-portal-grid {
  grid-template-columns: minmax(0, 1.04fr) minmax(300px, 0.96fr);
}

.client-portal-main {
  display: grid;
  gap: 22px;
}

.client-portal-card {
  position: relative;
}

.client-portal-section-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 16px;
}

.client-portal-overview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}

.client-portal-summary-list {
  margin-top: 6px;
}

.client-portal-entity-list {
  gap: 14px;
}

.client-portal-entity-item {
  gap: 10px;
}

.client-portal-stage-list {
  display: grid;
  gap: 12px;
}

.client-portal-stage {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
}

.client-portal-stage i {
  color: #a1a1aa;
  margin-top: 2px;
}

.client-portal-stage.is-complete {
  border-color: rgba(132, 204, 22, .28);
  background: rgba(132, 204, 22, .08);
}

.client-portal-stage.is-complete i {
  color: #bef264;
}

.client-portal-quicklinks {
  display: flex;
}

@media (max-width: 980px) {
  .client-portal-grid {
    grid-template-columns: 1fr;
  }

  .client-portal-overview-grid {
    grid-template-columns: 1fr;
  }
}

@media print {
  .client-portal-overview-grid,
  .client-portal-main,
  .client-portal-stage-list,
  .client-portal-quicklinks {
    display: block !important;
  }

  .client-portal-stage {
    margin: 0 0 10px !important;
    background: #ffffff !important;
    border-color: #d1d5db !important;
  }
}


.change-order-create-form{margin-bottom:14px}
.change-order-line-items{margin-top:18px;padding-top:14px;border-top:1px solid rgba(255,255,255,.08)}
.change-order-line-items-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.change-order-line-items-head h3{margin:0;font-size:1rem}
.change-order-line-items-list{display:flex;flex-direction:column;gap:16px}
.change-order-line-row{display:grid;grid-template-columns:minmax(0,1fr) 180px;gap:14px;padding-bottom:2px}
.change-order-add-row-btn{margin-top:14px}
.change-order-amount-field input{text-align:right}
.change-order-document h3{margin-top:22px}
.change-order-total-row{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:18px;padding:14px 16px;border:1px solid rgba(132,204,22,.25);border-radius:16px;background:rgba(132,204,22,.08);font-size:1.05rem}
.compact-print-list{gap:10px}
@media (max-width: 720px){.change-order-line-row{grid-template-columns:1fr}}
@media print{.change-order-line-items-head,.change-order-line-row .field label{color:#111!important}.change-order-total-row{background:#fff!important;border-color:#ccc!important;color:#111!important}}


.saved-quote-actions{display:grid;gap:12px;align-content:start;flex:0 0 min(48%,360px);min-width:320px}
.saved-quote-actions-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.saved-quote-actions-grid > a,
.saved-quote-actions-grid > form,
.saved-quote-actions-grid > form > button{width:100%}
.saved-quote-actions-grid .ghost-btn,
.saved-quote-actions-grid .primary-btn,
.saved-quote-actions-grid .danger-btn{justify-content:center;width:100%}
.quote-email-under-actions{margin-top:0}
.quote-email-under-actions summary{width:100%;justify-content:center}
.change-order-page-grid{grid-template-columns:minmax(0,1.16fr) minmax(320px,.84fr)}
.change-order-page-grid > *{min-width:0}
.change-order-main-card{min-width:0}
.change-order-summary-stack{align-self:start}
.change-order-line-items{margin-top:18px;padding-top:14px;border-top:1px solid rgba(255,255,255,.08)}
.change-order-line-items-list{display:flex;flex-direction:column;gap:18px}
.change-order-line-row{display:grid;grid-template-columns:minmax(0,1fr) 180px;gap:14px;align-items:end}
.change-order-add-row-btn{margin-top:14px}
.change-order-save-row{margin-top:8px}
.change-order-save-row .primary-btn{width:100%;justify-content:center}
@media (max-width: 980px){
  .saved-quote-actions-grid{grid-template-columns:1fr}
  .change-order-page-grid{grid-template-columns:1fr}
}

.financial-summary-inline {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px dashed rgba(255,255,255,.08);
  display: grid;
  gap: 8px;
}

.financial-summary-inline-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  font-size: 13px;
  color: var(--muted);
}

.financial-summary-inline-row strong {
  color: var(--text);
  font-size: 14px;
}

.financial-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.financial-mini-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.financial-mini-pill {
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  padding: 12px 14px;
  background: rgba(255,255,255,.02);
}

.financial-mini-label {
  display: block;
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 6px;
}

.financial-mini-pill strong {
  display: block;
  font-size: 16px;
}

@media (max-width: 720px) {
  .financial-mini-grid {
    grid-template-columns: 1fr;
  }
}


@media (max-width: 720px) {
  .quote-workspace-actions-grid,
  .quote-summary-actions-grid {
    grid-template-columns: 1fr;
  }
}

.template-settings-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.8fr) minmax(280px, 0.95fr);
  gap: 22px;
  align-items: start;
}

.template-settings-sidebar {
  display: grid;
  gap: 22px;
}

.invoice-template-copy {
  margin-top: 18px;
}

.invoice-template-copy h3 {
  margin-bottom: 10px;
}

.compact-list .entity-item + .entity-item {
  margin-top: 12px;
}

@media (max-width: 980px) {
  .template-settings-grid {
    grid-template-columns: 1fr;
  }
}


.template-settings-grid .section > .field {
  margin-bottom: 14px;
}

.template-settings-grid .section > .field:last-child {
  margin-bottom: 0;
}

.admin-users-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1.35fr);
  gap: 22px;
  align-items: start;
}

.admin-user-list {
  display: grid;
  gap: 16px;
}

.admin-user-item {
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 18px;
  background: linear-gradient(180deg, rgba(22,22,25,0.9) 0%, rgba(13,13,15,0.96) 100%);
}

.admin-user-item-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 14px;
}

.admin-user-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.admin-user-form-grid {
  gap: 14px;
}

.admin-inline-check {
  min-height: 48px;
}

.admin-active-field {
  align-self: end;
}

.admin-user-edit-form {
  margin-top: 6px;
}

@media (max-width: 980px) {
  .admin-users-grid {
    grid-template-columns: 1fr;
  }
}


.admin-users-grid {
  align-items: stretch;
}

.admin-users-grid > .card {
  height: 100%;
  display: flex;
  flex-direction: column;
}

.admin-users-grid > .card .stack-form,
.admin-users-grid > .card .admin-user-list {
  flex: 1 1 auto;
}



.topbar .tab-link,
.topbar-user-link,
.topbar-user-form button {
  font-weight: 700;
}

.topbar .tab-link span,
.topbar-user-link span {
  font-weight: 700;
}

.topbar-user-menu {
  position: relative;
}

.topbar-user-menu summary {
  list-style: none;
}

.topbar-user-menu summary::-webkit-details-marker {
  display: none;
}

.topbar-user-caret {
  font-size: 12px;
  opacity: 0.8;
}

.topbar-user-menu[open] > summary {
  background: var(--accent);
  color: var(--accent-text);
  border-color: var(--accent);
}

.topbar-user-dropdown {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  min-width: 210px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: rgba(18, 18, 20, 0.98);
  box-shadow: var(--shadow);
  display: grid;
  gap: 8px;
  z-index: 50;
}

.topbar-user-link {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--panel-2);
  color: var(--text);
  padding: 11px 13px;
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
}

.topbar-user-link.active {
  background: var(--accent);
  color: var(--accent-text);
  border-color: var(--accent);
}

.topbar-user-form {
  display: block;
  margin: 0;
}

.topbar-user-form .topbar-user-link {
  width: 100%;
}

.topbar-user-form button {
  appearance: none;
  -webkit-appearance: none;
}

@media (max-width: 980px) {
  .topbar-user-menu {
    width: 100%;
  }

  .topbar-user-menu > summary.tab-link {
    width: 100%;
  }

  .topbar-user-dropdown {
    position: static;
    margin-top: 10px;
    min-width: 0;
  }
}


.topbar-user-trigger {
  background: var(--accent) !important;
  color: var(--accent-text) !important;
  border-color: var(--accent) !important;
}

.topbar-user-trigger:hover {
  filter: brightness(0.98);
}

.topbar-user-dropdown {
  text-align: right;
}

.topbar-user-link,
.topbar-user-form .topbar-user-link {
  justify-content: flex-end;
  text-align: right;
}

.template-checkbox-field .checkbox {
  min-height: 48px;
  align-items: center;
}

.template-settings-grid textarea {
  margin-bottom: 10px;
}

.success-note-card {
  color: var(--text);
}

.inline-payment-summary {
  margin: 0 0 12px;
}

.stripe-payment-shell {
  display: grid;
  gap: 12px;
}

.stripe-payment-element {
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(255,255,255,0.02);
}

.stripe-payment-actions {
  display: grid;
  gap: 10px;
}

.stripe-payment-message.error-text {
  color: #fca5a5 !important;
}


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

.document-action-grid .ghost-btn,
.document-action-grid .primary-btn,
.document-action-grid .danger-btn {
  width: 100%;
  justify-content: center;
}

.settings-single-column {
  grid-template-columns: minmax(0, 1fr);
}

@media (max-width: 720px) {
  .document-action-grid {
    grid-template-columns: 1fr;
  }
}

.dashboard-metric-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.metric-card {
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 16px;
  background: linear-gradient(180deg, rgba(22,22,25,0.88) 0%, rgba(12,12,14,0.98) 100%);
}

.metric-card-value {
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 6px 0 8px;
}

.monetization-breakdown-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.compact-snapshot-list {
  gap: 10px;
}

.monetization-payment-item {
  gap: 12px;
}

.public-invoice-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
  gap: 24px;
  margin-bottom: 22px;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.08), transparent 35%),
    linear-gradient(180deg, rgba(21,21,25,0.95) 0%, rgba(12,12,14,0.98) 100%);
}

.public-invoice-hero h2 {
  margin-top: 6px;
  margin-bottom: 8px;
  font-size: clamp(26px, 4vw, 34px);
}

.public-invoice-meta-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 20px;
}

.public-invoice-hero-totals {
  display: grid;
  gap: 12px;
  align-content: start;
  padding: 20px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
}

.public-invoice-balance-label {
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}

.public-invoice-balance {
  font-size: clamp(34px, 6vw, 46px);
  font-weight: 800;
  letter-spacing: -0.03em;
}

.public-invoice-balance-meta {
  display: grid;
  gap: 10px;
  padding-top: 8px;
  border-top: 1px solid rgba(255,255,255,0.08);
}

.public-invoice-grid {
  align-items: start;
}

.public-line-items-card {
  padding: 0;
  overflow: hidden;
}

.public-line-items-card .quote-card-top {
  padding: 24px 24px 0;
}

.public-line-items-table {
  margin-top: 18px;
}

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

.public-line-items-head {
  padding: 0 24px 12px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.public-invoice-line-items {
  gap: 0;
}

.public-invoice-line-item {
  padding: 18px 24px;
  border-top: 1px solid rgba(255,255,255,0.06);
}

.public-invoice-line-item:first-child {
  border-top: 1px solid var(--border);
}

.public-invoice-line-item strong {
  display: block;
  margin-bottom: 4px;
}

.public-invoice-total-box {
  margin: 0;
  border-radius: 0 0 22px 22px;
  border-top: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,0.02) 0%, rgba(255,255,255,0.04) 100%);
  padding-top: 10px;
  padding-bottom: 10px;
}

.public-invoice-total-box .snapshot-row,
.public-invoice-balance-meta .snapshot-row {
  padding-left: 24px;
  padding-right: 24px;
}

.public-invoice-total-box .snapshot-row:last-child,
.public-invoice-balance-meta .snapshot-row:last-child {
  margin-bottom: 0;
}

.total-due-row {
  font-size: 18px;
}

.public-project-summary .snapshot-list,
.public-inline-payment-summary {
  gap: 12px;
}

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

.pay-online-badges {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.public-inline-payment-summary {
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(255,255,255,0.03);
}

@media (max-width: 980px) {
  .dashboard-metric-grid,
  .monetization-breakdown-grid,
  .public-invoice-hero,
  .public-invoice-meta-grid {
    grid-template-columns: 1fr;
  }

  .pay-online-header {
    flex-direction: column;
  }

  .pay-online-badges {
    justify-content: flex-start;
  }
}


.site-footer {
  margin-top: 28px;
  padding: 0 0 28px;
}

.site-footer-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px 24px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,0.08);
}

.site-footer-copy {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.6;
}

.site-footer-copy strong {
  color: var(--text);
}

.site-footer-credit a {
  color: var(--text);
  font-weight: 700;
  text-decoration: none;
}

.site-footer-credit a:hover,
.site-footer-credit a:focus-visible {
  color: var(--text);
  text-decoration: underline;
}

.readonly-setting-box {
  display: grid;
  gap: 6px;
  min-height: 46px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(12, 12, 14, 0.7);
}

.site-footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.site-footer-link {
  color: var(--muted);
  text-decoration: none;
  font-size: 13px;
  font-weight: 700;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 999px;
  background: rgba(18, 18, 20, 0.82);
  transition: 0.18s ease;
}

.site-footer-link:hover,
.site-footer-link.active {
  color: var(--text);
  border-color: rgba(255,255,255,0.16);
  background: rgba(31, 31, 35, 0.95);
}

.legal-page-wrap {
  padding-bottom: 10px;
}


.legal-page-shell {
  display: grid;
  gap: 24px;
}

.legal-page-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px 24px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.legal-page-toolbar-copy {
  flex: 1 1 420px;
  min-width: 0;
}

.legal-page-toolbar-copy .sub {
  max-width: 760px;
}

.legal-page-toolbar-actions {
  margin-left: auto;
  justify-content: flex-end;
}

.legal-page-grid {
  align-items: stretch;
}

.legal-page-single {
  display: block;
}

.legal-eyebrow {
  display: inline-flex;
  align-items: center;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(31,31,35,0.9);
  color: #d4d4d8;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 12px;
}

.legal-document-card {
  display: grid;
  gap: 22px;
}

.legal-document-card--full {
  width: 100%;
}

.legal-document-head {
  display: grid;
  grid-template-columns: minmax(0, 180px) minmax(0, 1fr);
  gap: 16px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.legal-document-head--simple {
  grid-template-columns: 1fr;
  gap: 0;
}

.legal-document-head-note {
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(31,31,35,0.72) 0%, rgba(18,18,20,0.9) 100%);
  padding: 16px 18px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.65;
}

.legal-section-stack {
  display: grid;
  gap: 20px;
}

.legal-section-block {
  display: grid;
  gap: 12px;
  padding: 20px;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 20px;
  background: rgba(9,9,11,0.32);
}

.legal-section-block h2 {
  margin: 0;
  font-size: 20px;
  letter-spacing: -0.01em;
}

.legal-section-block p {
  margin: 0;
  color: #dedee3;
  font-size: 14px;
  line-height: 1.7;
}

.legal-side-card {
  height: fit-content;
}

@media (max-width: 980px) {
  .legal-document-head {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .site-footer-inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .site-footer-links {
    width: 100%;
  }
}


.public-summary-stack > .card:first-child {
  margin-top: 0;
}

@media (max-width: 980px) {
  .public-page-toolbar-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .public-page-toolbar-actions .tab-link,
  .public-page-toolbar-actions .tab-button {
    flex: 0 0 auto;
  }
}


.public-quote-wrap > .public-quote-hero:first-child,
.public-invoice-wrap > .public-doc-page-hero:first-child,
.client-portal-wrap > .public-quote-hero:first-child {
  margin-top: 6px;
}

.workspace-records-tabs .dashboard-tab-panel.active {
  padding-top: 18px;
}

.public-invoice-total-box {
  padding-left: 20px;
  padding-right: 20px;
}

.public-line-items-card {
  margin-bottom: 22px;
}

.public-page-toolbar-actions {
  align-items: center;
}

.public-page-toolbar-actions .tab-link,
.public-page-toolbar-actions .tab-button {
  white-space: nowrap;
}

@media (max-width: 980px) {
  .public-quote-wrap > .public-quote-hero:first-child,
  .public-invoice-wrap > .public-doc-page-hero:first-child,
  .client-portal-wrap > .public-quote-hero:first-child {
    margin-top: 0;
  }
}


.monetization-toggle-row {
  margin-bottom: 12px;
}

.monetization-toggle-row .field {
  max-width: 520px;
}

.monetization-detail-grid {
  align-items: start;
}

.monetization-detail-grid .field {
  margin-bottom: 0;
}

.monetization-detail-grid input[type="number"] {
  max-width: 340px;
}


.topbar-actions-stack {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
}

.topbar-brand-logo {
  display: block;
  height: 44px;
  width: auto;
  max-width: min(100%, 420px);
  object-fit: contain;
}

.topbar-nav-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

@media (max-width: 760px) {
  .topbar {
    align-items: flex-start;
  }

  .topbar-copy {
    display: none;
  }

  .topbar-actions-stack {
    width: 100%;
    align-items: center;
    margin-left: 0;
  }

  .topbar-brand-logo {
    height: 56px;
    max-width: min(100%, 420px);
  }

  .topbar-nav-row {
    width: 100%;
    justify-content: center;
  }
}

/* Step 62: broader mobile polish pass */
@media (max-width: 980px) {
  .wrap {
    padding-left: 16px;
    padding-right: 16px;
  }

  .card,
  .print-document-card,
  .summary-box,
  .client-portal-card,
  .readonly-setting-box {
    border-radius: 22px;
  }

  .template-settings-grid,
  .public-quote-grid,
  .client-portal-grid,
  .dashboard-grid,
  .grid-2,
  .dashboard-layout,
  .workspace-grid,
  .public-doc-grid,
  .public-summary-stack,
  .document-main-stack {
    grid-template-columns: 1fr;
  }

  .fields,
  .fields.two,
  .fields.three,
  .fields.four,
  .monetization-detail-grid,
  .monetization-toggle-row,
  .client-portal-overview-grid,
  .contract-scope-grid,
  .change-order-line-row {
    grid-template-columns: 1fr;
  }

  .snapshot-row {
    grid-template-columns: 1fr;
  }

  .snapshot-row span:last-child,
  .snapshot-row strong:last-child {
    text-align: left;
  }

  .public-page-toolbar-actions,
  .workspace-link-row,
  .public-response-actions,
  .response-actions-row,
  .invoice-actions-stack,
  .invoice-share-controls,
  .client-portal-quicklinks,
  .public-pay-actions,
  .saved-quote-title-row,
  .saved-quote-actions,
  .workspace-actions {
    gap: 10px;
  }

  .saved-quote-actions,
  .workspace-actions,
  .client-portal-quicklinks,
  .invoice-actions-stack,
  .public-page-toolbar-actions,
  .response-actions-row,
  .workspace-link-row {
    display: grid;
    grid-template-columns: 1fr;
  }

  .saved-quote-actions > *,
  .workspace-actions > *,
  .client-portal-quicklinks > *,
  .invoice-actions-stack > *,
  .public-page-toolbar-actions > *,
  .response-actions-row > *,
  .workspace-link-row > * {
    width: 100%;
  }

  .client-portal-stage-list,
  .snapshot-list,
  .entity-list {
    gap: 14px;
  }

  .public-invoice-grid,
  .public-invoice-summary-grid,
  .public-quote-grid,
  .client-portal-grid {
    gap: 18px;
  }

  .quote-box,
  .readonly-setting-box {
    padding: 14px;
  }
}

@media (max-width: 760px) {
  .wrap {
    padding-left: 14px;
    padding-right: 14px;
  }

  .card,
  .print-document-card,
  .summary-box,
  .client-portal-card {
    padding: 18px;
  }

  .topbar {
    gap: 14px;
  }

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

  .topbar-nav-row > * {
    width: 100%;
  }

  .topbar-nav-row .tab-link,
  .topbar-nav-row .topbar-user-menu > summary,
  .public-shell-topbar .topbar-actions .tab-link {
    justify-content: center;
    width: 100%;
    min-height: 46px;
  }

  .topbar-nav-row .tab-link,
  .topbar-nav-row .topbar-user-menu > summary,
  .public-shell-topbar .topbar-actions .tab-link {
    font-size: 15px;
    line-height: 1.1;
  }

  .topbar-nav-row .tab-link i,
  .topbar-nav-row .topbar-user-menu > summary i,
  .public-shell-topbar .topbar-actions .tab-link i {
    font-size: 16px;
    line-height: 1;
  }

  .topbar-nav-row .tab-link span,
  .topbar-nav-row .topbar-user-menu > summary span,
  .public-shell-topbar .topbar-actions .tab-link span {
    font-size: 15px;
    line-height: 1.1;
  }

  .topbar-user-dropdown {
    text-align: left;
  }

  .topbar-user-link,
  .topbar-user-form .topbar-user-link {
    justify-content: flex-start;
    text-align: left;
  }

  .section {
    padding: 16px;
  }

  .helper {
    font-size: 13px;
    line-height: 1.55;
  }

  .inline-checks,
  .conditional-checks {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .checkbox {
    min-height: 46px;
    align-items: center;
  }

  .saved-quote-item,
  .entity-item,
  .client-portal-stage,
  .mini-summary-card {
    padding: 14px;
  }

  .saved-quote-title-row,
  .entity-item-meta,
  .client-portal-section-head {
    gap: 8px;
  }

  .public-shell-topbar,
  .public-doc-page-hero,
  .public-quote-hero {
    margin-bottom: 16px;
  }

  .public-page-toolbar-actions .tab-link,
  .public-page-toolbar-actions .tab-button,
  .tab-link,
  .primary-btn,
  .ghost-btn,
  .danger-btn,
  .btn-link,
  .topbar-user-link,
  .topbar-user-form button {
    min-height: 46px;
  }

  .public-shell-topbar .tab-link {
    font-size: 15px;
    gap: 8px;
  }

  .public-shell-topbar .tab-link i {
    font-size: 16px;
  }

  .public-shell-topbar .tab-link span {
    font-size: 15px;
  }

  .quote-box,
  .readonly-setting-box,
  .response-state {
    border-radius: 16px;
  }

  .snapshot-row {
    display: grid;
    gap: 6px;
    padding-bottom: 12px;
  }

  .public-pay-card .helper,
  .invoice-template-copy .helper,
  .client-portal-card .helper {
    margin-bottom: 10px;
  }

  .public-pay-card,
  .invoice-template-copy,
  .client-portal-card,
  .summary-box {
    overflow: hidden;
  }

  .site-footer-inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .site-footer-links {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .site-footer-link {
    justify-content: center;
    text-align: center;
  }
}

@media (max-width: 520px) {
  .topbar-brand-logo {
    height: 44px;
    max-width: min(100%, 320px);
  }

  .topbar-nav-row {
    grid-template-columns: 1fr;
  }

  .site-footer-inner {
    align-items: stretch;
  }

  .site-footer-links {
    order: 1;
    grid-template-columns: 1fr;
  }

  .site-footer-copy {
    order: 2;
    width: 100%;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    text-align: center;
  }

  .site-footer-copy > span {
    display: block;
    width: 100%;
  }

  .tab-link,
  .primary-btn,
  .ghost-btn,
  .danger-btn,
  .btn-link,
  .topbar-user-link,
  .topbar-user-form button {
    font-size: 14px;
  }

  .public-pay-card #payment-element {
    overflow: hidden;
  }
}


.pricing-settings-head {
  align-items: flex-start;
}

.pricing-settings-head .helper {
  margin-bottom: 0;
}

.pricing-settings-actions-top {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.pricing-autofill-btn,
.pricing-clear-btn {
  white-space: nowrap;
}

.pricing-settings-actions-bottom {
  justify-content: flex-end;
}

.settings-message-modal {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: grid;
  place-items: center;
  padding: 24px;
}

.settings-message-modal.hidden {
  display: none;
}

.settings-message-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(5, 7, 10, 0.68);
  backdrop-filter: blur(4px);
}

.settings-message-dialog {
  position: relative;
  z-index: 1;
  width: min(100%, 440px);
  text-align: center;
  padding: 28px 24px;
}

.settings-message-icon {
  width: 56px;
  height: 56px;
  margin: 0 auto 14px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  font-size: 24px;
}

.settings-message-dialog h3 {
  margin: 0 0 10px;
}

.settings-message-dialog p {
  margin: 0;
  color: var(--muted);
}

.settings-message-actions {
  margin-top: 18px;
  display: flex;
  justify-content: center;
  gap: 12px;
}
.settings-message-actions .hidden {
  display: none;
}

.settings-message-actions .ghost-btn,
.settings-message-actions .primary-btn {
  min-width: 120px;
}


@media (max-width: 767px) {
  .pricing-settings-head {
    flex-direction: column;
    align-items: stretch;
  }

  .pricing-settings-actions-top {
    width: 100%;
    justify-content: stretch;
  }

  .pricing-autofill-btn,
  .pricing-clear-btn {
    width: 100%;
    justify-content: center;
  }

  .pricing-settings-actions-bottom {
    width: 100%;
    flex-direction: column-reverse;
    align-items: stretch;
  }

  .pricing-settings-actions-bottom .primary-btn,
  .pricing-settings-actions-bottom .ghost-btn {
    width: 100%;
    justify-content: center;
  }

  .settings-message-dialog {
    padding: 24px 18px;
  }
}


.connect-foundation-card {
  margin-bottom: 1.25rem;
}

.connect-foundation-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.connect-foundation-head h3 {
  margin-bottom: 0.35rem;
}

.connect-foundation-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
}

.connect-status-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem 1rem;
  margin-top: 0.75rem;
}

.connect-status-grid .snapshot-row {
  margin: 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.connect-foundation-note {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
  padding: 0.95rem 1rem;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  background: rgba(255,255,255,0.03);
  margin-top: 1rem;
}

.connect-foundation-note i {
  margin-top: 0.15rem;
}

@media (max-width: 900px) {
  .connect-foundation-head {
    flex-direction: column;
  }

  .connect-status-grid {
    grid-template-columns: 1fr;
  }
}


.autofill-decoy {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
}

.connect-foundation-actions form {
  margin: 0;
}

.connect-action-btn {
  min-width: 180px;
}

.connect-inline-grid {
  align-items: end;
}

.connect-platform-note {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
  margin-top: 1rem;
  padding: 0.9rem 1rem;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
}

.connect-platform-note i {
  margin-top: 0.1rem;
}


/* Header simplification: move logo left, remove redundant title/subtitle */
.topbar {
  align-items: center;
}

.topbar-brand {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  flex: 0 1 auto;
  min-width: 0;
}

.topbar-actions {
  display: flex;
  align-items: center;
}

.topbar-actions-stack {
  flex: 1 1 auto;
  flex-direction: row;
  justify-content: flex-end;
  align-items: center;
  gap: 16px;
}

.topbar-brand-logo {
  height: 56px;
  width: auto;
  max-width: min(100%, 320px);
}

.topbar-nav-row {
  align-items: center;
}

.public-shell-topbar .topbar-actions {
  margin-left: auto;
  align-self: center;
}

@media (max-width: 760px) {
  .topbar {
    justify-content: center;
    gap: 12px;
  }

  .topbar-brand {
    width: 100%;
    justify-content: center;
  }

  .topbar-actions,
  .topbar-actions-stack {
    width: 100%;
    margin-left: 0;
    justify-content: center;
    align-items: center;
  }

  .topbar-actions-stack {
    flex-direction: column;
    gap: 10px;
  }

  .topbar-brand-logo {
    height: 52px;
    max-width: min(100%, 280px);
  }
}


/* Header polish: add tagline under logo and true vertical centering */
.topbar {
  align-items: center;
}

.topbar-brand {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  flex: 0 1 auto;
  min-width: 0;
}

.topbar-brand-lockup {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 8px;
  min-width: 0;
}

.topbar-brand-tagline {
  display: block;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.35;
  max-width: 420px;
}

.topbar-actions {
  display: flex;
  align-items: center;
  min-height: 100%;
}

.topbar-actions-stack {
  flex: 1 1 auto;
  flex-direction: row;
  justify-content: flex-end;
  align-items: center;
  gap: 16px;
}

.topbar-brand-logo {
  height: 56px;
  width: auto;
  max-width: min(100%, 320px);
}

.topbar-nav-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
  align-items: center;
}

.topbar-nav-row .tab-link,
.topbar-nav-row .topbar-user-menu > summary,
.public-shell-topbar .topbar-actions .tab-link {
  align-self: center;
}

.public-shell-topbar .topbar-actions {
  margin-left: auto;
  align-self: center;
}

@media (max-width: 760px) {
  .topbar {
    justify-content: center;
    gap: 12px;
  }

  .topbar-brand {
    width: 100%;
    justify-content: center;
  }

  .topbar-brand-lockup {
    align-items: center;
    text-align: center;
    gap: 6px;
  }

  .topbar-brand-tagline {
    max-width: 100%;
    font-size: 13px;
  }

  .topbar-actions,
  .topbar-actions-stack {
    width: 100%;
    margin-left: 0;
    justify-content: center;
    align-items: center;
  }

  .topbar-actions-stack {
    flex-direction: column;
    gap: 10px;
  }

  .topbar-brand-logo {
    height: 52px;
    max-width: min(100%, 280px);
  }
}


/* Header cleanup: remove tagline, keep desktop height, fix true centering, restore mobile spacing */
.topbar {
  align-items: center;
  min-height: 102px;
}

.topbar > :first-child,
.topbar-brand {
  flex: 0 1 auto;
  min-width: 0;
}

.topbar-brand-lockup {
  gap: 0;
}

.topbar-brand-tagline {
  display: none !important;
}

.topbar-actions,
.topbar-actions-stack,
.topbar .tabs,
.public-shell-topbar .topbar-actions,
.topbar-nav-row {
  align-items: center !important;
}

.topbar-actions,
.public-shell-topbar .topbar-actions {
  align-self: center !important;
  min-height: 0;
}

.topbar-actions-stack {
  justify-content: center;
}

.topbar-nav-row {
  min-height: 0;
}

@media (max-width: 760px) {
  .topbar {
    min-height: 0;
    padding-top: 22px;
    padding-bottom: 22px;
    gap: 14px;
  }

  .topbar > :first-child,
  .topbar-brand {
    flex: 0 0 auto;
    width: 100%;
  }

  .topbar-brand-lockup {
    gap: 0;
  }

  .topbar-actions,
  .topbar-actions-stack {
    width: 100%;
    margin-left: 0;
    justify-content: center;
    align-items: center;
  }
}
