:root {
  --bg: #f6f8fc;
  --bg-strong: #ffffff;
  --surface: rgba(255, 255, 255, 0.84);
  --surface-strong: rgba(255, 255, 255, 0.97);
  --surface-soft: rgba(244, 247, 252, 0.72);
  --ink: #0f172a;
  --ink-soft: #243348;
  --muted: #627084;
  --line: rgba(130, 148, 176, 0.22);
  --line-strong: rgba(130, 148, 176, 0.34);
  --accent: #2663eb;
  --accent-deep: #153a8a;
  --accent-soft: rgba(38, 99, 235, 0.12);
  --ok: #0f8a61;
  --ok-soft: rgba(15, 138, 97, 0.13);
  --warn: #c27b00;
  --warn-soft: rgba(194, 123, 0, 0.14);
  --danger: #d04444;
  --danger-soft: rgba(208, 68, 68, 0.12);
  --shadow-lg: 0 28px 80px rgba(15, 23, 42, 0.12);
  --shadow-md: 0 18px 42px rgba(15, 23, 42, 0.08);
  --shadow-sm: 0 8px 24px rgba(15, 23, 42, 0.06);
  --radius-xl: 28px;
  --radius-lg: 22px;
  --radius-md: 18px;
  --radius-sm: 14px;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-height: 100vh;
  color: var(--ink);
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at top left, rgba(38, 99, 235, 0.14), transparent 28%),
    radial-gradient(circle at 85% 0%, rgba(15, 138, 97, 0.08), transparent 24%),
    linear-gradient(180deg, #fbfcff 0%, #f6f8fc 48%, #f4f6fb 100%);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.35) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.35) 1px, transparent 1px);
  background-size: 120px 120px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.45), transparent 90%);
  opacity: 0.35;
}

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

button,
a.button-link {
  cursor: pointer;
  transition:
    transform 160ms ease,
    box-shadow 160ms ease,
    background-color 160ms ease,
    border-color 160ms ease,
    color 160ms ease;
}

button:hover,
a.button-link:hover {
  transform: translateY(-1px);
}

button:disabled {
  opacity: 0.58;
  cursor: not-allowed;
  transform: none;
}

a {
  color: inherit;
}

[hidden] {
  display: none !important;
}

.shell {
  display: grid;
  grid-template-columns: minmax(280px, 330px) minmax(0, 1fr);
  gap: 28px;
  max-width: 1600px;
  margin: 0 auto;
  padding: 24px;
}

.sidebar {
  position: sticky;
  top: 24px;
  height: calc(100vh - 48px);
}

.sidebar-shell {
  height: 100%;
  overflow: auto;
  padding: 22px 18px;
  border: 1px solid rgba(255, 255, 255, 0.56);
  border-radius: 30px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(247, 250, 255, 0.74));
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(18px);
}

.sidebar-shell::-webkit-scrollbar {
  width: 8px;
}

.sidebar-shell::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: rgba(98, 112, 132, 0.28);
}

.sidebar-brand h1,
#hero-title,
.panel-header h2,
.result-card h3,
.summary-card h2,
.status-card h2 {
  font-family: ui-serif, Georgia, serif;
  font-weight: 600;
  letter-spacing: -0.03em;
}

.sidebar-brand h1 {
  margin: 0 0 12px;
  font-size: clamp(1.7rem, 1.35rem + 0.8vw, 2.2rem);
  line-height: 1.05;
}

.sidebar-brand .lede {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.7;
}

.content {
  display: grid;
  align-content: start;
  gap: 20px;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 10px;
  color: var(--accent-deep);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.lede,
.muted-line,
#autosave-state,
#quote-meta,
.field small,
.panel-header p,
.question-description,
.search-status {
  color: var(--muted);
}

.sidebar-card,
.hero-card,
.panel,
.alert,
.toast,
.inline-note,
.document-card,
.field-card,
.result-card,
.context-card,
.subpanel {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--surface);
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(14px);
}

.status-card,
.summary-card,
.internal-card,
.hero-card,
.panel {
  padding: 20px;
}

.status-card,
.summary-card,
.internal-card {
  margin-top: 14px;
}

.card-kicker {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

#prototype-banner:empty {
  display: none;
}

.toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding: 18px 22px;
  border-radius: var(--radius-xl);
  border: 1px solid rgba(255, 255, 255, 0.68);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(247, 250, 255, 0.86));
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(18px);
}

.toolbar-actions .secondary {
  background: rgba(255, 255, 255, 0.72);
}

.toolbar-copy {
  min-width: 0;
}

.sr-only-shell {
  display: none !important;
}

#wizard-title {
  display: block;
  margin-bottom: 6px;
  font-size: clamp(1.05rem, 0.94rem + 0.45vw, 1.35rem);
  color: var(--ink);
}

#autosave-state {
  margin: 0;
  font-size: 0.94rem;
}

.toolbar-actions,
.inline-actions,
.nav-row,
.field-actions,
.document-head,
.line-head {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

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

.toolbar-entry-shell {
  justify-content: center;
}

.toolbar-entry-shell .toolbar-actions {
  width: 100%;
  justify-content: center;
}

.toolbar-entry-shell #new-quote-btn {
  min-width: clamp(260px, 30vw, 360px);
  min-height: 56px;
  font-size: 1rem;
  box-shadow: 0 18px 36px rgba(35, 79, 208, 0.16);
}

.technical-actions[hidden] {
  display: none !important;
}

.status-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.hero-card {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(300px, 0.95fr);
  gap: 20px;
  min-height: 220px;
  background:
    radial-gradient(circle at 0% 0%, rgba(38, 99, 235, 0.16), transparent 32%),
    radial-gradient(circle at 100% 100%, rgba(15, 138, 97, 0.12), transparent 36%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(247, 250, 255, 0.88));
}

.hero-card::after {
  content: "";
  position: absolute;
  inset: auto -80px -120px auto;
  width: 280px;
  height: 280px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(38, 99, 235, 0.16), transparent 72%);
}

.hero-copy-block {
  position: relative;
  z-index: 1;
  max-width: 720px;
  align-self: center;
}

#hero-title {
  margin: 0 0 14px;
  font-size: clamp(2rem, 1.55rem + 1.15vw, 3rem);
  line-height: 0.98;
}

#hero-copy {
  margin: 0;
  max-width: 62ch;
  font-size: 1.02rem;
  line-height: 1.8;
  color: var(--ink-soft);
}

.hero-card.compact {
  min-height: unset;
  padding: 18px 20px;
}

.hero-metrics {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.metric-card {
  padding: 16px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(130, 148, 176, 0.2);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: var(--shadow-sm);
}

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

.metric-card strong {
  display: block;
  margin-top: 2px;
  font-size: 1rem;
  line-height: 1.45;
}

.metric-card .metric-value {
  font-size: 1.45rem;
  line-height: 1.05;
}

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

.metric-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: var(--muted);
}

.panel {
  padding: 26px;
}

.panel-step {
  animation: rise-in 240ms ease;
}

.panel-header {
  margin-bottom: 20px;
}

.panel-header h2,
.panel-header h3 {
  margin: 0 0 8px;
}

.panel-header h2 {
  font-size: clamp(1.4rem, 1.2rem + 0.5vw, 1.95rem);
}

.panel-header h3 {
  font-size: 1.15rem;
}

.panel-header p {
  max-width: 70ch;
  margin: 0;
  line-height: 1.7;
}

.panel-header-secondary {
  padding-top: 6px;
}

.panel-step-label {
  margin: 0 0 10px;
  color: var(--accent-deep);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.section-spacer {
  height: 14px;
}

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

.field-group {
  padding: 18px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(130, 148, 176, 0.18);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(247, 250, 255, 0.78));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.field-group + .field-group {
  margin-top: 16px;
}

.field-group-header {
  margin-bottom: 12px;
}

.field-group-header h3 {
  margin: 0;
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

.field {
  display: grid;
  gap: 8px;
  align-content: start;
}

.field-label {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  font-size: 0.93rem;
  font-weight: 700;
  color: var(--ink-soft);
}

input,
select,
textarea {
  width: 100%;
  min-height: 52px;
  padding: 14px 16px;
  border: 1px solid rgba(130, 148, 176, 0.24);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.88);
  color: var(--ink);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    background-color 160ms ease,
    transform 160ms ease;
}

input:hover,
select:hover,
textarea:hover {
  border-color: rgba(130, 148, 176, 0.38);
}

input:focus,
select:focus,
textarea:focus {
  outline: none;
  border-color: rgba(38, 99, 235, 0.46);
  box-shadow:
    0 0 0 4px rgba(38, 99, 235, 0.11),
    0 14px 26px rgba(38, 99, 235, 0.08);
  background: var(--bg-strong);
}

.field.invalid input,
.field.invalid select {
  border-color: rgba(208, 68, 68, 0.44);
  box-shadow: 0 0 0 4px rgba(208, 68, 68, 0.09);
}

.field small {
  display: block;
  font-size: 0.84rem;
  line-height: 1.55;
}

.field-error {
  color: var(--danger) !important;
}

button,
a.button-link {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  min-height: 48px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(130, 148, 176, 0.22);
  background: rgba(255, 255, 255, 0.88);
  color: var(--ink);
  font-weight: 700;
  text-decoration: none;
  box-shadow: var(--shadow-sm);
}

button.primary,
a.button-link.primary {
  border-color: rgba(38, 99, 235, 0.18);
  background: linear-gradient(135deg, #2663eb, #1f4fd4);
  color: #ffffff;
}

button.primary:hover,
a.button-link.primary:hover {
  box-shadow: 0 18px 36px rgba(38, 99, 235, 0.22);
}

button.secondary,
a.button-link.secondary {
  background: rgba(255, 255, 255, 0.58);
  color: var(--ink-soft);
}

.nav-row {
  margin-top: 22px;
  justify-content: space-between;
}

.form-actions {
  align-items: flex-end;
}

.stepper {
  display: grid;
  gap: 10px;
  position: relative;
}

.step-item {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(130, 148, 176, 0.16);
  background: rgba(255, 255, 255, 0.72);
  text-align: left;
}

.step-item::after {
  content: "";
  position: absolute;
  inset: auto auto -10px 32px;
  width: 1px;
  height: 12px;
  background: rgba(130, 148, 176, 0.24);
}

.step-item:last-child::after {
  display: none;
}

.step-item.active {
  border-color: rgba(38, 99, 235, 0.28);
  background: linear-gradient(135deg, rgba(38, 99, 235, 0.12), rgba(255, 255, 255, 0.9));
  box-shadow: 0 16px 32px rgba(38, 99, 235, 0.12);
}

.step-item.completed {
  background: linear-gradient(135deg, rgba(15, 138, 97, 0.08), rgba(255, 255, 255, 0.8));
}

.step-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  margin-right: 12px;
  border-radius: 999px;
  background: rgba(38, 99, 235, 0.12);
  color: var(--accent-deep);
  font-size: 0.82rem;
  font-weight: 800;
}

.summary-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(130, 148, 176, 0.12);
  font-size: 0.95rem;
}

.summary-row span {
  color: var(--muted);
}

.summary-row:last-child {
  border-bottom: 0;
}

.summary-row strong {
  text-align: right;
}

.search-results,
.field-grid,
.result-sections,
.section-items {
  display: grid;
  gap: 12px;
}

.municipality-actions,
.search-status {
  margin-top: 12px;
}

.search-option {
  width: 100%;
  justify-content: space-between;
  text-align: left;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.84);
}

.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  padding: 6px 10px;
  background: rgba(38, 99, 235, 0.09);
  color: var(--accent-deep);
  font-size: 0.78rem;
  font-weight: 700;
}

.badge.ok {
  background: var(--ok-soft);
  color: var(--ok);
}

.badge.warn {
  background: var(--warn-soft);
  color: var(--warn);
}

.badge.danger {
  background: var(--danger-soft);
  color: var(--danger);
}

.badge.subtle {
  background: rgba(130, 148, 176, 0.12);
  color: var(--muted);
}

.inline-note,
.alert,
.toast,
.document-card,
.field-card,
.result-card,
.context-card,
.subpanel {
  padding: 16px;
}

.municipality-note {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(247, 250, 255, 0.88));
}

.municipality-note-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.inline-note p,
.alert p,
.result-card p,
.subpanel p {
  margin-bottom: 0;
}

.inline-note.ok,
.alert.info {
  border-color: rgba(38, 99, 235, 0.18);
}

.alert.warning,
.toast.warning,
.warning-card {
  border-color: rgba(194, 123, 0, 0.28);
  background: rgba(255, 251, 240, 0.9);
}

.alert.error,
.toast.error,
.fatal-card {
  border-color: rgba(208, 68, 68, 0.32);
  background: rgba(255, 246, 246, 0.92);
}

.toast.success {
  border-color: rgba(15, 138, 97, 0.28);
  background: rgba(244, 255, 250, 0.94);
}

.alert + .alert {
  margin-top: 10px;
}

.question-section + .question-section {
  margin-top: 18px;
}

.question-section {
  padding: 18px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(130, 148, 176, 0.16);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.84), rgba(247, 250, 255, 0.8));
}

.question-section h3 {
  margin: 0 0 8px;
  font-size: 1.06rem;
}

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

.question-choice-group {
  margin: 0;
  padding: 0;
  border: 0;
}

.question-choice-group legend {
  margin-bottom: 12px;
  font-size: 0.94rem;
  font-weight: 700;
  color: var(--ink-soft);
}

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

.choice-card,
.checkbox-row {
  position: relative;
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 16px;
  border: 1px solid rgba(130, 148, 176, 0.18);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.86);
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    transform 160ms ease,
    background-color 160ms ease;
}

.choice-card:hover,
.checkbox-row:hover {
  border-color: rgba(38, 99, 235, 0.24);
  box-shadow: var(--shadow-sm);
}

.choice-card:has(input:checked),
.checkbox-row:has(input:checked) {
  border-color: rgba(38, 99, 235, 0.34);
  background: linear-gradient(135deg, rgba(38, 99, 235, 0.08), rgba(255, 255, 255, 0.96));
  box-shadow: 0 18px 34px rgba(38, 99, 235, 0.08);
}

.choice-card input,
.checkbox-row input {
  width: auto;
  min-height: unset;
  margin-top: 2px;
  box-shadow: none;
}

.document-upload {
  display: grid;
  grid-template-columns: minmax(200px, 240px) 1fr auto;
  gap: 14px;
  align-items: end;
}

.document-head {
  justify-content: space-between;
  align-items: flex-start;
}

.field-grid {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  margin-top: 12px;
}

.document-card strong,
.field-card strong {
  font-size: 0.98rem;
}

.mono,
pre {
  font-family: "Cascadia Mono", Consolas, monospace;
}

pre {
  margin: 0;
  white-space: pre-wrap;
  font-size: 0.78rem;
  line-height: 1.6;
}

.result-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 14px;
}

.result-summary-grid {
  grid-template-columns: minmax(280px, 1.4fr) repeat(2, minmax(220px, 1fr));
}

.total-card {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgba(38, 99, 235, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 250, 255, 0.9));
}

.total-card::after {
  content: "";
  position: absolute;
  inset: auto -70px -90px auto;
  width: 200px;
  height: 200px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(38, 99, 235, 0.14), transparent 70%);
}

.grand-total {
  position: relative;
  z-index: 1;
  margin-top: 10px;
  font-size: clamp(2rem, 1.4rem + 1vw, 3rem);
  font-weight: 800;
  letter-spacing: -0.04em;
}

.result-card h3,
.result-card h4 {
  margin-top: 0;
}

.metric-summary-card strong {
  display: block;
  font-size: 1.35rem;
  line-height: 1.15;
}

.result-section-head,
.line-head,
.section-summary,
.line-meta {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  flex-wrap: wrap;
}

.result-line-card {
  padding: 16px;
  border-radius: 18px;
  border: 1px solid rgba(130, 148, 176, 0.16);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.95);
}

.line-amount {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--ink);
}

.line-basis,
.compact-list,
.section-note {
  color: var(--muted);
  line-height: 1.65;
}

.result-section .muted-line {
  max-width: 56ch;
}

.plain-list,
.compact-list {
  margin: 0;
  padding-left: 18px;
}

.embedded-list {
  padding: 14px;
  border-radius: 18px;
  border: 1px dashed rgba(130, 148, 176, 0.24);
  background: rgba(247, 250, 255, 0.86);
}

.embedded-list + .embedded-list {
  margin-top: 12px;
}

.details-grid {
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 14px;
}

.result-inline-actions,
.result-contact-actions {
  margin-top: 18px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.contact-card {
  background:
    radial-gradient(circle at top right, rgba(38, 99, 235, 0.12), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 250, 255, 0.92));
}

.contact-card h3,
.support-card h3 {
  margin-bottom: 8px;
}

.savings-card {
  background:
    radial-gradient(circle at top left, rgba(38, 99, 235, 0.09), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 250, 255, 0.92));
}

.opportunity-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.opportunity-card {
  border: 1px solid rgba(38, 99, 235, 0.12);
  border-radius: 18px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 16px 36px rgba(15, 23, 42, 0.08);
}

.opportunity-card strong {
  display: block;
  margin-bottom: 12px;
}

.opportunity-metrics {
  display: grid;
  gap: 12px;
  margin: 0;
}

.opportunity-metrics div {
  display: grid;
  gap: 4px;
}

.opportunity-metrics dt {
  color: var(--muted);
  font-size: 0.9rem;
}

.opportunity-metrics dd {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.contact-highlights {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.contact-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(38, 99, 235, 0.08);
  color: var(--accent-deep);
  font-size: 0.84rem;
  font-weight: 700;
}

.contact-reveal {
  margin-top: 16px;
}

.contact-reveal[hidden] {
  display: none !important;
}

.lead-capture-panel {
  display: grid;
  gap: 16px;
}

.lead-form-grid {
  align-items: end;
}

.lead-confirmation-reference {
  margin: 6px 0 0;
  color: var(--ink-soft);
}

.confirmation-panel .embedded-list {
  display: grid;
  gap: 10px;
}

.support-card {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(247, 250, 255, 0.86));
}

.technical-details {
  margin-top: 16px;
}

.technical-details summary {
  cursor: pointer;
  font-weight: 700;
}

.demo-card-item + .demo-card-item {
  margin-top: 12px;
}

.demo-chip {
  width: 100%;
  justify-content: flex-start;
  text-align: left;
  margin-top: 10px;
}

.toast-stack {
  position: static;
  z-index: 20;
  display: grid;
  gap: 10px;
}

.client-action-bar {
  position: static;
  z-index: 18;
}

.client-action-bar[hidden] {
  display: none !important;
}

.client-action-bar-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  padding: 16px 18px;
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.64);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(18px);
}

.result-shell #result-panel,
.result-shell #frontend-debug-panel,
.result-shell #normalized-context {
  display: grid;
  gap: 16px;
}

.fatal-card {
  border-color: rgba(208, 68, 68, 0.34);
}

@keyframes rise-in {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.partner-quote-page {
  min-height: 100vh;
  background: #f5f7fb;
  color: #0f172a;
}

.partner-quote-shell {
  width: min(980px, calc(100% - 32px));
  margin: 0 auto;
  padding: 48px 0;
}

.partner-quote-panel {
  background: #ffffff;
  border: 1px solid rgba(15, 31, 92, 0.12);
  border-radius: 8px;
  box-shadow: 0 18px 42px rgba(15, 31, 92, 0.08);
  overflow: hidden;
}

.partner-quote-header {
  padding: 28px 32px 22px;
  border-bottom: 1px solid rgba(15, 31, 92, 0.1);
}

.partner-quote-eyebrow {
  margin: 0 0 8px;
  color: #2851f0;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.partner-quote-header h1 {
  margin: 0;
  font-size: 1.7rem;
  line-height: 1.15;
}

.partner-quote-copy {
  margin: 10px 0 0;
  color: #475569;
}

.partner-quote-alert {
  margin: 18px 32px 0;
  padding: 12px 14px;
  border-radius: 6px;
  font-weight: 700;
}

.partner-quote-alert-info {
  background: #eff6ff;
  color: #1d4ed8;
}

.partner-quote-alert-success {
  background: #ecfdf5;
  color: #047857;
}

.partner-quote-alert-danger {
  background: #fef2f2;
  color: #b91c1c;
}

.partner-quote-lines {
  display: grid;
  gap: 16px;
  padding: 24px 32px;
}

.partner-quote-block {
  display: grid;
  gap: 14px;
  padding: 16px;
  border: 1px solid rgba(15, 31, 92, 0.12);
  border-radius: 8px;
  background: #f8fafc;
}

.partner-quote-block-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: start;
}

.partner-quote-block-eyebrow {
  margin: 0 0 4px;
  color: #64748b;
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.partner-quote-block h2 {
  margin: 0;
  color: #122147;
  font-size: 1.08rem;
  line-height: 1.2;
}

.partner-quote-block-total {
  display: grid;
  gap: 3px;
  justify-items: end;
  min-width: 160px;
  color: #64748b;
  font-size: 0.82rem;
  font-weight: 800;
  text-align: right;
}

.partner-quote-block-total strong {
  color: #122147;
  font-size: 1.1rem;
}

.partner-quote-block-lines {
  display: grid;
  gap: 10px;
}

.partner-quote-block-actions {
  display: flex;
  justify-content: flex-start;
}

.partner-quote-empty {
  margin: 0;
  color: #64748b;
  font-size: 0.9rem;
  font-weight: 700;
}

.partner-quote-line {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(140px, auto) auto;
  gap: 16px;
  align-items: center;
  padding: 16px;
  border: 1px solid rgba(15, 31, 92, 0.1);
  border-radius: 8px;
  background: #ffffff;
}

.partner-quote-line-main h3 {
  margin: 8px 0 0;
  font-size: 1rem;
  line-height: 1.25;
}

.partner-quote-line-status {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 800;
}

.partner-quote-line-status-pending {
  background: #fff7ed;
  color: #9a3412;
}

.partner-quote-line-status-confirmed {
  background: #ecfdf5;
  color: #047857;
}

.partner-quote-line-status-modified {
  background: #eff6ff;
  color: #1d4ed8;
}

.partner-quote-reason {
  margin: 8px 0 0;
  color: #64748b;
  font-size: 0.9rem;
}

.partner-quote-line-amount {
  display: grid;
  gap: 4px;
  justify-items: end;
  white-space: nowrap;
}

.partner-quote-line-amount strong {
  font-size: 1rem;
}

.partner-quote-line-amount span {
  color: #64748b;
  font-size: 0.78rem;
}

.partner-quote-line-actions,
.partner-quote-dialog-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
}

.partner-quote-secondary,
.partner-quote-submit {
  min-height: 40px;
  border-radius: 6px;
  padding: 0 14px;
  font-weight: 800;
  cursor: pointer;
}

.partner-quote-secondary {
  border: 1px solid rgba(15, 31, 92, 0.18);
  background: #ffffff;
  color: #153a8a;
}

.partner-quote-submit {
  border: 1px solid #153a8a;
  background: #153a8a;
  color: #ffffff;
}

.partner-quote-secondary:disabled,
.partner-quote-submit:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}

.partner-quote-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 32px;
  border-top: 1px solid rgba(15, 31, 92, 0.1);
  background: #f8fafc;
}

.partner-quote-signature {
  display: grid;
  grid-template-columns: minmax(140px, 0.72fr) minmax(220px, 1.28fr);
  gap: 10px;
  min-width: min(560px, 100%);
}

.partner-quote-signature label {
  display: grid;
  gap: 6px;
  color: #334155;
  font-size: 0.82rem;
  font-weight: 900;
}

.partner-quote-signature input {
  width: 100%;
  border: 1px solid rgba(15, 31, 92, 0.18);
  border-radius: 6px;
  padding: 10px 12px;
  font: inherit;
}

.partner-quote-signature-pad {
  display: grid;
  gap: 6px;
}

.partner-quote-signature-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  color: #334155;
  font-size: 0.82rem;
  font-weight: 900;
}

.partner-quote-signature-head .partner-quote-secondary {
  min-height: 30px;
  padding: 6px 10px;
  font-size: 0.78rem;
}

#partner-quote-signature-canvas {
  display: block;
  width: 100%;
  height: 86px;
  border: 1px solid rgba(15, 31, 92, 0.2);
  border-radius: 6px;
  background: #ffffff;
  cursor: crosshair;
  touch-action: none;
}

#partner-quote-signature-canvas.is-disabled {
  cursor: not-allowed;
  opacity: 0.72;
}

.partner-quote-footer > div:not(.partner-quote-signature) {
  display: grid;
  gap: 2px;
}

.partner-quote-footer span {
  color: #64748b;
  font-size: 0.82rem;
  font-weight: 700;
}

.partner-quote-footer strong {
  font-size: 1.25rem;
}

.partner-quote-dialog {
  width: min(480px, calc(100% - 28px));
  border: 0;
  border-radius: 8px;
  padding: 0;
  box-shadow: 0 24px 70px rgba(15, 23, 42, 0.28);
}

.partner-quote-dialog::backdrop {
  background: rgba(15, 23, 42, 0.42);
}

.partner-quote-dialog form {
  display: grid;
  gap: 16px;
  padding: 24px;
}

.partner-quote-dialog h2 {
  margin: 0;
  font-size: 1.2rem;
}

.partner-quote-dialog-copy {
  margin: 0;
  color: #475569;
}

.partner-quote-dialog label {
  display: grid;
  gap: 6px;
  color: #334155;
  font-size: 0.9rem;
  font-weight: 800;
}

.partner-quote-dialog input,
.partner-quote-dialog textarea {
  width: 100%;
  border: 1px solid rgba(15, 31, 92, 0.18);
  border-radius: 6px;
  padding: 10px 12px;
  font: inherit;
}

.partner-quote-dialog small {
  min-height: 1em;
  color: #64748b;
  font-size: 0.78rem;
}

.admin-billing-body {
  display: grid;
  gap: 14px;
}

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

.admin-billing-kpi {
  display: grid;
  gap: 4px;
  padding: 12px;
  border: 1px solid rgba(15, 31, 92, 0.1);
  border-radius: 8px;
  background: #f8fafc;
}

.admin-billing-kpi span {
  color: #64748b;
  font-size: 0.78rem;
  font-weight: 800;
}

.admin-billing-kpi strong {
  color: #122147;
  font-size: 1.02rem;
}

.admin-billing-section {
  display: grid;
  gap: 10px;
}

.admin-billing-section h4 {
  margin: 0;
  color: #122147;
  font-size: 1rem;
}

.admin-payment-overview {
  display: grid;
  gap: 10px;
}

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

.admin-payment-overview-cell {
  display: grid;
  gap: 5px;
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(15, 31, 92, 0.1);
  border-radius: 8px;
  background: #ffffff;
}

.admin-payment-overview-cell span {
  color: #64748b;
  font-size: 0.75rem;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-payment-overview-cell strong {
  min-width: 0;
  color: #122147;
  font-size: 0.95rem;
  font-weight: 900;
  overflow-wrap: anywhere;
}

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

.admin-payment-flow > div {
  display: grid;
  gap: 6px;
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(15, 31, 92, 0.1);
  border-radius: 8px;
  background: #f8fafc;
}

.admin-payment-flow span {
  color: #64748b;
  font-size: 0.8rem;
  font-weight: 800;
}

.admin-payment-flow strong,
.admin-payment-flow small {
  color: #122147;
  overflow-wrap: anywhere;
}

.admin-billing-partner-quote {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid rgba(15, 31, 92, 0.1);
  border-radius: 8px;
  background: #f8fafc;
}

.admin-client-quote {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(15, 31, 92, 0.1);
  border-radius: 8px;
  background: #ffffff;
}

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

.admin-client-quote-totals span {
  display: grid;
  gap: 3px;
  padding: 10px;
  border: 1px solid rgba(15, 31, 92, 0.08);
  border-radius: 8px;
  color: #64748b;
  font-size: 0.8rem;
  font-weight: 800;
  background: #f8fafc;
}

.admin-client-quote-totals strong {
  color: #122147;
  font-size: 0.98rem;
}

.admin-client-quote-timeline {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  color: #64748b;
  font-size: 0.84rem;
  font-weight: 800;
}

.admin-client-quote-timeline strong {
  color: #122147;
}

.admin-payment-history {
  border-top: 1px solid rgba(15, 31, 92, 0.1);
  padding-top: 10px;
}

.admin-payment-history summary {
  cursor: pointer;
  color: #244be8;
  font-weight: 900;
}

.admin-payment-history ul {
  display: grid;
  gap: 8px;
  margin: 10px 0 0;
  padding: 0;
  list-style: none;
}

.admin-payment-event {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 10px;
  border: 1px solid rgba(15, 31, 92, 0.08);
  border-radius: 8px;
  background: #ffffff;
}

.admin-payment-event > div {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.admin-payment-event > div:last-child {
  justify-items: end;
}

.admin-payment-event strong {
  color: #122147;
  font-weight: 900;
}

.admin-payment-event span,
.admin-payment-event code,
.admin-payment-overview-cell code {
  color: #64748b;
  font-size: 0.82rem;
  overflow-wrap: anywhere;
}

.admin-partner-quote-details {
  border-top: 1px solid rgba(15, 31, 92, 0.1);
  padding-top: 10px;
}

.admin-partner-quote-details summary {
  cursor: pointer;
  color: #244be8;
  font-weight: 900;
}

.admin-partner-quote-details ul {
  display: grid;
  gap: 8px;
  margin: 10px 0 0;
  padding: 0;
  list-style: none;
}

.admin-partner-quote-block {
  display: grid;
  gap: 8px;
}

.admin-client-quote-block {
  display: grid;
  gap: 8px;
}

.admin-partner-quote-block-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: #122147;
  font-size: 0.9rem;
  font-weight: 900;
}

.admin-client-quote-block-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: #122147;
  font-size: 0.9rem;
  font-weight: 900;
}

.admin-partner-quote-block ul {
  margin-top: 0;
}

.admin-partner-quote-line {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
  padding: 10px;
  border: 1px solid rgba(15, 31, 92, 0.08);
  border-radius: 8px;
  background: #ffffff;
}

.admin-client-quote-line {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 10px;
  border: 1px solid rgba(15, 31, 92, 0.08);
  border-radius: 8px;
  background: #ffffff;
}

.admin-partner-quote-line div {
  display: grid;
  gap: 3px;
}

.admin-client-quote-line div {
  display: grid;
  gap: 4px;
  justify-items: start;
}

.admin-client-quote-line div:last-child {
  justify-items: end;
}

.admin-partner-quote-line strong {
  color: #122147;
}

.admin-client-quote-line strong {
  color: #122147;
}

.admin-partner-quote-line span,
.admin-partner-quote-line small {
  color: #64748b;
  font-size: 0.82rem;
}

.admin-client-quote-line span {
  color: #64748b;
  font-size: 0.82rem;
}

.admin-gestor-signature-preview {
  display: inline-grid;
  gap: 4px;
  justify-items: start;
  width: fit-content;
  max-width: 100%;
  padding: 8px 10px;
  border: 1px solid rgba(15, 31, 92, 0.12);
  border-radius: 8px;
  background: #ffffff;
}

.admin-gestor-signature-label {
  color: #64748b;
  font-size: 0.78rem;
  font-weight: 900;
}

.admin-gestor-signature-image {
  display: block;
  width: min(220px, 100%);
  height: 72px;
  object-fit: contain;
}

@media (max-width: 760px) {
  .partner-quote-shell {
    width: min(100% - 20px, 980px);
    padding: 20px 0;
  }

  .partner-quote-header,
  .partner-quote-lines,
  .partner-quote-footer {
    padding-left: 18px;
    padding-right: 18px;
  }

  .partner-quote-alert {
    margin-left: 18px;
    margin-right: 18px;
  }

  .partner-quote-line {
    grid-template-columns: minmax(0, 1fr);
  }

  .partner-quote-block-head {
    grid-template-columns: minmax(0, 1fr);
  }

  .partner-quote-block-total {
    justify-items: start;
    min-width: 0;
    text-align: left;
  }

  .partner-quote-line-amount {
    justify-items: start;
  }

  .partner-quote-signature {
    grid-template-columns: minmax(0, 1fr);
    width: 100%;
  }

  .admin-billing-kpis,
  .admin-payment-overview-grid,
  .admin-payment-flow,
  .admin-client-quote-totals,
  .admin-partner-quote-line,
  .admin-client-quote-line,
  .admin-payment-event {
    grid-template-columns: minmax(0, 1fr);
  }

  .admin-client-quote-line div:last-child,
  .admin-payment-event > div:last-child {
    justify-items: start;
  }

  .partner-quote-line-actions,
  .partner-quote-dialog-actions,
  .partner-quote-footer {
    align-items: stretch;
    flex-direction: column;
  }
}

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

  .sidebar {
    position: static;
    height: auto;
  }

  .sidebar-shell {
    height: auto;
  }
}

@media (max-width: 980px) {
  .shell {
    padding: 16px;
    gap: 16px;
  }

  .toolbar {
    flex-direction: column;
  }

  .toolbar-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .hero-card {
    grid-template-columns: 1fr;
    min-height: unset;
  }

  .hero-metrics {
    grid-template-columns: 1fr;
  }

  .result-summary-grid {
    grid-template-columns: 1fr;
  }

  .document-upload {
    grid-template-columns: 1fr;
  }

  .nav-row {
    flex-direction: column-reverse;
    align-items: stretch;
  }

  .nav-row button {
    width: 100%;
  }
}

@media (max-width: 680px) {
  body::before {
    opacity: 0.18;
  }

  .sidebar-shell,
  .toolbar,
  .hero-card,
  .panel {
    border-radius: 22px;
  }

  .status-pills,
  .toolbar-actions,
  .inline-actions,
  .field-actions {
    width: 100%;
  }

  .toolbar-actions > *,
  .inline-actions > *,
  .field-actions > * {
    width: 100%;
  }

  button,
  a.button-link {
    width: 100%;
  }

  .step-item {
    padding: 12px 14px;
  }
}

/* Next-gen simulation flow overrides */

.nextgen-shell {
  grid-template-columns: minmax(268px, 304px) minmax(0, 1fr);
  gap: 28px;
  padding: 28px;
}

.sidebar-shell {
  padding: 26px 20px;
  background:
    radial-gradient(circle at top left, rgba(38, 99, 235, 0.12), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(247, 250, 255, 0.8));
}

.sidebar-brand {
  margin-bottom: 6px;
}

.sidebar-brand .lede {
  max-width: 28ch;
}

.summary-pill-row,
.status-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.status-pills:empty,
#coverage-panel:empty,
#summary-panel:empty {
  display: none;
}

.soft-pill,
.status-pill {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(130, 148, 176, 0.18);
  background: rgba(247, 250, 255, 0.92);
  color: var(--ink-soft);
  font-size: 0.82rem;
  font-weight: 700;
}

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

.summary-empty {
  margin: 0;
  line-height: 1.6;
}

.summary-line {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.summary-line span {
  color: var(--muted);
  font-size: 0.9rem;
}

.summary-line strong {
  max-width: 18ch;
  text-align: right;
  font-size: 0.94rem;
}

.toolbar {
  position: static;
}

.hero-card {
  grid-template-columns: minmax(0, 1.5fr) minmax(280px, 0.9fr);
  gap: 22px;
  min-height: 0;
  padding: 26px 28px;
}

.hero-copy-block {
  max-width: 60ch;
}

.hero-copy-block p:last-child {
  margin-bottom: 0;
}

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

.hero-metric-card {
  padding: 14px 16px;
  border-radius: 20px;
  border: 1px solid rgba(130, 148, 176, 0.18);
  background: rgba(255, 255, 255, 0.78);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.hero-metric-card span {
  display: block;
  color: var(--muted);
  font-size: 0.78rem;
  margin-bottom: 6px;
}

.hero-metric-card strong {
  font-size: 1rem;
  line-height: 1.35;
}

.client-flow-shell,
.results-shell,
.expert-shell {
  display: grid;
  gap: 18px;
}

.stage-card {
  min-height: 380px;
}

.stage-panel {
  position: relative;
  overflow: hidden;
  padding: clamp(24px, 3vw, 34px);
  border-radius: 34px;
  border: 1px solid rgba(255, 255, 255, 0.68);
  background:
    radial-gradient(circle at top right, rgba(38, 99, 235, 0.08), transparent 26%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(248, 250, 255, 0.88));
  box-shadow: var(--shadow-lg);
  animation: rise-in 220ms ease;
}

.stage-panel-wide {
  min-height: 0;
}

.stage-intro,
.stage-block-head {
  max-width: 48ch;
}

.stage-intro h2,
.stage-block-head h3,
.destination-hero-card h3 {
  margin: 0 0 8px;
  font-family: ui-serif, Georgia, serif;
  font-weight: 600;
  letter-spacing: -0.03em;
}

.stage-intro p:last-child,
.stage-block-head p:last-child {
  margin-bottom: 0;
}

.choice-deck {
  display: grid;
  gap: 18px;
}

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

.choice-card,
.toggle-card,
.search-result-item {
  position: relative;
  width: 100%;
  padding: 18px 18px 20px;
  border-radius: 24px;
  border: 1px solid rgba(130, 148, 176, 0.18);
  background: rgba(255, 255, 255, 0.84);
  box-shadow: var(--shadow-sm);
  text-align: left;
}

.choice-card.is-selected,
.toggle-card.is-selected {
  border-color: rgba(38, 99, 235, 0.35);
  background:
    radial-gradient(circle at top right, rgba(38, 99, 235, 0.12), transparent 32%),
    rgba(255, 255, 255, 0.96);
  box-shadow: 0 16px 36px rgba(38, 99, 235, 0.14);
}

.choice-title {
  display: block;
  margin-bottom: 8px;
  font-size: 1rem;
  font-weight: 800;
  color: var(--ink);
}

.choice-note {
  display: block;
  color: var(--muted);
  line-height: 1.6;
  font-size: 0.92rem;
}

.stage-actions {
  position: static;
}

.stage-actions-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 16px 18px;
  border-radius: 24px;
  border: 1px solid rgba(255, 255, 255, 0.74);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(18px);
}

.stage-actions-inner > *:last-child {
  min-width: 220px;
}

.mini-form-grid,
.toggle-grid,
.expert-options-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.field.is-readonly input,
.field.is-readonly select {
  background: rgba(244, 247, 252, 0.9);
  color: var(--ink-soft);
}

.stage-inline-card,
.destination-hero-card,
.selected-place-card,
.selected-reference-card,
.expert-subsection {
  margin-top: 20px;
  padding: 18px;
  border-radius: 24px;
  border: 1px solid rgba(130, 148, 176, 0.16);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

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

.selected-place-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
}

.selected-reference-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
}

.selected-place-card p,
.selected-reference-card p,
.stage-hint-inline {
  margin: 6px 0 0;
  color: var(--muted);
}

.lookup-stack {
  display: grid;
  gap: 14px;
}

.vehicle-reference-card {
  background:
    radial-gradient(circle at top right, rgba(38, 99, 235, 0.08), transparent 30%),
    rgba(255, 255, 255, 0.78);
}

.nextgen-field.is-disabled {
  opacity: 0.68;
}

.nextgen-field span {
  font-weight: 700;
}

.nextgen-field input,
.nextgen-field select,
.nextgen-field textarea {
  min-height: 54px;
  border-radius: 18px;
}

.field-error {
  margin-top: 8px;
  color: var(--danger);
  font-size: 0.84rem;
  font-weight: 700;
}

.search-results {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.search-result-item strong,
.search-result-item span {
  display: block;
}

.search-result-item span {
  margin-top: 6px;
  color: var(--muted);
  font-size: 0.88rem;
}

.result-card.total-card {
  padding: 24px;
}

.grand-total {
  font-size: clamp(2rem, 1.8rem + 1vw, 3rem);
  font-weight: 800;
  letter-spacing: -0.04em;
}

.result-sections {
  display: grid;
  gap: 16px;
}

.expert-shell {
  gap: 20px;
}

.expert-subsection + .expert-subsection {
  margin-top: 16px;
}

.checkbox-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(130, 148, 176, 0.16);
  background: rgba(255, 255, 255, 0.84);
}

.radio-stack {
  display: grid;
  gap: 10px;
}

.subtle-note {
  padding: 14px 16px;
}

.subtle-note strong {
  display: block;
  margin-bottom: 6px;
}

.subtle-note p {
  margin: 0;
}

@media (max-width: 1220px) {
  .nextgen-shell {
    grid-template-columns: 1fr;
  }

  .hero-card {
    grid-template-columns: 1fr;
  }

  .stage-actions {
    position: static;
  }
}

@media (max-width: 820px) {
  .nextgen-shell {
    padding: 16px;
    gap: 18px;
  }

  .sidebar-shell {
    padding: 18px 16px;
  }

  .hero-card,
  .stage-panel,
  .toolbar,
  .sidebar-shell {
    border-radius: 24px;
  }

  .hero-metrics {
    grid-template-columns: 1fr;
  }

  .choice-grid,
  .mini-form-grid,
  .toggle-grid,
  .expert-options-grid {
    grid-template-columns: 1fr;
  }

  .destination-hero-card,
  .selected-place-card,
  .stage-actions-inner {
    flex-direction: column;
    align-items: stretch;
  }
}

/* Premium V2 refinements */

:root {
  --bg: #f3f0ea;
  --bg-strong: #fffdf9;
  --surface: rgba(255, 255, 255, 0.74);
  --surface-strong: rgba(255, 255, 255, 0.94);
  --surface-soft: rgba(247, 243, 236, 0.72);
  --ink: #13233f;
  --ink-soft: #31415f;
  --muted: #6b7890;
  --line: rgba(86, 104, 140, 0.14);
  --line-strong: rgba(86, 104, 140, 0.24);
  --accent: #2958d6;
  --accent-deep: #13294f;
  --accent-soft: rgba(41, 88, 214, 0.1);
  --shadow-lg: 0 34px 90px rgba(17, 30, 56, 0.12);
  --shadow-md: 0 18px 48px rgba(17, 30, 56, 0.08);
  --shadow-sm: 0 10px 28px rgba(17, 30, 56, 0.06);
  --font-sans: "Aptos", "Segoe UI Variable", "Segoe UI", "Inter", ui-sans-serif, system-ui, sans-serif;
  --font-display: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;
  --space-1: 6px;
  --space-2: 10px;
  --space-3: 14px;
  --space-4: 18px;
  --space-5: 24px;
  --space-6: 32px;
  --surface-stroke: rgba(255, 255, 255, 0.55);
}

body {
  color: var(--ink);
  font-family: var(--font-sans);
  background:
    radial-gradient(circle at top left, rgba(41, 88, 214, 0.1), transparent 24%),
    radial-gradient(circle at 82% 3%, rgba(15, 138, 97, 0.06), transparent 18%),
    linear-gradient(180deg, #faf7f2 0%, #f3f0ea 55%, #efebe5 100%);
}

body::before {
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.28) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.22) 1px, transparent 1px);
  background-size: 160px 160px;
  opacity: 0.14;
}

body::after {
  content: "";
  position: fixed;
  inset: auto auto -180px -120px;
  width: 520px;
  height: 520px;
  pointer-events: none;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(27, 61, 149, 0.08), transparent 68%);
  filter: blur(12px);
}

.sidebar-shell {
  width: min(100%, 304px);
  border-color: rgba(157, 175, 214, 0.12);
  background:
    radial-gradient(circle at top right, rgba(82, 118, 214, 0.18), transparent 24%),
    linear-gradient(180deg, rgba(14, 23, 40, 0.98), rgba(16, 27, 49, 0.98));
  box-shadow: 0 36px 90px rgba(8, 14, 28, 0.28);
  backdrop-filter: blur(22px);
}

.sidebar-brand h1,
#hero-title,
.panel-header h2,
.result-card h3,
.summary-card h2,
.status-card h2,
.stage-intro h2,
.stage-block-head h3,
.destination-hero-card h3,
.result-card h4 {
  font-family: var(--font-display);
}

.sidebar,
.sidebar .lede,
.sidebar #quote-meta,
.sidebar .summary-line span,
.sidebar .summary-line strong,
.sidebar .eyebrow,
.sidebar .status-pill,
.sidebar .soft-pill,
.sidebar .step-item strong,
.sidebar .step-item span,
.sidebar .muted-line {
  color: #edf3ff;
}

.sidebar .lede,
.sidebar #quote-meta,
.sidebar .summary-line span,
.sidebar .step-item span {
  color: rgba(237, 243, 255, 0.72);
}

.sidebar .eyebrow {
  color: rgba(196, 214, 255, 0.84);
}

.sidebar-card {
  margin-top: 18px;
  padding: 16px 0 0;
  border: 0;
  border-top: 1px solid rgba(190, 206, 238, 0.12);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

.status-card,
.summary-card,
.internal-card {
  padding-left: 0;
  padding-right: 0;
}

.summary-line strong {
  max-width: 16ch;
}

.step-item {
  border-color: rgba(190, 206, 238, 0.1);
  background: rgba(255, 255, 255, 0.04);
}

.step-item::after {
  background: rgba(190, 206, 238, 0.16);
}

.step-item.active {
  border-color: rgba(141, 172, 255, 0.38);
  background: linear-gradient(135deg, rgba(83, 125, 238, 0.2), rgba(255, 255, 255, 0.06));
  box-shadow: 0 18px 36px rgba(15, 26, 58, 0.28);
}

.step-item.completed {
  background: linear-gradient(135deg, rgba(38, 177, 123, 0.12), rgba(255, 255, 255, 0.05));
}

.step-index {
  background: rgba(255, 255, 255, 0.1);
  color: #edf3ff;
}

.toolbar {
  align-items: center;
  padding: 18px 22px;
  border: 1px solid rgba(255, 255, 255, 0.82);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 18px 40px rgba(17, 30, 56, 0.08);
}

#wizard-title {
  font-size: clamp(1.04rem, 0.94rem + 0.4vw, 1.32rem);
  letter-spacing: -0.02em;
}

#autosave-state {
  font-size: 0.88rem;
}

.hero-card {
  min-height: 0;
  padding: 30px 32px;
  border: 1px solid rgba(255, 255, 255, 0.88);
  background:
    radial-gradient(circle at 100% 0%, rgba(41, 88, 214, 0.13), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.84), rgba(255, 252, 246, 0.72));
}

#hero-title {
  margin-bottom: 12px;
  font-size: clamp(2.25rem, 1.9rem + 1vw, 3.35rem);
  line-height: 0.96;
}

#hero-copy,
.stage-lede {
  max-width: 46ch;
  color: var(--ink-soft);
  font-size: 0.98rem;
  line-height: 1.65;
}

.hero-metric-card,
.metric-card {
  border-color: rgba(86, 104, 140, 0.12);
  background: rgba(255, 255, 255, 0.52);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.hero-metrics {
  align-content: start;
  justify-content: end;
}

.hero-metric-chip {
  display: grid;
  gap: 4px;
  align-content: start;
  min-height: 92px;
  padding: 14px 16px;
  border-left: 1px solid rgba(86, 104, 140, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.3), rgba(255, 255, 255, 0.06));
}

.hero-metric-chip span {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.hero-metric-chip strong {
  font-size: 1rem;
  line-height: 1.25;
}

.hero-progress-card {
  display: grid;
  gap: 12px;
  align-content: start;
  padding: 16px 0 0 22px;
  border-left: 1px solid rgba(86, 104, 140, 0.12);
}

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

.hero-progress-head span {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.hero-progress-head strong {
  font-size: 1.08rem;
  font-weight: 800;
  color: var(--ink);
}

.hero-progress-bar {
  position: relative;
  overflow: hidden;
  height: 8px;
  border-radius: 999px;
  background: rgba(86, 104, 140, 0.12);
}

.hero-progress-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(35, 79, 208, 0.9), rgba(75, 117, 224, 0.74));
  box-shadow: 0 8px 18px rgba(35, 79, 208, 0.18);
}

.hero-progress-stage {
  margin: 0;
  color: var(--ink);
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.hero-progress-copy {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.stage-card {
  min-height: 0;
}

.stage-panel,
.result-card,
.subpanel,
.embedded-list {
  border-color: rgba(86, 104, 140, 0.12);
}

.stage-panel {
  padding: clamp(26px, 3vw, 38px);
  border-radius: 38px;
  background:
    radial-gradient(circle at top right, rgba(41, 88, 214, 0.08), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(255, 252, 247, 0.74));
  box-shadow: var(--shadow-lg);
}

.stage-panel::before,
.result-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  border: 1px solid rgba(255, 255, 255, 0.38);
  mask: linear-gradient(180deg, rgba(0, 0, 0, 0.9), transparent 70%);
}

.stage-intro,
.stage-block-head {
  display: grid;
  gap: 8px;
  max-width: 38ch;
}

.stage-intro h2,
.stage-block-head h3,
.destination-hero-card h3 {
  margin-bottom: 0;
  font-size: clamp(1.55rem, 1.3rem + 0.55vw, 2.1rem);
  line-height: 0.98;
}

.compact-head {
  max-width: 34ch;
}

.title-with-info {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.title-with-info h3,
.title-with-info h2 {
  margin: 0;
}

.field-head {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 20px;
}

.field-title {
  color: var(--ink-soft);
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.info-bubble {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  outline: none;
}

.info-bubble-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 19px;
  height: 19px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(86, 104, 140, 0.18);
  background: rgba(244, 247, 255, 0.86);
  color: var(--muted);
  font-size: 0.67rem;
  font-weight: 800;
  line-height: 1;
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    color 180ms ease,
    background-color 180ms ease;
  box-shadow: none;
}

.info-bubble.is-subtle .info-bubble-trigger {
  background: rgba(248, 250, 255, 0.6);
}

.info-bubble-popover {
  position: fixed;
  left: var(--bubble-left, 16px);
  top: var(--bubble-top, 16px);
  z-index: 12;
  pointer-events: none;
  width: min(300px, calc(100vw - 32px));
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(86, 104, 140, 0.14);
  background: rgba(18, 28, 51, 0.96);
  color: rgba(247, 250, 255, 0.92);
  font-size: 0.82rem;
  line-height: 1.5;
  box-shadow: 0 22px 50px rgba(10, 17, 31, 0.24);
  opacity: 0;
  visibility: hidden;
  transform: translateY(6px) scale(0.985);
  transform-origin: top right;
  transition:
    opacity 160ms ease,
    transform 160ms ease,
    visibility 160ms ease;
}

.info-bubble.align-left .info-bubble-popover {
  left: var(--bubble-left, 16px);
  right: auto;
}

.info-bubble[data-placement="top"] .info-bubble-popover {
  transform-origin: bottom right;
}

.info-bubble:hover .info-bubble-trigger,
.info-bubble:focus-within .info-bubble-trigger,
.info-bubble.is-open .info-bubble-trigger {
  transform: translateY(-1px);
  border-color: rgba(41, 88, 214, 0.28);
  color: var(--accent-deep);
  background: rgba(239, 244, 255, 0.94);
}

.info-bubble:hover .info-bubble-popover,
.info-bubble:focus-within .info-bubble-popover,
.info-bubble.is-open .info-bubble-popover {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
}

.info-bubble .info-bubble-popover {
  display: none !important;
}

.info-bubble-popover-global {
  display: block;
  pointer-events: none;
}

.info-bubble-popover-global:not([hidden]) {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
}

.info-bubble-popover-global[hidden] {
  display: none !important;
}

.choice-grid {
  gap: 16px;
}

.choice-deck + .choice-deck,
.choice-deck + .stage-inline-card,
.stage-inline-card + .choice-deck,
.stage-inline-card + .stage-inline-card {
  margin-top: 22px;
}

.choice-card,
.toggle-card,
.search-result-item,
.stage-actions-inner,
.selected-reference-card,
.selected-place-card,
.stage-inline-card,
.destination-hero-card,
.expert-subsection,
.opportunity-card,
.result-line-card {
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    background-color 180ms ease,
    box-shadow 180ms ease;
}

.choice-card,
.toggle-card,
.search-result-item {
  padding: 18px 18px 18px;
  border-radius: 26px;
  border-color: rgba(86, 104, 140, 0.13);
  background: rgba(255, 255, 255, 0.7);
  box-shadow: none;
}

.choice-card::after,
.toggle-card::after,
.search-result-item::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1px solid rgba(255, 255, 255, 0.4);
  opacity: 0;
  transition: opacity 180ms ease;
}

.choice-card:hover,
.toggle-card:hover,
.search-result-item:hover {
  transform: translateY(-2px);
  border-color: rgba(41, 88, 214, 0.2);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 20px 44px rgba(17, 30, 56, 0.08);
}

.choice-card:hover::after,
.toggle-card:hover::after,
.search-result-item:hover::after,
.choice-card.is-selected::after,
.toggle-card.is-selected::after {
  opacity: 1;
}

.choice-card.is-selected,
.toggle-card.is-selected {
  border-color: rgba(41, 88, 214, 0.28);
  background:
    radial-gradient(circle at top right, rgba(41, 88, 214, 0.12), transparent 32%),
    rgba(255, 255, 255, 0.96);
  box-shadow: 0 20px 44px rgba(41, 88, 214, 0.12);
}

.choice-title {
  margin-bottom: 6px;
  font-size: 1.02rem;
  letter-spacing: -0.02em;
}

.choice-note {
  max-width: 28ch;
  color: var(--muted);
  font-size: 0.87rem;
  line-height: 1.5;
}

.stage-actions-inner {
  padding: 14px 16px;
  border-radius: 999px;
  border-color: rgba(255, 255, 255, 0.92);
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 20px 48px rgba(17, 30, 56, 0.1);
}

.stage-actions-inner > *:last-child {
  min-width: 240px;
}

input,
select,
textarea,
.nextgen-field input,
.nextgen-field select,
.nextgen-field textarea {
  min-height: 56px;
  padding: 15px 16px;
  border-radius: 20px;
  border-color: rgba(86, 104, 140, 0.14);
  background: rgba(255, 255, 255, 0.82);
  color: var(--ink);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

input::placeholder,
textarea::placeholder {
  color: #97a2b8;
}

input:hover,
select:hover,
textarea:hover {
  border-color: rgba(86, 104, 140, 0.22);
  background: rgba(255, 255, 255, 0.9);
}

input:focus,
select:focus,
textarea:focus {
  border-color: rgba(41, 88, 214, 0.34);
  box-shadow:
    0 0 0 4px rgba(41, 88, 214, 0.08),
    0 16px 28px rgba(41, 88, 214, 0.08);
}

.field small {
  display: none;
}

.stage-inline-card,
.destination-hero-card,
.selected-place-card,
.selected-reference-card,
.expert-subsection {
  padding: 16px 18px;
  border-color: rgba(86, 104, 140, 0.08);
  background: rgba(255, 255, 255, 0.34);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

.selected-reference-card p,
.selected-place-card p,
.stage-inline-meta,
.stage-hint-inline,
.search-status {
  color: var(--muted);
  font-size: 0.85rem;
  line-height: 1.55;
}

.stage-inline-meta {
  margin: 4px 0 0;
}

.search-status {
  margin-top: 10px;
}

.compact-results:empty {
  display: none;
}

.soft-pill,
.status-pill,
.contact-chip,
.signal-chip {
  border-color: rgba(86, 104, 140, 0.12);
  background: rgba(248, 250, 255, 0.86);
  color: var(--ink-soft);
}

.soft-pill.subtle {
  color: var(--muted);
}

.result-card {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.88), rgba(255, 252, 247, 0.76));
  box-shadow: var(--shadow-md);
}

.total-card,
.savings-card,
.contact-card {
  background:
    radial-gradient(circle at top right, rgba(41, 88, 214, 0.1), transparent 26%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 252, 247, 0.82));
}

.result-overview-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(320px, 0.9fr);
  gap: 24px;
  padding: 28px;
}

.result-overview-main {
  display: grid;
  align-content: start;
  gap: 10px;
}

.result-overview-topline {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.result-overview-label {
  margin: 0;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.result-overview-copy {
  margin: 0;
  max-width: 46ch;
  color: var(--ink-soft);
  line-height: 1.65;
}

.result-overview-rail {
  display: grid;
  gap: 12px;
  align-content: start;
}

.result-overview-metric {
  display: grid;
  gap: 6px;
  padding: 14px 0 0 18px;
  border-left: 1px solid rgba(86, 104, 140, 0.12);
}

.result-overview-metric span {
  color: var(--muted);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.result-overview-metric strong {
  font-size: 1.15rem;
  letter-spacing: -0.03em;
}

.grand-total {
  font-size: clamp(2.5rem, 2rem + 1vw, 3.7rem);
  line-height: 0.96;
}

.result-section-head h3 {
  font-size: clamp(1.2rem, 1.05rem + 0.35vw, 1.5rem);
  letter-spacing: -0.03em;
}

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

.section-chip {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(86, 104, 140, 0.12);
  background: rgba(248, 250, 255, 0.9);
  color: var(--ink-soft);
  font-size: 0.76rem;
  font-weight: 800;
}

.section-chip.ok {
  background: rgba(15, 138, 97, 0.1);
  color: var(--ok);
}

.section-chip.warn {
  background: rgba(194, 123, 0, 0.12);
  color: var(--warn);
}

.section-chip.danger {
  background: rgba(208, 68, 68, 0.1);
  color: var(--danger);
}

.result-section {
  padding: 22px 24px;
}

.result-line-card {
  padding: 16px 0;
  border: 0;
  border-radius: 0;
  border-bottom: 1px solid rgba(86, 104, 140, 0.1);
  background: transparent;
  box-shadow: none;
}

.result-line-card:last-child {
  border-bottom: 0;
}

.result-line-card:hover {
  transform: none;
  border-color: rgba(86, 104, 140, 0.14);
  background: transparent;
  box-shadow: none;
}

.line-basis,
.muted-line {
  color: var(--muted);
}

.line-basis {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.signal-cloud,
.contact-highlights {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.signal-chip {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 0.84rem;
  font-weight: 700;
}

.micro-disclosure {
  margin-top: 16px;
  padding-top: 2px;
  border-top: 1px solid rgba(86, 104, 140, 0.1);
}

.micro-disclosure summary {
  cursor: pointer;
  list-style: none;
  color: var(--accent-deep);
  font-size: 0.88rem;
  font-weight: 800;
}

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

.micro-disclosure h4 {
  margin: 14px 0 10px;
  font-size: 0.95rem;
}

.compact-guidance {
  display: grid;
  gap: 12px;
}

.compact-guidance-intro {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.65;
}

.lead-capture-panel,
.embedded-list {
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(86, 104, 140, 0.12);
  box-shadow: 0 22px 44px rgba(18, 32, 62, 0.08);
  padding: 20px;
}

.lead-capture-panel .result-section-head,
.confirmation-panel .embedded-list {
  gap: 8px;
}

.result-contact-actions {
  gap: 10px;
}

.contact-card-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 0.9fr);
  gap: 18px;
  align-items: center;
}

.contact-card-copy {
  display: grid;
  gap: 8px;
}

.contact-card-copy p {
  margin: 0;
}

.contact-card-actions {
  display: grid;
  gap: 10px;
  justify-items: end;
}

.contact-card-actions > * {
  width: min(100%, 360px);
}

.lead-panel-head {
  display: grid;
  gap: 8px;
}

.lead-panel-copy {
  display: grid;
  gap: 8px;
}

.lead-panel-copy h4,
.confirmation-panel h4 {
  margin: 0;
  font-size: clamp(1.08rem, 1.8vw, 1.34rem);
  letter-spacing: -0.03em;
}

.lead-panel-copy p,
.confirmation-panel p {
  margin: 0;
}

.lead-form-grid {
  gap: 14px;
}

.lead-capture-panel .nextgen-field {
  background: rgba(255, 255, 255, 0.92);
}

.lead-capture-panel .nextgen-field input {
  min-height: 54px;
}

.lead-capture-panel .field-error {
  margin: 0;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(185, 61, 61, 0.18);
  background: rgba(250, 235, 235, 0.94);
}

button,
a.button-link {
  min-height: 48px;
  padding: 0 18px;
  border-radius: 999px;
  border-color: rgba(86, 104, 140, 0.14);
  font-size: 0.92rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  box-shadow: 0 10px 26px rgba(17, 30, 56, 0.05);
}

button.primary,
a.button-link.primary {
  background: linear-gradient(135deg, #234fd0, #173da8);
  border-color: rgba(35, 79, 208, 0.14);
}

button.primary:hover,
a.button-link.primary:hover {
  box-shadow: 0 22px 44px rgba(35, 79, 208, 0.24);
}

button.secondary,
a.button-link.secondary {
  background: rgba(255, 255, 255, 0.62);
}

.empty-state,
.warning-card,
.support-card,
.contact-card {
  padding: 22px;
}

.result-guidance-grid {
  grid-template-columns: minmax(0, 1fr) minmax(340px, 0.96fr);
  gap: 18px;
}

.option-flags-card {
  margin-top: 24px;
}

.option-flags-grid {
  gap: 14px;
}

@keyframes rise-in {
  from {
    opacity: 0;
    transform: translateY(10px) scale(0.995);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@media (max-width: 980px) {
  .stage-actions-inner {
    border-radius: 28px;
  }

  .stage-actions-inner > *:last-child {
    min-width: 0;
  }
}

@media (max-width: 820px) {
  .hero-card,
  .stage-panel,
  .result-card,
  .toolbar,
  .sidebar-shell {
    border-radius: 26px;
  }

  .result-overview-shell {
    grid-template-columns: 1fr;
  }

  .stage-actions-inner {
    border-radius: 26px;
  }

  .contact-card-shell,
  .result-guidance-grid {
    grid-template-columns: 1fr;
  }

  .contact-card-actions {
    justify-items: stretch;
  }

  .info-bubble-popover {
    width: min(240px, 72vw);
  }
}

/* Premium desktop + mobile redesign */

.shell.nextgen-shell {
  grid-template-columns: minmax(214px, 248px) minmax(0, 1fr);
  gap: 32px;
  max-width: 1500px;
}

.sidebar {
  align-self: start;
  top: 18px;
  height: auto;
}

.sidebar-shell {
  width: 100%;
  height: auto;
  max-height: calc(100svh - 36px);
  padding: 18px 16px 20px;
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(82, 118, 214, 0.15), transparent 24%),
    linear-gradient(180deg, rgba(14, 23, 40, 0.94), rgba(16, 27, 49, 0.96));
}

.sidebar-brand {
  margin-bottom: 2px;
}

.sidebar-brand h1 {
  font-size: clamp(1.95rem, 1.55rem + 0.6vw, 2.45rem);
  line-height: 0.96;
}

.sidebar-brand .lede {
  max-width: 24ch;
  font-size: 0.92rem;
  line-height: 1.62;
}

.sidebar-card {
  margin-top: 14px;
  padding-top: 14px;
}

.stepper {
  gap: 8px;
}

.step-item {
  padding: 12px 14px;
  border-radius: 16px;
}

.content {
  gap: 18px;
  min-width: 0;
}

.toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  padding: 16px 18px;
  border-radius: 24px;
}

.toolbar-copy {
  min-width: 0;
}

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

.hero-card {
  padding: 26px 28px;
  gap: 18px;
  border-radius: 32px;
  grid-template-columns: minmax(0, 1.55fr) minmax(240px, 0.78fr);
}

.hero-copy-block {
  display: grid;
  gap: 14px;
  min-width: 0;
}

#hero-title {
  max-width: 10ch;
  margin: 0;
}

#hero-copy {
  margin: 0;
}

.hero-support-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.hero-support-chip {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 7px 11px;
  border-radius: 999px;
  border: 1px solid rgba(86, 104, 140, 0.12);
  background: rgba(255, 255, 255, 0.68);
  color: var(--ink-soft);
  font-size: 0.8rem;
  font-weight: 800;
}

.hero-progress-card {
  min-width: 0;
  padding: 10px 0 0 18px;
}

.stage-panel {
  border-radius: 34px;
}

.stage-panel,
.result-card {
  box-shadow:
    0 24px 58px rgba(17, 30, 56, 0.08),
    0 2px 0 rgba(255, 255, 255, 0.55) inset;
}

.stage-panel,
.result-card,
.result-body-layout > * {
  min-width: 0;
}

.mobile-summary-shell {
  display: none;
}

.result-body-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.76fr);
  gap: 18px;
  align-items: start;
}

.result-main-column,
.result-side-column {
  display: grid;
  gap: 16px;
  min-width: 0;
}

.result-side-column {
  position: sticky;
  top: 18px;
}

.result-side-column .contact-card {
  background:
    radial-gradient(circle at top right, rgba(84, 122, 226, 0.22), transparent 26%),
    linear-gradient(180deg, rgba(16, 28, 53, 0.98), rgba(22, 39, 76, 0.96));
  color: #eef4ff;
}

.result-side-column .contact-card .muted-line,
.result-side-column .contact-card .eyebrow,
.result-side-column .contact-card h3,
.result-side-column .contact-card p {
  color: inherit;
}

.result-side-column .contact-card .muted-line {
  color: rgba(238, 244, 255, 0.76);
}

.result-side-column .contact-chip {
  border-color: rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.08);
  color: #f4f7ff;
}

.result-side-column .contact-card button.secondary {
  background: rgba(255, 255, 255, 0.1);
  color: #f4f7ff;
  border-color: rgba(255, 255, 255, 0.1);
}

.result-side-column .contact-card .embedded-list,
.result-side-column .contact-card .lead-capture-panel {
  background: rgba(255, 255, 255, 0.96);
  color: var(--ink);
}

.result-side-column .contact-card .embedded-list .muted-line,
.result-side-column .contact-card .lead-capture-panel .muted-line,
.result-side-column .contact-card .embedded-list p,
.result-side-column .contact-card .lead-capture-panel p {
  color: var(--ink-soft);
}

.provisional-quote-panel {
  margin-top: 16px;
}

.provisional-quote-panel .lead-capture-panel {
  background: rgba(247, 250, 255, 0.96);
  border: 1px dashed rgba(86, 104, 140, 0.28);
  box-shadow: none;
  padding: 16px 18px;
}

.provisional-quote-submit {
  width: 100%;
  min-height: 46px;
}

.provisional-quote-submit:disabled {
  cursor: not-allowed;
  opacity: 0.72;
}

.result-shift-card {
  background: linear-gradient(180deg, rgba(255, 252, 247, 0.94), rgba(248, 245, 240, 0.84));
}

.result-overview-shell {
  gap: 22px;
  padding: 30px 32px;
}

.result-overview-main {
  gap: 12px;
}

.result-overview-copy {
  max-width: 38ch;
}

.result-overview-rail {
  gap: 10px;
}

.result-overview-metric {
  padding-left: 16px;
}

.result-sections {
  gap: 12px;
}

.result-section {
  padding: 20px 22px;
}

.section-items {
  gap: 0;
}

.result-line-card {
  padding: 14px 0;
}

.line-basis {
  -webkit-line-clamp: 3;
}

.contact-card-shell {
  gap: 14px;
}

.contact-card-actions > * {
  min-height: 52px;
}

.lead-capture-panel .mini-form-grid {
  grid-template-columns: 1fr;
}

.mobile-summary-card {
  margin: 0;
  border: 1px solid rgba(255, 255, 255, 0.82);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 18px 36px rgba(17, 30, 56, 0.08);
  overflow: hidden;
}

.mobile-summary-toggle {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  cursor: pointer;
}

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

.mobile-summary-intro {
  display: grid;
  gap: 4px;
}

.mobile-summary-brand {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.mobile-summary-intro strong,
.mobile-summary-count {
  color: var(--ink);
  font-size: 0.95rem;
  font-weight: 800;
}

.mobile-summary-track {
  position: relative;
  height: 6px;
  margin: 0 16px 12px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(86, 104, 140, 0.12);
}

.mobile-summary-track span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(35, 79, 208, 0.88), rgba(75, 117, 224, 0.72));
}

.mobile-summary-copy {
  margin: 0 16px 12px;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.55;
}

.mobile-summary-list {
  display: grid;
  gap: 10px;
  padding: 0 16px 16px;
}

.mobile-summary-line {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.mobile-summary-line span {
  color: var(--muted);
  font-size: 0.84rem;
}

.mobile-summary-line strong {
  color: var(--ink);
  font-size: 0.9rem;
  text-align: right;
}

@media (max-width: 1100px) {
  .shell.nextgen-shell {
    grid-template-columns: minmax(196px, 224px) minmax(0, 1fr);
    gap: 24px;
  }

  .sidebar-shell {
    padding: 16px 14px 18px;
  }

  .hero-card {
    grid-template-columns: minmax(0, 1.4fr) minmax(220px, 0.8fr);
  }
}

@media (max-width: 980px) {
  .shell.nextgen-shell {
    grid-template-columns: 1fr;
    padding: 14px;
    gap: 14px;
  }

  .sidebar {
    display: none;
  }

  .mobile-summary-shell {
    display: none;
  }

  .toolbar {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 14px 14px 12px;
    border-radius: 22px;
  }

  .toolbar-actions {
    width: 100%;
    justify-content: stretch;
    gap: 8px;
  }

  .toolbar-entry-shell .toolbar-actions {
    justify-content: stretch;
  }

  .toolbar-actions > button {
    flex: 1 1 0;
    min-width: 0;
  }

  #technical-toggle-btn {
    display: none;
  }

  .hero-card {
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 22px 18px;
    border-radius: 26px;
  }

  .hero-card.is-mobile-centered .hero-copy-block {
    margin: 0 auto;
    text-align: center;
  }

  .hero-card.is-mobile-centered #hero-title,
  .hero-card.is-mobile-centered #hero-copy,
  .hero-card.is-mobile-centered .eyebrow {
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }

  .hero-card.is-mobile-centered .hero-metrics {
    justify-self: stretch;
  }

  #hero-title {
    max-width: 11ch;
    font-size: clamp(2rem, 8vw, 2.8rem);
  }

  #hero-copy,
  .stage-lede {
    max-width: none;
    font-size: 0.93rem;
    line-height: 1.58;
  }

  .hero-progress-card {
    padding: 4px 0 0;
    border-left: 0;
  }

  .stage-panel {
    padding: 20px 16px 18px;
    border-radius: 24px;
  }

  .stage-intro h2,
  .stage-block-head h3,
  .destination-hero-card h3 {
    font-size: clamp(1.42rem, 6.6vw, 1.85rem);
  }

  .choice-grid,
  .mini-form-grid,
  .toggle-grid,
  .expert-options-grid,
  .field-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .choice-card,
  .toggle-card,
  .search-result-item {
    padding: 16px;
    border-radius: 20px;
  }

  .destination-hero-card,
  .selected-place-card,
  .selected-reference-card,
  .stage-actions-inner {
    flex-direction: column;
    align-items: stretch;
  }

  .stage-actions-inner {
    padding: 12px;
    border-radius: 22px;
    gap: 10px;
  }

  .stage-actions-inner > * {
    width: 100%;
  }

  input,
  select,
  textarea,
  .nextgen-field input,
  .nextgen-field select,
  .nextgen-field textarea,
  button,
  a.button-link {
    min-height: 54px;
  }

  .result-overview-shell {
    grid-template-columns: 1fr;
    padding: 22px 18px;
    border-radius: 24px;
  }

  .result-overview-main {
    gap: 10px;
  }

  .grand-total {
    font-size: clamp(2.4rem, 10vw, 3.2rem);
  }

  .result-body-layout {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .result-side-column {
    position: static;
    order: 2;
  }

  .result-main-column {
    order: 1;
  }

  .result-section,
  .support-card,
  .contact-card,
  .result-shift-card,
  .savings-card {
    padding: 18px 16px;
    border-radius: 22px;
  }

  .result-section-head,
  .line-head {
    gap: 10px;
  }

  .line-basis {
    -webkit-line-clamp: 4;
  }

  .contact-card-shell {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .contact-card-actions {
    justify-items: stretch;
  }

  .contact-card-actions > * {
    width: 100%;
  }

  .lead-capture-panel,
  .embedded-list {
    padding: 16px;
    border-radius: 20px;
  }

  .info-bubble-popover {
    width: min(260px, calc(100vw - 24px));
    border-radius: 16px;
  }
}

@media (max-width: 480px) {
  .shell.nextgen-shell {
    padding: 12px;
  }

  .toolbar {
    padding: 12px 12px 10px;
  }

  #wizard-title {
    font-size: 0.98rem;
  }

  #autosave-state {
    font-size: 0.8rem;
  }

  .mobile-summary-toggle,
  .mobile-summary-copy,
  .mobile-summary-list,
  .mobile-summary-track {
    margin-left: 14px;
    margin-right: 14px;
  }

  .mobile-summary-toggle {
    margin: 0;
    padding: 14px;
  }

  .hero-card {
    padding: 20px 16px;
  }

  #hero-title {
    font-size: clamp(1.8rem, 10vw, 2.35rem);
  }

  .hero-support-row {
    gap: 6px;
  }

  .hero-support-chip {
    min-height: 30px;
    padding: 6px 10px;
    font-size: 0.76rem;
  }

  .stage-panel {
    padding: 18px 14px 16px;
  }

  .result-overview-shell,
  .result-section,
  .support-card,
  .contact-card,
  .result-shift-card,
  .savings-card {
    padding: 16px 14px;
  }

  .result-overview-topline {
    gap: 6px;
  }

  .badge,
  .soft-pill,
  .contact-chip,
  .signal-chip,
  .section-chip {
    font-size: 0.74rem;
  }

  .result-overview-metric {
    padding-left: 0;
    padding-top: 10px;
    border-left: 0;
    border-top: 1px solid rgba(86, 104, 140, 0.1);
  }
}

@media (max-width: 360px) {
  .toolbar-actions {
    grid-template-columns: 1fr;
  }

  .toolbar-actions > button {
    flex: 1 1 100%;
  }

  .grand-total {
    font-size: clamp(2.1rem, 11vw, 2.8rem);
  }

  .info-bubble-popover {
    width: calc(100vw - 20px);
  }
}

.conversion-offer-card {
  display: grid;
  gap: 14px;
  padding: 20px 22px;
  background:
    radial-gradient(circle at top right, rgba(56, 111, 238, 0.14), transparent 30%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 250, 255, 0.92));
}

.conversion-offer-head {
  display: grid;
  gap: 4px;
}

.conversion-offer-head h3 {
  margin: 0;
  font-size: clamp(1.18rem, 2vw, 1.48rem);
  letter-spacing: -0.03em;
}

.conversion-offer-note {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

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

.conversion-offer-metric {
  border: 1px solid rgba(86, 104, 140, 0.14);
  border-radius: 18px;
  padding: 14px 15px;
  background: rgba(255, 255, 255, 0.86);
  display: grid;
  gap: 6px;
  box-shadow: 0 16px 34px rgba(18, 32, 62, 0.06);
}

.conversion-offer-metric span {
  font-size: 0.77rem;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: rgba(32, 46, 76, 0.68);
}

.conversion-offer-metric strong {
  font-size: 1.18rem;
  color: rgba(22, 30, 48, 0.95);
}

.conversion-offer-metric small {
  font-size: 0.78rem;
  line-height: 1.35;
  color: rgba(32, 46, 76, 0.66);
}

.contact-card-actions .ghost,
.dossier-account-actions .ghost {
  background: rgba(255, 255, 255, 0.55);
  border-color: rgba(86, 104, 140, 0.24);
}

.contact-card-actions .ghost:hover,
.dossier-account-actions .ghost:hover {
  background: rgba(255, 255, 255, 0.84);
}

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

  .conversion-offer-metric {
    padding: 11px 12px;
  }

  .conversion-offer-card,
  .contact-card {
    padding: 18px 16px;
  }

  .lead-capture-panel,
  .embedded-list {
    padding: 16px;
    border-radius: 20px;
  }

  .lead-capture-panel .nextgen-field input {
    min-height: 52px;
  }
}

body.dossier-mode .shell.nextgen-shell {
  grid-template-columns: 1fr;
  max-width: 1180px;
}

body.dossier-mode .content {
  gap: 16px;
}

body.dossier-mode .results-shell {
  gap: 0;
}

.auth-shell {
  grid-template-columns: minmax(0, 1fr);
  width: min(100%, 1440px);
  max-width: 1440px;
  min-height: 100vh;
  align-items: start;
  padding-top: clamp(18px, 3vw, 36px);
}

.auth-shell .content {
  width: min(calc(100vw - 56px), 1240px);
  max-width: 1240px;
  margin-inline: auto;
  justify-self: center;
  gap: clamp(18px, 2vw, 28px);
}

.shell.nextgen-shell.auth-shell {
  grid-template-columns: minmax(0, 1fr);
  width: min(100%, 1440px);
  max-width: 1440px;
}

.home-shell {
  min-height: 100vh;
  align-items: center;
}

.home-hero-card {
  min-height: 0;
}

.home-actions-shell {
  display: grid;
  gap: 14px;
  max-width: 420px;
}

.home-actions-shell .button-link {
  justify-content: center;
}

.admin-dashboard-grid {
  grid-template-columns: minmax(360px, 420px) minmax(0, 1fr);
  gap: 24px;
  align-items: start;
}

.admin-dashboard-grid > * {
  min-width: 0;
  position: relative;
}

.admin-dashboard-grid > :first-child {
  z-index: 2;
}

.admin-dashboard-grid > :last-child {
  z-index: 1;
}

.client-dossier-dashboard {
  display: grid;
  gap: 18px;
}

.dossier-hero-card,
.dossier-summary-card,
.dossier-progress-card,
.dossier-payment-card,
.dossier-account-card,
.dossier-section-card,
.dossier-footer-card,
.dossier-estimate-disclosure {
  border-radius: 30px;
  border: 1px solid rgba(86, 104, 140, 0.12);
  background:
    radial-gradient(circle at top right, rgba(41, 88, 214, 0.08), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 250, 255, 0.9));
  box-shadow:
    0 24px 54px rgba(17, 30, 56, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

.dossier-hero-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
  padding: 28px 30px;
}

.dossier-hero-copy {
  display: grid;
  gap: 10px;
}

.dossier-hero-copy h2 {
  margin: 0;
  font-size: clamp(1.8rem, 1.45rem + 0.9vw, 2.55rem);
  line-height: 0.98;
}

.dossier-hero-text {
  margin: 0;
  max-width: 58ch;
  color: var(--ink-soft);
  line-height: 1.7;
}

.dossier-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.dossier-hero-actions {
  display: flex;
  justify-content: flex-end;
}

.dossier-dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, 0.86fr);
  gap: 18px;
  align-items: start;
}

#client-access-connected.dossier-dashboard-grid {
  grid-template-columns: minmax(0, 820px);
  justify-content: center;
}

.client-access-connected-card {
  width: 100%;
  overflow: hidden;
}

#client-access-login.dossier-dashboard-grid {
  grid-template-columns: minmax(320px, 0.86fr) minmax(360px, 1fr);
}

#client-access-login .hero-card {
  align-self: stretch;
  min-height: 280px;
  display: flex;
  align-items: center;
}

#client-access-login .result-card {
  min-height: 0;
}

.dossier-summary-card,
.dossier-progress-card,
.dossier-payment-card,
.dossier-account-card,
.dossier-section-card,
.dossier-footer-card {
  padding: 24px;
}

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

.dossier-summary-item {
  display: grid;
  gap: 6px;
  padding: 16px 18px;
  border-radius: 20px;
  border: 1px solid rgba(86, 104, 140, 0.1);
  background: rgba(255, 255, 255, 0.82);
}

.dossier-summary-item span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.dossier-summary-item strong {
  font-size: 1.05rem;
  line-height: 1.2;
}

.dossier-summary-item-wide {
  grid-column: 1 / -1;
}

.dossier-summary-item p {
  margin: 0;
}

.dossier-count-grid {
  margin-top: 18px;
}

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

.dossier-section-head {
  display: grid;
  gap: 6px;
  margin-bottom: 16px;
}

.dossier-section-head h4,
.dossier-section-head h3 {
  margin: 0;
}

.dossier-progress-steps {
  display: grid;
  gap: 14px;
}

.dossier-progress-step {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid rgba(86, 104, 140, 0.08);
}

.dossier-progress-step:last-child {
  border-bottom: 0;
}

.dossier-progress-dot {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  border: 2px solid rgba(86, 104, 140, 0.18);
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 0 0 6px rgba(86, 104, 140, 0.04);
}

.dossier-progress-step strong {
  display: block;
  font-size: 0.98rem;
}

.dossier-progress-step.complete .dossier-progress-dot {
  border-color: rgba(15, 138, 97, 0.22);
  background: rgba(15, 138, 97, 0.92);
  box-shadow: 0 0 0 6px rgba(15, 138, 97, 0.09);
}

.dossier-progress-step.current .dossier-progress-dot {
  border-color: rgba(35, 79, 208, 0.28);
  background: rgba(35, 79, 208, 0.94);
  box-shadow: 0 0 0 6px rgba(35, 79, 208, 0.1);
}

.dossier-progress-step.blocked .dossier-progress-dot {
  border-color: rgba(208, 68, 68, 0.24);
  background: rgba(208, 68, 68, 0.92);
  box-shadow: 0 0 0 6px rgba(208, 68, 68, 0.08);
}

.dossier-checklist-shell {
  display: grid;
  gap: 18px;
}

.dossier-documents-block {
  display: grid;
  gap: 18px;
}

.dossier-documents-subsection {
  display: grid;
  gap: 14px;
}

.dossier-documents-subsection + .dossier-documents-subsection {
  padding-top: 18px;
  border-top: 1px solid rgba(86, 104, 140, 0.08);
}

.dossier-documents-subsection h4 {
  margin: 0;
  font-size: 1rem;
}

.dossier-progress-disclosures {
  display: grid;
  gap: 14px;
  margin-top: 18px;
}

.dossier-disclosure-card {
  padding: 18px 20px;
}

.dossier-disclosure-card summary,
.dossier-payment-card summary {
  cursor: pointer;
  list-style: none;
  color: var(--accent-deep);
  font-weight: 800;
}

.dossier-disclosure-card summary::-webkit-details-marker,
.dossier-payment-card summary::-webkit-details-marker {
  display: none;
}

.dossier-disclosure-body,
.dossier-payment-grid {
  margin-top: 16px;
}

.dossier-document-grid {
  display: grid;
  gap: 14px;
}

.dossier-document-card {
  display: grid;
  gap: 14px;
  padding: 18px 18px 16px;
  border-radius: 24px;
  border: 1px solid rgba(86, 104, 140, 0.1);
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 16px 34px rgba(17, 30, 56, 0.06);
}

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

.dossier-document-head p {
  margin: 0;
}

.dossier-card-actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.dossier-upload-btn {
  min-width: 210px;
}

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

.dossier-uploaded-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(86, 104, 140, 0.1);
  background: rgba(248, 250, 255, 0.88);
}

.dossier-uploaded-item > div {
  display: grid;
  gap: 3px;
}

.dossier-uploaded-item span {
  color: var(--ink-soft);
  font-size: 0.86rem;
}

.dossier-download-link {
  white-space: nowrap;
}

.dossier-option-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.dossier-option-pill {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(86, 104, 140, 0.12);
  background: rgba(248, 250, 255, 0.94);
  color: var(--ink-soft);
  font-size: 0.85rem;
  font-weight: 700;
}

.dossier-option-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.dossier-option-btn {
  min-width: 0;
  padding-inline: 14px;
}

.dossier-selected-label {
  margin: 0;
}

.dossier-footer-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
}

.dossier-footer-copy {
  display: grid;
  gap: 8px;
}

.dossier-footer-copy h3,
.dossier-footer-copy p {
  margin: 0;
}

.dossier-footer-actions {
  display: flex;
  justify-content: flex-end;
}

.dossier-account-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 14px;
}

.client-password-grid {
  margin-top: 14px;
}

.dossier-inline-notice {
  margin: 14px 0 0;
  padding: 12px 14px;
  border-radius: 16px;
  font-size: 0.95rem;
  line-height: 1.5;
}

.dossier-inline-notice.ok {
  color: var(--ok);
  background: var(--ok-soft);
}

.dossier-inline-notice.danger {
  color: var(--danger);
  background: var(--danger-soft);
}

.dossier-dev-link {
  margin-top: 12px;
}

.admin-dossier-list-item {
  width: 100%;
  text-align: left;
  border: 0;
  background: rgba(247, 250, 255, 0.78);
}

.admin-dossier-list-item.is-selected {
  background: linear-gradient(180deg, rgba(228, 236, 251, 0.96), rgba(240, 245, 255, 0.92));
  box-shadow: 0 12px 26px rgba(24, 42, 77, 0.08);
}

.admin-search-field {
  margin-bottom: 14px;
}

#admin-dossiers-list {
  max-height: calc(100vh - 320px);
  overflow: auto;
  padding-right: 6px;
}

#admin-dossier-detail {
  min-height: 520px;
}

.admin-dashboard-detail-layout {
  display: grid;
  gap: 18px;
}

.admin-summary-card {
  padding: 20px;
}

.admin-detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
  gap: 18px;
}

.admin-detail-card {
  align-self: start;
}

.admin-section-subhead {
  margin-top: 18px;
}

.admin-uploaded-document-list {
  display: grid;
  gap: 12px;
}

.admin-uploaded-document-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(86, 104, 140, 0.1);
  background: rgba(255, 255, 255, 0.88);
}

.admin-uploaded-document-meta {
  display: grid;
  gap: 4px;
}

.admin-uploaded-document-meta span {
  color: var(--muted);
  font-size: 0.84rem;
}

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

.admin-document-card .dossier-document-head {
  grid-template-columns: 1fr;
}

.dossier-estimate-disclosure {
  padding: 20px 22px;
}

.dossier-estimate-disclosure summary {
  cursor: pointer;
  list-style: none;
  color: var(--accent-deep);
  font-weight: 800;
}

.dossier-estimate-disclosure summary::-webkit-details-marker {
  display: none;
}

.dossier-estimate-body {
  display: grid;
  gap: 14px;
  margin-top: 18px;
}

.dossier-empty-copy {
  margin: 0;
}

@media (max-width: 980px) {
  .dossier-hero-card,
  .dossier-footer-card,
  .dossier-dashboard-grid,
  .admin-dashboard-grid,
  .dossier-document-head {
    grid-template-columns: 1fr;
  }

  .dossier-hero-card,
  .dossier-summary-card,
  .dossier-progress-card,
  .dossier-payment-card,
  .dossier-account-card,
  .dossier-section-card,
  .dossier-footer-card {
    padding: 20px 18px;
    border-radius: 24px;
  }

  .dossier-summary-grid {
    grid-template-columns: 1fr;
  }

  .home-actions-shell {
    max-width: none;
  }

  .dossier-card-actions,
  .dossier-account-actions,
  .dossier-footer-actions,
  .dossier-hero-actions {
    justify-content: stretch;
  }

  .dossier-card-actions > *,
  .dossier-footer-actions > *,
  .dossier-hero-actions > * {
    width: 100%;
  }

  .dossier-upload-btn {
    min-width: 0;
    width: 100%;
  }

  .dossier-option-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  #admin-dossiers-list {
    max-height: none;
    overflow: visible;
    padding-right: 0;
  }

  .admin-detail-grid,
  .admin-uploaded-document-row {
    grid-template-columns: 1fr;
  }

  .admin-uploaded-document-actions {
    justify-content: stretch;
  }

  .admin-uploaded-document-actions > * {
    width: 100%;
  }
}

@media (max-width: 480px) {
  .client-dossier-dashboard {
    gap: 14px;
  }

  .home-actions-shell {
    gap: 12px;
  }

  .dossier-hero-card,
  .dossier-summary-card,
  .dossier-progress-card,
  .dossier-payment-card,
  .dossier-account-card,
  .dossier-section-card,
  .dossier-footer-card,
  .dossier-estimate-disclosure {
    padding: 18px 14px;
    border-radius: 22px;
  }

  .dossier-document-card {
    padding: 16px 14px 14px;
    border-radius: 20px;
  }

  .dossier-option-pill {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  .dossier-estimate-financials {
    grid-template-columns: 1fr;
  }
}

/* Run 2: client dossier list and admin dashboard polish. */
.my-dossiers-section {
  display: grid;
  gap: 18px;
  margin-top: 24px;
}

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

.my-dossiers-head,
.my-dossier-item,
.admin-card,
.admin-summary-strip-card {
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 18px 48px rgba(15, 23, 42, 0.08);
}

.my-dossiers-head {
  border-radius: 24px;
  padding: 22px;
}

.my-dossiers-list {
  display: grid;
  gap: 14px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.my-dossier-item {
  display: grid;
  gap: 12px;
  border-radius: 22px;
  padding: 18px;
  transition: transform 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
}

.my-dossier-item:hover {
  transform: translateY(-1px);
  border-color: rgba(37, 99, 235, 0.28);
  box-shadow: 0 22px 56px rgba(15, 23, 42, 0.1);
}

.my-dossier-item.is-current {
  border-color: rgba(16, 185, 129, 0.42);
}

.my-dossier-item-head,
.my-dossiers-footer,
.my-dossier-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-content: space-between;
  flex-wrap: wrap;
}

.my-dossier-imm {
  font-size: 1.05rem;
  color: #0f172a;
}

.my-dossier-badge,
.admin-pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border-radius: 999px;
  padding: 7px 10px;
  font-size: 0.78rem;
  font-weight: 800;
}

.my-dossier-badge {
  background: #eef2ff;
  color: #3730a3;
}

.my-dossier-badge.is-current {
  background: #dcfce7;
  color: #166534;
}

.my-dossier-vehicle,
.my-dossier-meta {
  margin: 0;
}

.my-dossier-vehicle {
  font-weight: 800;
  color: #0f172a;
}

.my-dossier-meta {
  color: #64748b;
  font-size: 0.92rem;
}

.my-dossiers-footer {
  justify-content: flex-start;
}

.my-dossiers-footer .link-action {
  border: 0;
  background: transparent;
  color: #2563eb;
  font-weight: 800;
  cursor: pointer;
}

@media (max-width: 880px) {
  #client-access-login.dossier-dashboard-grid {
    grid-template-columns: 1fr;
  }

  #client-access-login .hero-card {
    min-height: 0;
  }
}

.admin-body-root {
  margin: 0;
  min-height: 100vh;
  background: #f8fafc;
  color: #0f172a;
}

.admin-shell {
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto 1fr;
}

.admin-topbar {
  min-height: 64px;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 0 24px;
  border-bottom: 1px solid #e2e8f0;
  background: #ffffff;
  position: sticky;
  top: 0;
  z-index: 10;
}

.admin-topbar-logo,
.admin-sidebar-title,
.admin-card-title,
.admin-detail-header-num {
  font-weight: 900;
  letter-spacing: 0;
}

.admin-topbar-logo span {
  color: #2563eb;
}

.admin-topbar-tag,
.admin-topbar-caption,
.admin-sidebar-count,
.admin-list-section-title,
.admin-card-eyebrow {
  color: #64748b;
  font-size: 0.82rem;
  font-weight: 800;
  text-transform: uppercase;
}

.admin-topbar-spacer {
  flex: 1;
}

.admin-topbar-btn,
.admin-btn {
  border: 1px solid transparent;
  border-radius: 10px;
  padding: 10px 13px;
  font-weight: 800;
  text-decoration: none;
  cursor: pointer;
}

.admin-topbar-btn,
.admin-btn-secondary {
  background: #f1f5f9;
  color: #0f172a;
}

.admin-body {
  display: grid;
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
  min-height: 0;
}

.admin-sidebar {
  border-right: 1px solid #e2e8f0;
  background: #ffffff;
  display: grid;
  grid-template-rows: auto 1fr;
  min-height: calc(100vh - 64px);
}

.admin-sidebar-head {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-bottom: 1px solid #e2e8f0;
}

.admin-sidebar-head-row,
.admin-detail-header,
.admin-card-head,
.admin-doc-row,
.admin-missing-row,
.admin-uploaded-document-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.admin-search-input,
.admin-field-control {
  width: 100%;
  border: 1px solid #cbd5e1;
  border-radius: 10px;
  padding: 11px 12px;
  font: inherit;
  background: #ffffff;
}

.admin-sidebar-list {
  overflow: auto;
  padding: 12px;
}

.admin-list-tabs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  margin-bottom: 12px;
}

.admin-list-tab {
  border: 1px solid #e2e8f0;
  border-radius: 9px;
  padding: 9px 7px;
  background: #ffffff;
  color: #475569;
  font-weight: 800;
  cursor: pointer;
}

.admin-list-tab.is-active {
  background: #0f172a;
  color: #ffffff;
}

.admin-list-section,
.admin-doc-list,
.admin-card-body,
.admin-detail-content {
  display: grid;
  gap: 12px;
}

.admin-dossier-item {
  width: 100%;
  display: grid;
  gap: 7px;
  text-align: left;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: 12px;
  background: #ffffff;
  cursor: pointer;
}

.admin-dossier-item:hover,
.admin-dossier-item.is-selected {
  border-color: #2563eb;
  box-shadow: 0 10px 28px rgba(37, 99, 235, 0.12);
}

.admin-dossier-item-num,
.admin-dossier-item-name,
.admin-doc-row-label,
.admin-missing-label {
  font-weight: 850;
}

.admin-dossier-item-contact,
.admin-empty,
.admin-empty-state-sub,
.admin-doc-row-meta,
.admin-doc-row-note,
.admin-missing-instruction,
.admin-comp-source {
  color: #64748b;
  font-size: 0.9rem;
}

.admin-dossier-item-pills,
.admin-detail-header-pills,
.admin-card-head-pills,
.admin-doc-row-actions,
.admin-replacement-form-actions,
.admin-gestor-cta-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.admin-main {
  overflow: auto;
  padding: 24px;
}

.admin-detail-header,
.admin-card,
.admin-summary-strip-card,
.admin-empty-state {
  border-radius: 18px;
  padding: 18px;
  background: #ffffff;
}

.admin-detail-header {
  border: 1px solid #e2e8f0;
  margin-bottom: 16px;
}

.admin-empty-state {
  text-align: center;
  border: 1px dashed #cbd5e1;
}

.admin-success,
.admin-error {
  border-radius: 12px;
  padding: 11px 13px;
  font-weight: 800;
}

.admin-success {
  background: #dcfce7;
  color: #166534;
}

.admin-error {
  background: #fee2e2;
  color: #991b1b;
}

.admin-pill-ok,
.admin-dot-ok {
  background: #dcfce7;
  color: #166534;
}

.admin-pill-warn,
.admin-dot-warn {
  background: #fef3c7;
  color: #92400e;
}

.admin-pill-danger,
.admin-dot-danger {
  background: #fee2e2;
  color: #991b1b;
}

.admin-pill-subtle,
.admin-dot-subtle {
  background: #f1f5f9;
  color: #475569;
}

.admin-pill-accent,
.admin-dot-accent {
  background: #dbeafe;
  color: #1d4ed8;
}

.admin-dot {
  width: 7px;
  height: 7px;
  border-radius: 999px;
}

.admin-summary-strip,
.admin-top-grid,
.admin-estimate-grid,
.admin-sim-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

.admin-summary-cell,
.admin-estimate-kpi,
.admin-sim-row {
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  padding: 12px;
  background: #f8fafc;
}

.admin-summary-cell label,
.admin-estimate-kpi span,
.admin-sim-label {
  display: block;
  color: #64748b;
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
}

.admin-msg-bar,
.admin-gestor-blocking,
.admin-replacement-form {
  border-radius: 12px;
  padding: 12px;
  background: #eff6ff;
  color: #1e3a8a;
}

.admin-gestor-blocking {
  background: #fff7ed;
  color: #9a3412;
}

.admin-doc-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.admin-doc-tab {
  border: 1px solid #e2e8f0;
  border-radius: 999px;
  padding: 9px 12px;
  background: #ffffff;
  font-weight: 800;
  cursor: pointer;
}

.admin-doc-tab.is-active {
  color: #ffffff;
  background: #0f172a;
}

.admin-doc-row,
.admin-missing-row {
  align-items: flex-start;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  padding: 13px;
  background: #ffffff;
}

.admin-doc-row-info,
.admin-missing-info {
  flex: 1;
  min-width: 0;
}

.admin-doc-row-icon {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  background: #eef2ff;
}

.admin-doc-extracted-preview,
.admin-comp-table {
  width: 100%;
}

.admin-doc-extracted-preview {
  display: grid;
  gap: 8px;
  margin: 10px 0 0;
}

.admin-doc-extracted-preview div,
.admin-estimate-line {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.admin-comp-wrap {
  overflow-x: auto;
}

.admin-comp-table {
  border-collapse: collapse;
  min-width: 760px;
}

.admin-comp-table th,
.admin-comp-table td {
  border-bottom: 1px solid #e2e8f0;
  padding: 10px;
  text-align: left;
  vertical-align: top;
}

.admin-btn-primary {
  background: #2563eb;
  color: #ffffff;
}

.admin-btn-ok {
  background: #16a34a;
  color: #ffffff;
}

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

.admin-btn-ghost {
  background: transparent;
  color: #475569;
}

.admin-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

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

  .admin-sidebar {
    min-height: auto;
    border-right: 0;
    border-bottom: 1px solid #e2e8f0;
  }

  .admin-sidebar-list {
    max-height: 380px;
  }

  .admin-main {
    padding: 16px;
  }

  .admin-doc-row,
  .admin-missing-row,
  .admin-detail-header {
    display: grid;
  }
}

/* ============================================================
   Admin dashboard visual parity final — recovered from ProImmat v3 handoff
   and kept scoped to the admin surface.
   ============================================================ */

/* ============================================================
   Admin dashboard redesign — scoped under .admin-shell
   ============================================================
   All classes prefixed with `admin-`. None of these styles bleed
   onto the wizard, the public landing or the client dashboard.
*/

.admin-body-root {
  background: var(--bg);
  height: 100vh;
  overflow: hidden;
}

.admin-body-root::before {
  display: none;
}

.admin-shell {
  display: flex;
  flex-direction: column;
  height: 100vh;
  overflow: hidden;
  background: var(--bg);
  color: var(--ink);
}

.admin-topbar {
  height: 52px;
  flex-shrink: 0;
  background: var(--bg-strong);
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  padding: 0 22px;
  gap: 14px;
  z-index: 60;
}

.admin-topbar-logo {
  font-weight: 700;
  font-size: 15px;
  letter-spacing: -0.3px;
  color: var(--ink);
}

.admin-topbar-logo span {
  color: var(--accent);
}

.admin-topbar-tag {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
  background: var(--surface-soft);
  border: 1px solid var(--line-strong);
  padding: 2px 8px;
  border-radius: 999px;
}

.admin-topbar-caption {
  font-size: 13px;
  font-weight: 500;
  color: var(--muted);
}

.admin-topbar-spacer {
  flex: 1;
}

.admin-topbar-btn {
  font-size: 13px;
  font-weight: 600;
  padding: 7px 14px;
  border-radius: 8px;
  border: 1px solid var(--line-strong);
  background: transparent;
  color: var(--ink-soft);
  cursor: pointer;
  text-decoration: none;
  transition: background 120ms, border-color 120ms;
}

.admin-topbar-btn:hover,
.admin-topbar-btn:focus-visible {
  background: var(--surface-soft);
  border-color: var(--accent);
  color: var(--accent);
}

.admin-body {
  display: flex;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

.admin-sidebar {
  width: 268px;
  flex-shrink: 0;
  background: var(--bg-strong);
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.admin-sidebar-head {
  padding: 16px 16px 12px;
  border-bottom: 1px solid var(--line);
  flex-shrink: 0;
}

.admin-sidebar-head-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}

.admin-sidebar-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
}

.admin-sidebar-count {
  font-size: 11px;
  font-weight: 700;
  color: var(--muted);
  background: var(--surface-soft);
  border: 1px solid var(--line);
  padding: 1px 8px;
  border-radius: 999px;
}

.admin-search-input {
  width: 100%;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  padding: 8px 11px;
  font: inherit;
  font-size: 13px;
  color: var(--ink);
  background: var(--bg);
  outline: none;
  transition: border-color 120ms, background 120ms;
}

.admin-search-input:focus {
  border-color: var(--accent);
  background: var(--bg-strong);
}

.admin-sidebar-list {
  flex: 1;
  overflow-y: auto;
  padding: 8px;
}

.admin-list-tabs {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
  margin-bottom: 10px;
  padding: 4px;
  border: 1px solid rgba(17, 24, 39, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.72);
}

.admin-list-tab {
  width: 100%;
  padding: 9px 10px;
  border: 1px solid transparent;
  border-radius: 11px;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  font: inherit;
  font-size: 12px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  transition: background 120ms, border-color 120ms, color 120ms;
}

.admin-list-tab:hover {
  color: var(--ink);
  background: var(--surface-soft);
}

.admin-list-tab.is-active {
  color: var(--accent-deep);
  background: rgba(38, 99, 235, 0.09);
  border-color: rgba(38, 99, 235, 0.24);
}

.admin-list-tab span {
  min-width: 24px;
  padding: 1px 7px;
  border-radius: 999px;
  background: rgba(100, 116, 139, 0.12);
  color: inherit;
  text-align: center;
}

.admin-list-empty {
  padding: 16px 12px;
  font-size: 13px;
  color: var(--muted);
}

.admin-list-section {
  margin-bottom: 14px;
  padding: 8px;
  border: 1px solid rgba(17, 24, 39, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.72);
}

.admin-list-section-title {
  margin: 0 2px 10px;
  padding: 7px 9px;
  border-radius: 999px;
  background: var(--surface-soft);
  font-size: 11px;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.admin-dossier-item {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 11px 12px;
  border-radius: 10px;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background 120ms, border-color 120ms;
  margin-bottom: 4px;
  background: transparent;
  width: 100%;
  text-align: left;
  font: inherit;
  color: inherit;
}

.admin-dossier-item:hover {
  background: var(--surface-soft);
}

.admin-dossier-item.is-selected {
  background: rgba(38, 99, 235, 0.09);
  border-color: rgba(38, 99, 235, 0.28);
}

.admin-dossier-item-num {
  font-size: 12px;
  font-weight: 700;
  font-family: ui-monospace, "Cascadia Code", "Menlo", monospace;
  letter-spacing: -0.2px;
  color: var(--ink);
}

.admin-dossier-item-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  margin-top: 2px;
}

.admin-dossier-item-contact {
  font-size: 12px;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.admin-dossier-item-pills {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  margin-top: 6px;
}

/* Main panel — scrolls vertically */

.admin-main {
  flex: 1;
  min-width: 0;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

.admin-detail-header {
  background: var(--bg-strong);
  border-bottom: 1px solid var(--line);
  padding: 14px 24px;
  display: flex;
  align-items: center;
  gap: 14px;
  position: sticky;
  top: 0;
  z-index: 40;
  flex-shrink: 0;
}

.admin-detail-header-num {
  font-size: 15px;
  font-weight: 700;
  font-family: ui-monospace, "Cascadia Code", "Menlo", monospace;
  letter-spacing: -0.3px;
}

.admin-detail-header-pills {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}

.admin-detail-header-spacer {
  flex: 1;
}

.admin-detail-header-actions {
  display: flex;
  gap: 8px;
}

.admin-detail-content {
  padding: 20px 24px 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.admin-detail-loading {
  padding: 28px 24px;
}

.admin-empty {
  padding: 18px 16px;
  font-size: 13px;
  color: var(--muted);
  margin: 0;
}

.admin-empty-state {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 20px;
  text-align: center;
  color: var(--muted);
  gap: 6px;
}

.admin-empty-state-icon {
  font-size: 30px;
  opacity: 0.45;
}

.admin-empty-state-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--ink-soft);
  margin: 0;
}

.admin-empty-state-sub {
  font-size: 13px;
  max-width: 280px;
  margin: 0;
}

.admin-error {
  padding: 12px 16px;
  margin: 0;
  font-size: 13px;
  font-weight: 500;
  color: #a02020;
  background: var(--danger-soft);
  border: 1px solid rgba(208, 68, 68, 0.25);
  border-radius: 10px;
}

.admin-error-inline {
  margin-bottom: 10px;
}

.admin-success {
  padding: 12px 16px;
  margin: 0;
  font-size: 13px;
  font-weight: 600;
  color: #076044;
  background: var(--ok-soft);
  border: 1px solid rgba(7, 96, 68, 0.22);
  border-radius: 10px;
}

/* Pills + dots */

.admin-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 600;
  padding: 2px 9px;
  border-radius: 999px;
  white-space: nowrap;
  letter-spacing: 0.01em;
}

.admin-pill-ok {
  background: var(--ok-soft);
  color: #076044;
}

.admin-pill-warn {
  background: var(--warn-soft);
  color: #8a5500;
}

.admin-pill-danger {
  background: var(--danger-soft);
  color: #a02020;
}

.admin-pill-subtle {
  background: rgba(100, 116, 139, 0.12);
  color: var(--muted);
}

.admin-pill-accent {
  background: rgba(38, 99, 235, 0.1);
  color: #1a4db8;
}

.admin-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

.admin-dot-ok {
  background: var(--ok);
}

.admin-dot-warn {
  background: var(--warn);
}

.admin-dot-danger {
  background: var(--danger);
}

.admin-dot-subtle {
  background: var(--muted);
}

.admin-dot-accent {
  background: var(--accent);
}

/* Cards */

.admin-card {
  background: var(--bg-strong);
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
}

.admin-card-head {
  padding: 14px 18px 12px;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.admin-collapsible-card > summary.admin-card-head {
  cursor: pointer;
  list-style: none;
}

.admin-collapsible-card > summary.admin-card-head::-webkit-details-marker {
  display: none;
}

.admin-collapsible-card > summary.admin-card-head::after {
  content: ">";
  color: var(--muted);
  font-size: 18px;
  font-weight: 800;
  transition: transform 200ms ease;
}

.admin-collapsible-card[open] > summary.admin-card-head::after {
  transform: rotate(90deg);
}

.admin-collapsible-card:not([open]) > summary.admin-card-head {
  border-bottom: none;
}

.admin-collapsible-body {
  display: grid;
  gap: 12px;
}

.admin-card-eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0 0 2px;
}

.admin-card-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  margin: 0;
}

.admin-card-body {
  padding: 14px 18px 16px;
}

.admin-card-head-pills {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

/* Summary strip */

.admin-summary-strip-card {
  background: var(--bg-strong);
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
}

.admin-summary-strip {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.admin-summary-cell {
  padding: 12px 14px;
  border-right: 1px solid var(--line);
}

.admin-summary-cell:last-child {
  border-right: none;
}

.admin-summary-cell-wide {
  grid-column: span 1;
}

.admin-summary-cell label {
  display: block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 4px;
}

.admin-summary-cell strong {
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
  overflow-wrap: anywhere;
}

.admin-summary-hint {
  display: block;
  margin-top: 4px;
  font-size: 11px;
  font-weight: 600;
  color: var(--accent-deep);
  overflow-wrap: anywhere;
}

.admin-summary-emph-ok {
  color: #076044;
}

.admin-summary-emph-danger {
  color: #a02020;
}

.admin-msg-bar {
  padding: 11px 18px;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-soft);
  background: var(--surface-soft);
  border-top: 1px solid var(--line);
  display: flex;
  align-items: center;
  gap: 8px;
}

.admin-msg-bar-subtle {
  background: rgba(38, 99, 235, 0.06);
  color: var(--accent-deep);
}

.admin-msg-arrow {
  color: var(--muted);
}

/* Top grid (simulation + gestor) */

.admin-top-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 16px;
}

.admin-sim-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 24px;
}

.admin-sim-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  padding: 9px 0;
  border-bottom: 1px solid var(--line);
}

.admin-sim-row:last-child,
.admin-sim-grid > .admin-sim-row:nth-last-child(-n + 2) {
  border-bottom: none;
}

.admin-sim-label {
  font-size: 12px;
  color: var(--muted);
  white-space: nowrap;
}

.admin-sim-value {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  text-align: right;
  overflow-wrap: anywhere;
}

/* Admin estimate */

.admin-estimate-card {
  overflow: hidden;
}

.admin-estimate-summary {
  list-style: none;
  cursor: pointer;
  padding: 14px 18px 12px;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

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

.admin-estimate-toggle {
  font-size: 11px;
  font-weight: 700;
  color: var(--muted);
}

.admin-estimate-body {
  display: grid;
  gap: 14px;
}

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

.admin-estimate-kpi {
  padding: 11px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface-soft);
}

.admin-estimate-kpi span,
.admin-estimate-line small {
  display: block;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--muted);
}

.admin-estimate-kpi strong {
  display: block;
  margin-top: 3px;
  font-size: 15px;
  color: var(--ink);
}

.admin-estimate-lines {
  display: grid;
  gap: 6px;
}

.admin-estimate-line {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 9px 0;
  border-top: 1px solid var(--line);
}

.admin-estimate-line span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.admin-estimate-line strong {
  white-space: nowrap;
}

/* Gestor card */

.admin-gestor-body {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.admin-gestor-head {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.admin-gestor-avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: rgba(38, 99, 235, 0.1);
  color: #1a4db8;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 14px;
  flex-shrink: 0;
}

.admin-gestor-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.admin-gestor-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
}

.admin-gestor-meta-row {
  font-size: 12px;
  color: var(--muted);
  overflow-wrap: anywhere;
}

.admin-gestor-alternates {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.admin-gestor-cta-row {
  display: flex;
  gap: 8px;
}

.admin-gestor-blocked {
  font-size: 12px;
  color: var(--muted);
  margin: 0;
}

.admin-gestor-blocking {
  border: 1px solid rgba(220, 38, 38, 0.2);
  background: rgba(254, 242, 242, 0.9);
  color: #7f1d1d;
  border-radius: 14px;
  padding: 12px;
  display: grid;
  gap: 6px;
  font-size: 12px;
}

.admin-gestor-blocking strong {
  color: #991b1b;
}

.admin-gestor-blocking ul {
  list-style: none;
  display: grid;
  gap: 6px;
  padding: 0;
  margin: 2px 0 0;
}

.admin-gestor-blocking li {
  display: grid;
  gap: 2px;
  padding-left: 10px;
  border-left: 2px solid rgba(220, 38, 38, 0.35);
}

.admin-gestor-blocking small {
  color: #7f1d1d;
  line-height: 1.4;
}

.admin-gestor-warning {
  border-color: rgba(217, 119, 6, 0.28);
  background: rgba(255, 251, 235, 0.92);
  color: #78350f;
}

.admin-gestor-warning strong,
.admin-gestor-warning small {
  color: #92400e;
}

.admin-gestor-warning li {
  border-left-color: rgba(217, 119, 6, 0.4);
}

/* Documents — tabs */

.admin-doc-tabs {
  display: flex;
  gap: 0;
  padding: 0 16px;
  border-bottom: 1px solid var(--line);
  background: var(--surface-soft);
}

.admin-doc-tab {
  padding: 10px 14px;
  font: inherit;
  font-size: 13px;
  font-weight: 600;
  color: var(--muted);
  cursor: pointer;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  background: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: color 120ms, border-color 120ms;
}

.admin-doc-tab:hover {
  color: var(--ink);
}

.admin-doc-tab.is-active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

.admin-doc-tab-count {
  font-size: 11px;
  font-weight: 700;
  padding: 1px 7px;
  border-radius: 999px;
  background: rgba(100, 116, 139, 0.12);
  color: var(--muted);
}

.admin-doc-tab.is-active .admin-doc-tab-count {
  background: rgba(38, 99, 235, 0.1);
  color: #1a4db8;
}

.admin-doc-tab-count-danger {
  background: var(--danger-soft);
  color: #a02020;
}

.admin-doc-tab-count-warn {
  background: var(--warn-soft);
  color: #8a5500;
}

/* Documents — rows */

.admin-doc-list {
  display: flex;
  flex-direction: column;
}

.admin-doc-row {
  padding: 12px 18px;
  border-bottom: 1px solid var(--line);
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: flex-start;
  transition: background 120ms;
}

.admin-doc-row:last-child {
  border-bottom: none;
}

.admin-doc-row:hover {
  background: var(--surface-soft);
}

.admin-doc-row-icon {
  width: 36px;
  height: 36px;
  border-radius: 9px;
  background: var(--surface-soft);
  border: 1px solid var(--line);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 14px;
  color: var(--muted);
}

.admin-doc-row-info {
  min-width: 0;
}

.admin-doc-row-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
  margin: 0 0 3px;
}

.admin-doc-row-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 12px;
  font-size: 12px;
  color: var(--muted);
}

.admin-doc-row-note {
  margin: 6px 0 0;
  font-size: 12px;
  color: var(--muted);
}

.admin-doc-row-note-danger {
  color: #a02020;
  font-weight: 600;
}

.admin-doc-row-note-warn {
  color: #8a5a00;
  font-weight: 600;
}

.admin-doc-extracted-preview {
  margin: 8px 0 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 6px 10px;
  font-size: 12px;
}

.admin-doc-analysis-disclosure {
  margin: 8px 0 0;
  border: 1px solid rgba(37, 99, 235, 0.18);
  border-radius: 10px;
  background: rgba(37, 99, 235, 0.04);
  padding: 8px 10px;
}

.admin-doc-analysis-disclosure > summary {
  cursor: pointer;
  color: #1d4ed8;
  font-size: 12px;
  font-weight: 700;
}

.admin-doc-analysis-disclosure[open] > summary {
  margin-bottom: 6px;
}

.admin-doc-analysis-disclosure .admin-doc-extracted-preview {
  margin-top: 0;
}

.admin-doc-extracted-preview div {
  min-width: 0;
}

.admin-doc-extracted-preview dt {
  margin: 0;
  color: var(--muted);
}

.admin-doc-extracted-preview dd {
  margin: 1px 0 0;
  color: var(--ink);
  font-weight: 650;
  overflow-wrap: anywhere;
}

.admin-doc-extracted-note {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 500;
  overflow-wrap: anywhere;
}

.admin-doc-extracted-note-warn {
  color: #8a5a00;
  font-weight: 650;
}

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

/* Replacement form */

.admin-replacement-form {
  grid-column: 1 / -1;
  margin-top: 12px;
  padding: 14px 16px;
  background: var(--surface-soft);
  border: 1px solid var(--line);
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.admin-replacement-form-title {
  font-size: 12px;
  font-weight: 700;
  color: var(--ink);
  margin: 0;
}

.admin-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.admin-field-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}

.admin-field-control {
  width: 100%;
  font: inherit;
  font-size: 13px;
  padding: 8px 11px;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  background: var(--bg-strong);
  color: var(--ink);
  outline: none;
  transition: border-color 120ms;
}

.admin-field-control:focus {
  border-color: var(--accent);
}

.admin-replacement-form-actions {
  display: flex;
  gap: 8px;
}

/* Missing rows */

.admin-missing-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 11px 18px;
  border-bottom: 1px solid var(--line);
}

.admin-missing-row:last-child {
  border-bottom: none;
}

.admin-missing-info {
  min-width: 0;
}

.admin-missing-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 2px;
}

.admin-missing-instruction {
  font-size: 12px;
  color: var(--muted);
  margin: 0;
}

.admin-missing-updated {
  font-size: 11px;
  color: var(--muted);
  white-space: nowrap;
}

/* Comparator table */

.admin-comp-wrap {
  overflow-x: auto;
}

.admin-comp-table {
  width: 100%;
  min-width: 720px;
  border-collapse: collapse;
}

.admin-comp-table th {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 10px 14px;
  text-align: left;
  border-bottom: 1px solid var(--line-strong);
  background: var(--surface-soft);
  white-space: nowrap;
}

.admin-comp-table td {
  padding: 11px 14px;
  font-size: 13px;
  border-bottom: 1px solid var(--line);
  vertical-align: middle;
}

.admin-comp-table tr:last-child td {
  border-bottom: none;
}

.admin-comp-row-ok td:first-child {
  border-left: 3px solid var(--ok);
}

.admin-comp-row-warn td:first-child {
  border-left: 3px solid var(--warn);
}

.admin-comp-row-danger td:first-child {
  border-left: 3px solid var(--danger);
}

.admin-comp-row-subtle td:first-child {
  border-left: 3px solid var(--line-strong);
}

.admin-comp-field {
  font-weight: 700;
  color: var(--ink);
}

.admin-comp-recommended {
  font-size: 12px;
  font-weight: 700;
  color: var(--ink);
}

.admin-comp-source {
  font-size: 11px;
  color: var(--muted);
  margin-top: 2px;
}

.admin-comp-value {
  font-weight: 500;
  color: var(--ink-soft);
}

.admin-comp-value-conflict {
  color: #a02020;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.admin-comp-value-awaiting {
  color: var(--muted);
  font-style: italic;
  font-weight: 400;
  font-size: 12px;
}

/* Buttons (admin-scoped — independent from public .btn) */

.admin-btn {
  font: inherit;
  font-size: 13px;
  font-weight: 600;
  padding: 7px 14px;
  border-radius: 8px;
  border: 1px solid transparent;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: background 120ms, color 120ms, border-color 120ms, box-shadow 120ms;
  text-decoration: none;
  min-height: 32px;
  box-shadow: none;
}

.admin-btn:hover {
  transform: none;
}

.admin-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.admin-btn-sm {
  padding: 5px 11px;
  font-size: 12px;
  min-height: 28px;
}

.admin-btn-primary {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

.admin-btn-primary:hover:not(:disabled),
.admin-btn-primary:focus-visible:not(:disabled) {
  background: #1a4db8;
  border-color: #1a4db8;
  color: #fff;
}

.admin-btn-secondary {
  background: var(--bg-strong);
  color: var(--ink);
  border-color: var(--line-strong);
}

.admin-btn-secondary:hover:not(:disabled),
.admin-btn-secondary:focus-visible:not(:disabled) {
  background: var(--surface-soft);
  border-color: var(--accent);
  color: var(--accent);
}

.admin-btn-ghost {
  background: transparent;
  color: var(--muted);
  border-color: transparent;
}

.admin-btn-ghost:hover:not(:disabled),
.admin-btn-ghost:focus-visible:not(:disabled) {
  background: var(--surface-soft);
  color: var(--ink);
}

.admin-btn-ok {
  background: var(--ok);
  color: #fff;
  border-color: var(--ok);
}

.admin-btn-ok:hover:not(:disabled),
.admin-btn-ok:focus-visible:not(:disabled) {
  background: #076044;
  border-color: #076044;
  color: #fff;
}

.admin-btn-danger {
  background: var(--danger-soft);
  color: #a02020;
  border-color: rgba(208, 68, 68, 0.28);
}

.admin-btn-danger:hover:not(:disabled),
.admin-btn-danger:focus-visible:not(:disabled) {
  background: rgba(208, 68, 68, 0.18);
  border-color: rgba(208, 68, 68, 0.45);
  color: #a02020;
}

/* Responsive */

@media (max-width: 1280px) {
  .admin-sidebar {
    width: 240px;
  }

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

  .admin-summary-cell {
    border-bottom: 1px solid var(--line);
  }

  .admin-summary-cell:nth-child(3n) {
    border-right: none;
  }

  .admin-top-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .admin-sim-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .admin-doc-row {
    grid-template-columns: 32px minmax(0, 1fr);
  }

  .admin-doc-row-actions {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
}

@media (max-width: 768px) {
  .admin-shell {
    height: auto;
    min-height: 100vh;
  }

  .admin-body-root {
    height: auto;
    overflow: auto;
  }

  .admin-body {
    flex-direction: column;
    overflow: visible;
  }

  .admin-sidebar {
    width: 100%;
    max-height: 60vh;
    border-right: none;
    border-bottom: 1px solid var(--line);
  }

  .admin-sidebar-list,
  #admin-dossiers-list {
    max-height: 50vh;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    padding-right: 4px;
  }

  .admin-empty-state {
    min-height: 0;
    padding: 28px 18px;
  }

  .admin-main {
    overflow: visible;
  }

  .admin-summary-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-summary-cell {
    border-right: 1px solid var(--line);
  }

  .admin-summary-cell:nth-child(2n) {
    border-right: none;
  }

  .admin-detail-header {
    flex-wrap: wrap;
    position: static;
  }

  .admin-detail-header-actions {
    width: 100%;
  }

  .admin-detail-header-actions > .admin-btn {
    flex: 1;
    justify-content: center;
  }

  .admin-doc-row-actions > * {
    flex: 1;
    justify-content: center;
  }
}

@media (max-width: 520px) {
  .admin-detail-content {
    padding: 16px 14px 24px;
  }

  .admin-summary-strip {
    grid-template-columns: 1fr;
  }

  .admin-summary-cell {
    border-right: none;
    border-bottom: 1px solid var(--line);
  }

  .admin-summary-cell:last-child {
    border-bottom: none;
  }
}

/* Client dashboard redesign V2 (cd-*) recovered from the historical pre-prod branch. */
.cd-page {
  display: flex;
  flex-direction: column;
  gap: 16px;
  max-width: 720px;
  margin: 0 auto;
  width: 100%;
}

.cd-card {
  background: var(--surface-strong, #fff);
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 8px 24px rgba(15, 23, 42, 0.04);
}

.cd-card-body {
  padding: 16px 20px 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.cd-section-head {
  padding: 16px 20px 14px;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.cd-pending-disclosure > summary {
  cursor: pointer;
  list-style: none;
}

.cd-pending-disclosure > summary::-webkit-details-marker {
  display: none;
}

.cd-validated-disclosure > summary {
  cursor: pointer;
  list-style: none;
}

.cd-validated-disclosure > summary::-webkit-details-marker {
  display: none;
}

.cd-validated-disclosure > summary::after {
  content: ">";
  color: var(--muted);
  font-size: 18px;
  font-weight: 700;
  transition: transform 200ms ease;
}

.cd-validated-disclosure[open] > summary::after {
  transform: rotate(90deg);
}

.cd-validated-disclosure:not([open]) > summary {
  border-bottom: none;
}

.cd-section-head-copy {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.cd-section-eyebrow {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0;
}

.cd-section-title {
  font-size: 15.5px;
  font-weight: 700;
  margin: 0;
  color: var(--ink);
}

.cd-section-head-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13.5px;
  font-weight: 700;
  color: var(--ink);
}

.cd-section-head-icon {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--danger);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 13px;
  flex-shrink: 0;
}

.cd-section-helper {
  margin: 12px 20px 0;
  padding: 10px 12px;
  background: var(--warn-soft);
  color: #6b4400;
  border-radius: 10px;
  font-size: 12.5px;
  line-height: 1.45;
}

.cd-section-danger {
  border-color: rgba(208, 68, 68, 0.32);
  box-shadow: 0 1px 2px rgba(208, 68, 68, 0.04), 0 8px 24px rgba(208, 68, 68, 0.06);
}

.cd-section-head-danger {
  background: var(--danger-soft);
  color: var(--danger);
}

.cd-empty {
  margin: 14px 20px 18px;
  padding: 12px 14px;
  background: var(--ok-soft);
  color: #086041;
  border-radius: 10px;
  font-size: 13px;
}

.cd-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11.5px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 999px;
  white-space: nowrap;
  border: 1px solid transparent;
}

.cd-pill-accent {
  background: var(--accent-soft);
  color: var(--accent-deep);
}

.cd-pill-ok {
  background: var(--ok-soft);
  color: #07634a;
}

.cd-pill-warn {
  background: var(--warn-soft);
  color: #7a4d00;
}

.cd-pill-danger {
  background: var(--danger-soft);
  color: #99262d;
}

.cd-hero-card {
  background: linear-gradient(135deg, #0f1f5c 0%, #1e40af 60%, #2663eb 100%);
  color: #fff;
  border: none;
  padding: 26px 28px 24px;
}

.cd-hero-eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.78;
  margin-bottom: 8px;
}

.cd-hero-title {
  font-size: 22px;
  font-weight: 700;
  margin: 0 0 12px;
  color: #fff;
}

.cd-hero-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 14px;
}

.cd-hero-chip {
  font-size: 12px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.18);
  color: rgba(255, 255, 255, 0.95);
}

.cd-hero-chip-status {
  background: rgba(255, 255, 255, 0.95);
  color: var(--accent-deep);
}

.cd-hero-next {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.13);
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.18);
}

.cd-hero-next-icon {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.22);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 700;
  flex-shrink: 0;
}

.cd-hero-next-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.92);
  line-height: 1.45;
}

.cd-hero-next-text strong {
  color: #fff;
  font-weight: 700;
}

.cd-stepper-card {
  padding: 14px 18px;
}

.cd-stepper {
  display: flex;
  gap: 8px;
}

.cd-step {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  min-width: 0;
}

.cd-step-bar {
  height: 4px;
  border-radius: 2px;
  width: 100%;
  background: var(--line-strong);
}

.cd-step.done .cd-step-bar {
  background: var(--ok);
}

.cd-step.current .cd-step-bar {
  background: var(--accent);
}

.cd-step-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
  text-align: center;
  line-height: 1.3;
}

.cd-step.done .cd-step-label {
  color: #07634a;
}

.cd-step.current .cd-step-label {
  color: var(--accent-deep);
  font-weight: 700;
}

.cd-doc-list {
  display: flex;
  flex-direction: column;
}

.cd-doc-list .dossier-document-card.cd-doc-card {
  border: none;
  border-bottom: 1px solid var(--line);
  border-radius: 0;
  padding: 16px 20px;
  margin: 0;
  background: transparent;
  display: flex;
  align-items: flex-start;
  gap: 14px;
  flex-wrap: wrap;
  box-shadow: none;
}

.cd-doc-list .dossier-document-card.cd-doc-card:last-child {
  border-bottom: none;
}

.cd-doc-list .dossier-document-card.cd-doc-card.cd-doc-card-stack {
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
}

.cd-doc-card-row {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  width: 100%;
}

.cd-doc-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 17px;
  font-weight: 700;
  background: rgba(100, 116, 139, 0.1);
  color: var(--muted);
}

.cd-doc-icon-pending {
  background: var(--accent-soft);
  color: var(--accent);
}

.cd-doc-icon-warn {
  background: var(--warn-soft);
  color: var(--warn);
}

.cd-doc-icon-ok {
  background: var(--ok-soft);
  color: var(--ok);
}

.cd-doc-icon-danger {
  background: var(--danger-soft);
  color: var(--danger);
}

.cd-doc-icon-subtle {
  background: rgba(100, 116, 139, 0.1);
  color: var(--muted);
}

.cd-doc-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.cd-doc-label {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.35;
}

.cd-doc-sub {
  font-size: 12.5px;
  color: var(--muted);
  line-height: 1.45;
}

.cd-doc-status-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}

.cd-doc-actions {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  flex-shrink: 0;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.cd-doc-actions .dossier-upload-btn,
.cd-doc-actions .cd-btn.dossier-upload-btn {
  min-width: 200px;
  width: auto;
  justify-content: center;
  align-self: center;
  height: 36px;
}

.dossier-option-actions {
  display: grid;
  gap: 10px;
}

.dossier-option-stack {
  display: grid;
  gap: 10px;
}

.dossier-option-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 18px;
  border: 1px solid rgba(86, 104, 140, 0.1);
  background: rgba(255, 255, 255, 0.66);
}

.dossier-option-row span {
  color: var(--ink-soft);
  font-weight: 760;
}

.dossier-option-actions .dossier-upload-btn.dossier-option-btn,
.dossier-option-actions .cd-btn.dossier-upload-btn.dossier-option-btn {
  min-width: 0;
  width: 100%;
  height: 36px;
  justify-content: center;
}

.dossier-local-draft-pill {
  justify-self: end;
}

.dossier-upload-preview-list {
  display: grid;
  gap: 10px;
}

.dossier-upload-preview {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 10px;
  border-radius: 18px;
  border: 1px solid rgba(86, 104, 140, 0.1);
  background: rgba(248, 250, 255, 0.86);
}

.dossier-upload-preview.is-local-draft {
  border-color: rgba(35, 79, 208, 0.24);
  background: rgba(35, 79, 208, 0.06);
}

.dossier-upload-thumb {
  display: grid;
  place-items: center;
  width: 56px;
  height: 48px;
  overflow: hidden;
  border-radius: 14px;
  background: rgba(35, 79, 208, 0.08);
  color: var(--accent-deep);
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.dossier-upload-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.dossier-upload-preview-copy {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.dossier-upload-preview-copy strong {
  overflow: hidden;
  color: var(--ink);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dossier-upload-preview-copy span {
  color: var(--muted);
  font-size: 0.84rem;
}

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

.dossier-local-upload-state {
  display: grid;
  gap: 8px;
}

.dossier-preview-action-btn {
  min-width: 0;
}

.dossier-upload-error {
  margin: 0;
}

.dossier-preview-link {
  white-space: nowrap;
}

.dossier-selected-label {
  margin: 0;
}

.cd-replacement-alert {
  width: 100%;
  margin-top: 12px;
  padding: 12px 14px;
  background: var(--danger-soft);
  border: 1px solid rgba(208, 68, 68, 0.22);
  border-radius: 10px;
}

.cd-replacement-alert-title {
  font-size: 12.5px;
  font-weight: 700;
  color: #99262d;
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.cd-replacement-alert-title span[aria-hidden="true"] {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--danger);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 800;
}

.cd-replacement-alert-text,
.cd-replacement-alert-comment {
  font-size: 12.5px;
  color: var(--ink-soft);
  line-height: 1.5;
}

.cd-replacement-alert-comment {
  margin-top: 4px;
}

.cd-btn {
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  padding: 8px 14px;
  border-radius: 8px;
  border: 1px solid transparent;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  white-space: nowrap;
}

.cd-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.cd-btn-sm {
  padding: 7px 12px;
  font-size: 12.5px;
}

.cd-btn-primary {
  background: var(--accent);
  color: #fff;
}

.cd-btn-primary:hover:not(:disabled) {
  background: var(--accent-deep);
}

.cd-btn-secondary {
  background: #fff;
  color: var(--ink);
  border-color: var(--line-strong);
}

.cd-btn-secondary:hover:not(:disabled) {
  background: var(--surface-soft);
}

.cd-btn-ghost {
  background: transparent;
  color: var(--muted);
  border-color: transparent;
}

.cd-btn-ghost:hover:not(:disabled) {
  background: var(--surface-soft);
  color: var(--ink);
}

.cd-btn-danger-outline {
  background: #fff;
  color: #99262d;
  border-color: rgba(208, 68, 68, 0.45);
}

.cd-btn-danger-outline:hover:not(:disabled) {
  background: var(--danger-soft);
}

.cd-disclosure {
  padding: 0;
}

.cd-disclosure > .cd-disclosure-summary {
  list-style: none;
  cursor: pointer;
  padding: 16px 20px;
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cd-disclosure > .cd-disclosure-summary::-webkit-details-marker {
  display: none;
}

.cd-disclosure > .cd-disclosure-summary::after {
  content: ">";
  font-size: 19px;
  color: var(--muted);
  transition: transform 200ms ease;
  margin-left: 12px;
  font-weight: 600;
}

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

.cd-disclosure-body {
  padding: 0 20px 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.cd-disclosure-helper {
  font-size: 13px;
  color: var(--muted);
  margin: 0;
  line-height: 1.5;
}

.cd-estimate-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
  background: var(--surface-soft);
}

.cd-vehicle-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 10px;
}

.cd-vehicle-cell {
  min-width: 0;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface-soft);
}

.cd-vehicle-cell label {
  display: block;
  margin-bottom: 4px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.cd-vehicle-cell strong {
  display: block;
  color: var(--ink);
  overflow-wrap: anywhere;
}

.cd-estimate-cell {
  padding: 12px 14px;
  border-right: 1px solid var(--line);
}

.cd-estimate-cell:last-child {
  border-right: none;
}

.cd-estimate-cell label,
.cd-payment-cell label,
.cd-account-field label {
  display: block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 4px;
}

.cd-estimate-cell strong,
.cd-payment-cell strong {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
}

.cd-estimate-note {
  font-size: 12.5px;
  color: var(--muted);
  margin: 0;
  line-height: 1.5;
}

.cd-final-quote-card {
  display: grid;
  gap: 14px;
}

.cd-final-quote-totals {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
  background: var(--surface-soft);
}

.cd-final-quote-totals div {
  min-width: 0;
  padding: 14px;
  border-right: 1px solid var(--line);
}

.cd-final-quote-totals div:last-child {
  border-right: none;
}

.cd-final-quote-totals span {
  display: block;
  margin-bottom: 4px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.cd-final-quote-totals strong {
  color: var(--ink);
  font-size: 15px;
  font-weight: 800;
}

.cd-final-quote-lines {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.cd-final-quote-lines li {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 11px 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

.cd-final-quote-lines span {
  min-width: 0;
  color: var(--ink);
  font-weight: 650;
  overflow-wrap: anywhere;
}

.cd-final-quote-lines strong {
  color: var(--ink);
  font-weight: 800;
}

.cd-final-quote-accept {
  width: fit-content;
}

.cd-final-quote-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.cd-final-quote-payment {
  width: fit-content;
}

.cd-payment-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
  background: var(--surface-soft);
}

.cd-payment-cell {
  padding: 14px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.cd-payment-cell:nth-child(2n) {
  border-right: none;
}

.cd-payment-cell:nth-last-child(-n + 2) {
  border-bottom: none;
}

.cd-muted {
  font-size: 13px;
  color: var(--muted);
  margin: 0;
  line-height: 1.5;
}

.cd-account-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.cd-account-field {
  padding: 12px 14px;
  background: var(--surface-soft);
  border: 1px solid var(--line);
  border-radius: 10px;
}

.cd-account-field strong {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--ink);
  font-family: 'DM Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
}

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

.cd-account-password {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.cd-multi-dossier {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: var(--accent-soft);
  border: 1px solid rgba(38, 99, 235, 0.18);
  border-radius: 10px;
}

.cd-multi-dossier-icon {
  flex-shrink: 0;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  color: var(--accent-deep);
}

.cd-multi-dossier-text {
  flex: 1;
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.45;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.cd-multi-dossier-text strong {
  color: var(--ink);
  font-weight: 700;
}

.cd-supplemental-stack {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.cd-help-footer {
  text-align: center;
  padding: 18px 12px 24px;
  font-size: 13px;
  color: var(--muted);
}

.cd-help-footer a {
  color: var(--accent);
  font-weight: 600;
  text-decoration: none;
}

.cd-help-footer a:hover {
  text-decoration: underline;
}

.cd-doc-card .badge.subtle {
  background: rgba(100, 116, 139, 0.1);
  color: var(--muted);
}

.cd-doc-card .badge.warn {
  background: var(--warn-soft);
  color: #7a4d00;
}

.cd-doc-card .badge.ok {
  background: var(--ok-soft);
  color: #07634a;
}

.cd-doc-card .badge.danger {
  background: var(--danger-soft);
  color: #99262d;
}

@media (max-width: 600px) {
  .cd-page {
    gap: 12px;
    padding: 0;
  }

  .cd-hero-card {
    padding: 20px 18px 18px;
  }

  .cd-hero-title {
    font-size: 19px;
  }

  .cd-stepper {
    flex-wrap: wrap;
    gap: 6px;
  }

  .cd-step {
    min-width: 60px;
    flex: 1 1 calc(33.333% - 6px);
  }

  .cd-section-head {
    padding: 14px 16px 12px;
    flex-wrap: wrap;
  }

  .cd-section-helper {
    margin: 10px 16px 0;
  }

  .cd-doc-list .dossier-document-card.cd-doc-card {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    padding: 14px 16px;
  }

  .cd-doc-card-row {
    align-items: flex-start;
  }

  .cd-doc-actions {
    width: 100%;
    justify-content: stretch;
  }

  .cd-doc-actions .cd-btn,
  .cd-doc-actions button.dossier-upload-btn {
    flex: 1;
    justify-content: center;
  }

  .dossier-option-row,
  .dossier-upload-preview {
    grid-template-columns: 1fr;
  }

  .dossier-upload-preview-actions {
    justify-content: stretch;
  }

  .dossier-upload-preview-actions > * {
    width: 100%;
    text-align: center;
  }

  .cd-estimate-grid {
    grid-template-columns: 1fr 1fr;
  }

  .cd-final-quote-totals,
  .cd-final-quote-lines li {
    grid-template-columns: 1fr;
  }

  .cd-final-quote-totals div,
  .cd-final-quote-totals div:last-child {
    border-right: none;
  }

  .cd-final-quote-totals div:not(:last-child) {
    border-bottom: 1px solid var(--line);
  }

  .cd-final-quote-accept,
  .cd-final-quote-payment {
    width: 100%;
    justify-content: center;
  }

  .cd-estimate-cell:nth-child(2) {
    border-right: none;
  }

  .cd-estimate-cell:nth-child(-n + 2) {
    border-bottom: 1px solid var(--line);
  }

  .cd-account-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .cd-account-actions .cd-btn {
    width: 100%;
    justify-content: center;
  }

  .cd-multi-dossier {
    flex-wrap: wrap;
  }

  .cd-multi-dossier .cd-btn {
    width: 100%;
    justify-content: center;
  }

  .cd-disclosure-body {
    padding: 0 16px 16px;
  }
}

/* ============================================================
   FASTIMMAT V4 SKIN — fidèle copie V4 Claude Design
   Activé via body.v4-skin. Calque visuel sur la structure
   existante : tokens, palette, typo, layout 2 colonnes, cards
   arrondies, accordéons résultat, bottom CTA mobile, WhatsApp.
   Aucun calcul ni logique métier touché.
   ============================================================ */

:root {
  --v3-navy:        #0A1B45;
  --v3-navy-2:      #18306E;
  --v3-ink:         #1E2A56;
  --v3-ink-2:       #3B4878;
  --v3-ink-3:       #6B76A0;
  --v3-ink-4:       #A4ABCB;
  --v3-blue:        #2851F0;
  --v3-blue-strong: #1E3FCC;
  --v3-blue-soft:   #DDE6FF;
  --v3-blue-tint:   #EEF2FF;
  --v3-blue-glow:   rgba(40, 81, 240, 0.32);
  --v3-bg:          #F2F5FF;
  --v3-bg-2:        #E7EDFE;
  --v3-surface:     #FFFFFF;
  --v3-line:        #E0E6F5;
  --v3-line-2:      #ECF0FB;
  --v3-display:     "Instrument Serif", Georgia, serif;
  --v3-sans:        "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --v3-mono:        "JetBrains Mono", ui-monospace, Menlo, monospace;
  --v3-pill:        999px;
  --v3-shadow-card: 0 1px 0 rgba(10, 27, 69, 0.04), 0 20px 40px -28px rgba(10, 27, 69, 0.16);
  --v3-shadow-cta:  0 12px 28px -10px rgba(40, 81, 240, 0.55), 0 2px 0 rgba(30, 63, 204, 0.2) inset;
}

@import url("https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Manrope:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;700&display=swap");

body.v4-skin {
  font-family: var(--v3-sans);
  color: var(--v3-ink);
  background:
    radial-gradient(80% 60% at 80% -10%, rgba(40, 81, 240, 0.10), transparent 65%),
    radial-gradient(60% 50% at 0% 100%, rgba(40, 81, 240, 0.06), transparent 65%),
    linear-gradient(180deg, var(--v3-bg) 0%, var(--v3-bg-2) 100%);
  -webkit-font-smoothing: antialiased;
}

body.v4-skin::before { display: none; }

/* ---- shell : 2 colonnes éprouvées 1.5fr / 1fr ---- */
body.v4-skin .shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: 28px;
  max-width: 1280px;
  margin: 0 auto;
  padding: 28px 32px 56px;
}

body.v4-skin .sidebar {
  order: 2;
  position: sticky;
  top: 24px;
  height: auto;
  max-height: calc(100vh - 48px);
}

body.v4-skin .sidebar-shell {
  background: var(--v3-surface);
  border: 1px solid var(--v3-line);
  border-radius: 22px;
  box-shadow: var(--v3-shadow-card);
  padding: 22px;
  backdrop-filter: none;
}

body.v4-skin .sidebar-brand h1 {
  font-family: var(--v3-display);
  font-weight: 400;
  letter-spacing: -0.01em;
  font-size: 22px;
  line-height: 1.15;
  color: var(--v3-navy);
}

body.v4-skin .sidebar-brand .lede {
  font-size: 13px;
  color: var(--v3-ink-3);
  line-height: 1.55;
}

body.v4-skin .sidebar-card {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 14px 0 0;
  border-top: 1px solid var(--v3-line);
  margin-top: 14px;
}

body.v4-skin .sidebar-card:first-of-type {
  border-top: 0;
  margin-top: 12px;
  padding-top: 0;
}

body.v4-skin .eyebrow,
body.v4-skin .panel-step-label {
  font-family: var(--v3-sans);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--v3-blue);
}

body.v4-skin .eyebrow.muted,
body.v4-skin .card-kicker .eyebrow {
  color: var(--v3-ink-3);
}

body.v4-skin #quote-meta {
  font-family: var(--v3-mono);
  font-size: 13px;
  font-weight: 600;
  color: var(--v3-navy);
}

body.v4-skin .stepper {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

body.v4-skin .step-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid transparent;
  background: transparent;
  text-align: left;
  cursor: pointer;
  font-size: 13px;
  color: var(--v3-ink-3);
}

body.v4-skin .step-item .step-count {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: var(--v3-bg);
  border: 1px solid var(--v3-line);
  font-family: var(--v3-mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--v3-ink-3);
}

body.v4-skin .step-item strong {
  font-weight: 600;
  font-size: 13.5px;
  color: inherit;
}

body.v4-skin .step-item.active {
  background: var(--v3-blue-tint);
  color: var(--v3-navy);
}

body.v4-skin .step-item.active .step-count {
  background: var(--v3-blue);
  border-color: var(--v3-blue);
  color: #fff;
  box-shadow: 0 0 0 4px var(--v3-blue-tint);
}

body.v4-skin .step-item.done {
  color: var(--v3-ink-2);
}

body.v4-skin .step-item.done .step-count {
  background: var(--v3-blue-tint);
  border-color: var(--v3-blue-soft);
  color: var(--v3-blue);
}

/* ---- toolbar : nav haut style landing ---- */
body.v4-skin .content {
  gap: 20px;
}

body.v4-skin.result-stage-active .content {
  gap: 8px;
}

body.v4-skin.result-stage-active #client-flow-shell {
  gap: 0;
}

body.v4-skin.result-stage-active #client-stage-actions {
  display: none;
}

body.v4-skin.result-stage-active #results-shell {
  gap: 12px;
}

body.v4-skin .toolbar {
  background: transparent;
  border: 0;
  box-shadow: none;
  backdrop-filter: none;
  padding: 0;
}

body.v4-skin .toolbar-actions {
  gap: 10px;
}

body.v4-skin #new-quote-btn {
  background: var(--v3-surface);
  border: 1px solid var(--v3-line);
  color: var(--v3-navy);
  border-radius: var(--v3-pill);
  padding: 12px 18px;
  font-size: 13px;
  font-weight: 600;
  box-shadow: none;
  min-width: 0;
  min-height: 0;
}

body.v4-skin #new-quote-btn:hover {
  border-color: var(--v3-blue);
  color: var(--v3-blue);
}

/* ---- hero card : version V4 compacte (progression top) ---- */
body.v4-skin .hero-card {
  display: block;
  background: var(--v3-surface);
  border: 1px solid var(--v3-line);
  border-radius: 22px;
  box-shadow: var(--v3-shadow-card);
  padding: 22px 28px;
  min-height: 0;
}

body.v4-skin .hero-card::after,
body.v4-skin .hero-card::before { display: none; }

body.v4-skin .hero-copy-block {
  max-width: 100%;
}

body.v4-skin #hero-eyebrow {
  margin-bottom: 8px;
}

body.v4-skin #hero-title {
  font-family: var(--v3-display);
  font-weight: 400;
  letter-spacing: -0.012em;
  font-size: clamp(1.8rem, 1.3rem + 1vw, 2.6rem);
  color: var(--v3-navy);
  margin: 0 0 10px;
  line-height: 1.04;
}

body.v4-skin #hero-copy {
  font-size: 15px;
  color: var(--v3-ink-2);
  line-height: 1.55;
  margin: 0;
}

body.v4-skin .hero-metrics {
  display: block;
  margin-top: 18px;
}

body.v4-skin .hero-progress-card {
  background: transparent;
  border: 0;
  padding: 0;
  box-shadow: none;
}

body.v4-skin .hero-progress-head {
  display: flex;
  justify-content: space-between;
  font-family: var(--v3-mono);
  font-size: 11px;
  color: var(--v3-ink-3);
  margin-bottom: 8px;
  letter-spacing: 0.02em;
}

body.v4-skin .hero-progress-head strong {
  color: var(--v3-blue);
  font-weight: 700;
}

body.v4-skin .hero-progress-bar {
  height: 4px;
  background: var(--v3-line);
  border-radius: 99px;
  overflow: hidden;
}

body.v4-skin .hero-progress-bar span {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--v3-blue) 0%, #5B7BF6 100%);
  border-radius: 99px;
  transition: width .3s ease;
}

body.v4-skin .hero-progress-stage {
  font-size: 12px;
  color: var(--v3-ink-3);
  margin-top: 8px;
}

/* ---- stage panel : V4 card blanche ---- */
body.v4-skin .stage-panel {
  background: var(--v3-surface);
  border: 1px solid var(--v3-line);
  border-radius: 28px;
  box-shadow: var(--v3-shadow-card);
  padding: clamp(24px, 3vw, 40px);
  animation: none;
}

body.v4-skin .stage-panel::before,
body.v4-skin .stage-panel::after { display: none; }

body.v4-skin .stage-block-head h3,
body.v4-skin .panel-header h2 {
  font-family: var(--v3-display);
  font-weight: 400;
  letter-spacing: -0.012em;
  color: var(--v3-navy);
}

/* ---- choice cards : option style V4 ---- */
body.v4-skin .choice-grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

body.v4-skin .choice-card,
body.v4-skin .toggle-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 18px 22px;
  border-radius: 22px;
  border: 1.5px solid var(--v3-line);
  background: var(--v3-surface);
  box-shadow: none;
  text-align: left;
  transition: border-color .15s, background .15s, box-shadow .15s;
}

body.v4-skin .choice-card::before {
  content: "";
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid var(--v3-line);
  flex-shrink: 0;
  background: transparent;
  position: relative;
  transition: all .15s;
}

body.v4-skin .choice-card::after {
  display: none;
}

body.v4-skin .choice-card:hover,
body.v4-skin .toggle-card:hover {
  border-color: var(--v3-blue-soft);
  transform: none;
}

body.v4-skin .choice-card.is-selected,
body.v4-skin .toggle-card.is-selected {
  border-color: var(--v3-blue);
  background: linear-gradient(180deg, #fff 0%, var(--v3-blue-tint) 100%);
  box-shadow: 0 0 0 4px var(--v3-blue-tint);
}

body.v4-skin .choice-card.is-selected::before {
  border-color: var(--v3-blue);
  background:
    radial-gradient(circle at center, #fff 35%, transparent 36%),
    var(--v3-blue);
}

body.v4-skin .choice-title {
  font-family: var(--v3-sans);
  font-weight: 600;
  font-size: 15px;
  color: var(--v3-navy);
  margin: 0 0 2px;
}

body.v4-skin .choice-note {
  font-size: 13px;
  color: var(--v3-ink-3);
  line-height: 1.45;
}

/* ---- stage actions : retour ghost + suivant primary ---- */
body.v4-skin .stage-actions-inner {
  background: transparent;
  border: 0;
  box-shadow: none;
  backdrop-filter: none;
  padding: 8px 0 0;
}

body.v4-skin .stage-actions-inner > *:last-child {
  min-width: 0;
}

body.v4-skin button.primary,
body.v4-skin a.primary {
  background: var(--v3-blue);
  color: #fff;
  border: 0;
  border-radius: var(--v3-pill);
  padding: 14px 26px;
  font-size: 14px;
  font-weight: 600;
  box-shadow: var(--v3-shadow-cta);
}

body.v4-skin button.primary:hover {
  background: var(--v3-blue-strong);
  transform: translateY(-1px);
}

body.v4-skin button.secondary,
body.v4-skin a.secondary {
  background: var(--v3-surface);
  color: var(--v3-navy);
  border: 1px solid var(--v3-line);
  border-radius: var(--v3-pill);
  padding: 13px 20px;
  font-size: 14px;
  font-weight: 600;
  box-shadow: none;
}

body.v4-skin button.secondary:hover {
  border-color: var(--v3-blue);
  color: var(--v3-blue);
  transform: translateY(-1px);
}

body.v4-skin button.ghost,
body.v4-skin .button-link.ghost {
  background: transparent;
  color: var(--v3-ink-2);
  border: 0;
  padding: 12px 14px;
  font-size: 14px;
  font-weight: 600;
}

body.v4-skin button.ghost:hover {
  color: var(--v3-blue);
  transform: none;
}

/* ---- fields V4 ---- */
body.v4-skin .field input,
body.v4-skin .field select,
body.v4-skin .field textarea,
body.v4-skin .nextgen-field input,
body.v4-skin .nextgen-field select,
body.v4-skin .nextgen-field textarea {
  background: var(--v3-surface);
  border: 1.5px solid var(--v3-line);
  border-radius: 14px;
  padding: 14px 16px;
  font-size: 15px;
  color: var(--v3-navy);
  font-weight: 500;
}

body.v4-skin .field input:focus,
body.v4-skin .field select:focus,
body.v4-skin .field textarea:focus,
body.v4-skin .nextgen-field input:focus,
body.v4-skin .nextgen-field select:focus,
body.v4-skin .nextgen-field textarea:focus {
  outline: none;
  border-color: var(--v3-blue);
  box-shadow: 0 0 0 4px var(--v3-blue-tint);
}

body.v4-skin .field-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--v3-ink-2);
  letter-spacing: 0.02em;
}

body.v4-skin .stage-inline-card,
body.v4-skin .destination-hero-card,
body.v4-skin .selected-place-card,
body.v4-skin .selected-reference-card {
  background: var(--v3-surface);
  border: 1px solid var(--v3-line);
  border-radius: 22px;
  box-shadow: var(--v3-shadow-card);
}

/* ---- soft pills ---- */
body.v4-skin .soft-pill {
  background: var(--v3-blue-tint);
  color: var(--v3-blue);
  border: 1px solid var(--v3-blue-soft);
  border-radius: 999px;
  min-height: 0;
  margin-top: 0;
  padding: 3px 8px;
  font-size: 10.5px;
  font-weight: 700;
  font-family: var(--v3-mono);
  letter-spacing: 0.02em;
}

body.v4-skin .status-pill,
body.v4-skin .badge {
  min-height: 0;
  padding: 3px 8px;
  font-size: 10.5px;
  line-height: 1.05;
}

body.v4-skin .summary-pill-row,
body.v4-skin .status-pills {
  gap: 6px;
}

body.v4-skin .info-bubble {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  flex: 0 0 auto;
}

body.v4-skin .info-bubble-trigger {
  box-sizing: border-box;
  width: 16px;
  min-width: 16px;
  max-width: 16px;
  height: 16px;
  min-height: 16px;
  max-height: 16px;
  padding: 0;
  font-size: 0.6rem;
}

/* =================================================================
   V4 RESULT : hero + accordéons + conversion sidebar
   ================================================================= */

body.v4-skin .result-overview-shell {
  display: block;
  background: var(--v3-surface);
  border: 1px solid var(--v3-line);
  border-radius: 36px;
  box-shadow: var(--v3-shadow-card);
  padding: 36px 36px 32px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

body.v4-skin .result-overview-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(50% 40% at 100% 0%, rgba(40, 81, 240, 0.10), transparent 65%),
    radial-gradient(40% 30% at 0% 100%, rgba(40, 81, 240, 0.06), transparent 65%);
  pointer-events: none;
}

body.v4-skin .result-overview-shell > * {
  position: relative;
}

body.v4-skin .result-overview-main {
  display: grid;
  justify-items: center;
  align-items: center;
  width: 100%;
}

body.v4-skin .result-overview-topline {
  display: flex;
  justify-content: center;
  margin-bottom: 10px;
}

body.v4-skin .result-overview-shell .badge {
  background: var(--v3-blue-tint);
  color: var(--v3-blue);
  border: 1px solid var(--v3-blue-soft);
  font-family: var(--v3-mono);
  font-weight: 700;
  letter-spacing: 0.04em;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 11px;
}

body.v4-skin .result-overview-label {
  font-family: var(--v3-sans);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--v3-blue);
  margin: 0 0 12px;
}

body.v4-skin .grand-total {
  display: block;
  width: fit-content;
  max-width: 100%;
  margin-inline: auto;
  font-family: var(--v3-sans);
  font-weight: 520;
  letter-spacing: 0;
  color: var(--v3-blue);
  font-size: clamp(42px, 4.8vw, 60px);
  line-height: 1.05;
}

body.v4-skin .result-overview-shell .result-amount-caption {
  display: block;
  margin: 12px 0 0;
  color: rgba(10, 27, 69, 0.58);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.35;
  text-align: center;
}

body.v4-skin .v4-hero-subtitle {
  margin: 14px auto 0;
  max-width: 60ch;
  font-size: 14px;
  color: var(--v3-ink-3);
  line-height: 1.55;
}

/* result-body-layout : 2 colonnes V4 (1.5fr / 1fr) */
body.v4-skin .result-body-layout-simple {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(280px, 1fr);
  gap: 28px;
  align-items: start;
  margin-top: 22px;
}

body.v4-skin .result-body-layout-simple .result-main-column {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

body.v4-skin .result-body-layout-simple .result-side-column {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* result-sections : container accordéon (1 seule carte, lignes séparées) */
body.v4-skin .result-sections.v4-acc-stack {
  background: var(--v3-surface);
  border: 1px solid var(--v3-line);
  border-radius: 22px;
  box-shadow: var(--v3-shadow-card);
  padding: 0 28px;
}

body.v4-skin .v4-detail-title {
  margin: 0 0 12px;
}

body.v4-skin .result-section,
body.v4-skin .result-card.result-section {
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  padding: 0;
  margin: 0;
}

body.v4-skin .v4-acc-stack .result-section + .result-section {
  border-top: 1px solid var(--v3-line);
}

body.v4-skin .result-section-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 22px 0;
  cursor: pointer;
  border-bottom: 0;
  margin: 0;
}

body.v4-skin .result-section.is-open .result-section-head {
  padding-bottom: 14px;
}

body.v4-skin .result-section-head > div:first-child {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

body.v4-skin .result-section-head h3 {
  font-family: var(--v3-sans);
  font-weight: 600;
  font-size: 15px;
  color: var(--v3-navy);
  margin: 0;
  letter-spacing: 0;
}

body.v4-skin .v4-section-icon {
  width: 28px;
  height: 28px;
  min-width: 28px;
  border-radius: 50%;
  display: inline-grid;
  place-items: center;
  background: var(--v3-blue-tint);
  border: 1px solid var(--v3-blue-soft);
  color: var(--v3-blue);
}

body.v4-skin .v4-section-icon svg {
  width: 17px;
  height: 17px;
}

body.v4-skin .v4-section-icon-fastimmat {
  background: var(--v3-blue);
  border-color: var(--v3-blue);
  color: #FFFFFF;
  font-family: var(--v3-display);
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
}

body.v4-skin .section-summary {
  display: flex;
  align-items: center;
  gap: 16px;
  margin: 0;
}

body.v4-skin .section-summary strong {
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  font-size: 15px;
  color: var(--v3-navy);
  font-family: var(--v3-sans);
}

body.v4-skin .v4-acc-chev {
  width: 32px;
  height: 32px;
  min-width: 32px;
  border-radius: 50%;
  background: var(--v3-blue-tint);
  color: var(--v3-blue);
  display: inline-grid;
  place-items: center;
  border: 1px solid rgba(40, 81, 240, 0.10);
  box-shadow: 0 8px 18px rgba(40, 81, 240, 0.08);
  transition: transform .15s, background-color .15s, box-shadow .15s;
}

body.v4-skin .v4-acc-chev svg {
  width: 16px;
  height: 16px;
}

body.v4-skin .result-section.is-open .v4-acc-chev {
  transform: rotate(180deg);
  background: #E5EBFF;
  box-shadow: 0 10px 22px rgba(40, 81, 240, 0.12);
}

body.v4-skin .section-items {
  padding: 14px 0 22px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  border-bottom: 0;
}

body.v4-skin .section-items[hidden] { display: none; }

body.v4-skin .result-line-card {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 8px 0;
  margin: 0;
  border-bottom: 1px dashed var(--v3-line-2);
}

body.v4-skin .result-line-card:last-child {
  border-bottom: 0;
}

body.v4-skin .result-line-card .line-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}

body.v4-skin .result-line-card .line-head > div:first-child {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

body.v4-skin .result-line-card .line-title-row {
  display: flex;
  align-items: center;
  gap: 6px;
}

body.v4-skin .result-line-card strong {
  font-size: 13.5px;
  color: var(--v3-navy);
  font-weight: 600;
}

body.v4-skin .result-line-card .line-amount {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  font-size: 13.5px;
  color: var(--v3-navy);
  font-family: var(--v3-sans);
}

body.v4-skin .result-line-card .badge {
  background: var(--v3-blue-tint);
  color: var(--v3-blue);
  border: 1px solid var(--v3-blue-soft);
  font-family: var(--v3-mono);
  font-weight: 700;
  letter-spacing: 0.04em;
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 10.5px;
}

/* sources V4 */
body.v4-skin .v4-sources {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 24px;
  color: var(--v3-navy);
  font-size: 12px;
  line-height: 1.35;
}

body.v4-skin .result-source-icon {
  width: 18px;
  height: 18px;
  min-width: 18px;
  display: inline-grid;
  place-items: center;
  color: var(--v3-blue);
}

body.v4-skin .result-source-icon svg {
  width: 18px;
  height: 18px;
}

body.v4-skin .v4-sources b {
  color: var(--v3-navy);
  font-weight: 700;
}

/* conversion sidebar V4 */
body.v4-skin .contact-card,
body.v4-skin .result-card.contact-card {
  background: var(--v3-surface);
  border: 1px solid var(--v3-line);
  border-radius: 28px;
  box-shadow: var(--v3-shadow-card);
  padding: 0;
  overflow: hidden;
  margin: 0;
}

body.v4-skin .contact-card-shell {
  display: block;
  padding: 24px 24px 18px;
  background: linear-gradient(180deg, #F4F7FF 0%, var(--v3-surface) 100%);
  border-bottom: 1px solid var(--v3-line);
}

body.v4-skin .contact-card-copy h3 {
  font-family: var(--v3-display);
  font-weight: 400;
  letter-spacing: -0.012em;
  color: var(--v3-navy);
  font-size: 24px;
  line-height: 1.15;
  margin: 4px 0 0;
}

body.v4-skin .contact-card-copy h3 em {
  color: var(--v3-blue);
  font-style: italic;
}

body.v4-skin .contact-card-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 0;
  padding: 20px 24px 16px;
}

body.v4-skin .contact-card-actions #conversion-primary-btn {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 24px;
  font-size: 15px;
}

body.v4-skin .contact-card-actions #conversion-primary-btn .v4-cta-amount {
  font-family: var(--v3-mono);
  font-size: 12px;
  font-weight: 700;
  opacity: 0.88;
}

body.v4-skin .contact-card-actions .v4-cta-quote,
body.v4-skin .contact-card-actions .v4-cta-advisor {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border-radius: var(--v3-pill);
  padding: 13px 20px;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  transition: border-color .15s, color .15s, transform .12s;
}

body.v4-skin .contact-card-actions .v4-cta-quote {
  background: var(--v3-surface);
  color: var(--v3-navy);
  border: 1px solid var(--v3-line);
}

body.v4-skin .contact-card-actions .v4-cta-quote:hover {
  border-color: var(--v3-blue);
  color: var(--v3-blue);
  transform: translateY(-1px);
}

body.v4-skin .contact-card-actions .v4-cta-advisor {
  background: transparent;
  color: var(--v3-ink-2);
  border: 0;
}

body.v4-skin .contact-card-actions .v4-cta-advisor:hover {
  color: var(--v3-blue);
}

body.v4-skin .contact-card-actions .v4-msg-icon {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--v3-blue-tint);
  color: var(--v3-blue);
  display: inline-grid;
  place-items: center;
  font-size: 11px;
}

body.v4-skin .v4-conv-foot {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 16px 24px;
  border-top: 1px solid var(--v3-line);
  background: #FAFBFF;
  font-size: 12px;
  color: var(--v3-ink-3);
}

body.v4-skin .v4-conv-foot b {
  color: var(--v3-navy);
  font-weight: 700;
}

body.v4-skin .v4-aside-card {
  background: var(--v3-surface);
  border: 1px solid var(--v3-line);
  border-radius: 22px;
  box-shadow: var(--v3-shadow-card);
  padding: 22px;
}

body.v4-skin .v4-aside-card .v4-trust-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 8px;
}

body.v4-skin .v4-aside-card .v4-trust-list .item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13.5px;
  color: var(--v3-ink-2);
}

body.v4-skin .v4-aside-card .v4-trust-list .check {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--v3-blue-tint);
  color: var(--v3-blue);
  display: grid;
  place-items: center;
  font-size: 10px;
  font-weight: 700;
  flex-shrink: 0;
}

/* offer-card / provisional / conversion panels : harmoniser */
body.v4-skin .conversion-offer-card,
body.v4-skin .result-card.conversion-offer-card,
body.v4-skin .provisional-quote-panel .lead-capture-panel,
body.v4-skin .confirmation-panel {
  background: var(--v3-surface);
  border: 1px solid var(--v3-line);
  border-radius: 22px;
  box-shadow: var(--v3-shadow-card);
  padding: 22px;
}

body.v4-skin .support-card,
body.v4-skin .result-card.support-card {
  background: var(--v3-surface);
  border: 1px solid var(--v3-line);
  border-radius: 22px;
  box-shadow: var(--v3-shadow-card);
  padding: 22px;
}

body.v4-skin .simulator-seo-content {
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 32px 72px;
}

body.v4-skin .simulator-seo-content-inner {
  background: var(--v3-surface);
  border: 1px solid var(--v3-line);
  border-radius: 22px;
  box-shadow: var(--v3-shadow-card);
  padding: 34px;
}

body.v4-skin .simulator-seo-eyebrow {
  color: var(--v3-blue);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  margin: 0 0 10px;
  text-transform: uppercase;
}

body.v4-skin .simulator-seo-content h2 {
  color: var(--v3-navy);
  font-family: var(--v3-display);
  font-size: clamp(2rem, 1.5rem + 1vw, 3rem);
  font-weight: 400;
  line-height: 1.05;
  margin: 0 0 18px;
}

body.v4-skin .simulator-seo-content h3 {
  color: var(--v3-navy);
  font-size: 1rem;
  line-height: 1.25;
  margin: 0 0 10px;
}

body.v4-skin .simulator-seo-content p {
  color: var(--v3-ink-2);
  font-size: 15px;
  line-height: 1.7;
  margin: 0;
}

body.v4-skin .simulator-seo-intro {
  display: grid;
  gap: 14px;
  margin-bottom: 24px;
}

body.v4-skin .simulator-seo-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 0 0 24px;
}

body.v4-skin .simulator-seo-panel {
  border: 1px solid var(--v3-line);
  border-radius: 18px;
  display: grid;
  gap: 10px;
  padding: 20px;
}

body.v4-skin .simulator-seo-faq {
  border-top: 1px solid var(--v3-line);
  display: grid;
  gap: 10px;
  padding-top: 22px;
}

body.v4-skin .simulator-seo-faq details {
  border: 1px solid var(--v3-line);
  border-radius: 14px;
  padding: 14px 16px;
}

body.v4-skin .simulator-seo-faq summary {
  color: var(--v3-navy);
  cursor: pointer;
  font-weight: 700;
}

body.v4-skin .simulator-seo-faq details p {
  margin-top: 10px;
}

body.v4-skin .simulator-seo-actions {
  margin-top: 22px;
}

body.v4-skin .simulator-seo-cta {
  align-items: center;
  background: var(--v3-blue);
  border-radius: var(--v3-pill);
  color: #fff;
  display: inline-flex;
  font-size: 14px;
  font-weight: 700;
  min-height: 44px;
  padding: 0 18px;
  text-decoration: none;
}

/* ============== mobile ============== */
@media (max-width: 880px) {
  body.v4-skin .shell {
    grid-template-columns: 1fr;
    padding: 14px 18px 132px;
    gap: 14px;
  }
  body.v4-skin .sidebar {
    position: static;
    order: 0;
    height: auto;
    max-height: none;
  }
  body.v4-skin .sidebar-shell {
    padding: 14px 16px;
    border-radius: 18px;
  }
  body.v4-skin .sidebar-brand h1 { display: none; }
  body.v4-skin .sidebar-brand .lede { display: none; }
  body.v4-skin .sidebar-brand .eyebrow { display: none; }
  body.v4-skin .sidebar-card.stepper-card { display: none; }
  body.v4-skin .sidebar-card.status-card { padding: 0; border-top: 0; margin-top: 0; }
  body.v4-skin #quote-meta { font-size: 11px; }

  body.v4-skin .toolbar { padding: 0; }
  body.v4-skin #new-quote-btn { display: none; }

  body.v4-skin .hero-card {
    padding: 14px 18px;
    border-radius: 16px;
  }
  body.v4-skin #hero-eyebrow { font-size: 10px; margin-bottom: 6px; }
  body.v4-skin #hero-title {
    font-size: 22px;
    line-height: 1.08;
    margin-bottom: 8px;
  }
  body.v4-skin #hero-copy { font-size: 13.5px; line-height: 1.5; }
  body.v4-skin .hero-progress-card { margin-top: 10px; }

  body.v4-skin .simulator-seo-content {
    padding: 0 18px 64px;
  }

  body.v4-skin .simulator-seo-content-inner {
    border-radius: 18px;
    padding: 22px 18px;
  }

  body.v4-skin .simulator-seo-grid {
    grid-template-columns: 1fr;
  }

  body.v4-skin .simulator-seo-content h2 {
    font-size: 26px;
  }

  body.v4-skin .stage-panel {
    padding: 20px 18px;
    border-radius: 22px;
  }

  body.v4-skin .choice-card,
  body.v4-skin .toggle-card {
    padding: 14px 16px;
    border-radius: 18px;
    gap: 12px;
  }

  body.v4-skin .choice-card::before {
    width: 20px;
    height: 20px;
  }

  body.v4-skin .choice-title { font-size: 14px; }
  body.v4-skin .choice-note { font-size: 12.5px; }

  /* CTA suivant/retour : sticky bottom bar mobile */
  body.v4-skin .stage-actions {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 14px 18px 22px;
    background: linear-gradient(180deg, rgba(231, 237, 254, 0) 0%, var(--v3-bg-2) 40%);
    z-index: 30;
  }
  body.v4-skin .stage-actions-inner {
    padding: 0;
  }
  body.v4-skin .stage-actions-inner > button.primary {
    flex: 1;
    padding: 16px 22px;
    font-size: 15px;
  }
  body.v4-skin .stage-actions-inner > button#client-back-btn {
    padding: 14px 16px;
    flex: 0 0 auto;
  }

  /* result mobile */
  body.v4-skin .result-overview-shell {
    padding: 24px 22px 22px;
    border-radius: 24px;
  }
  body.v4-skin .grand-total {
    font-size: clamp(34px, 9vw, 44px);
    font-weight: 520;
  }
  body.v4-skin .v4-hero-subtitle { font-size: 12.5px; }

  body.v4-skin .result-body-layout-simple {
    grid-template-columns: 1fr;
    gap: 18px;
    margin-top: 14px;
  }

  body.v4-skin .result-sections.v4-acc-stack {
    padding: 0 20px;
    border-radius: 18px;
  }

  body.v4-skin .result-section,
  body.v4-skin .result-card.result-section {
    padding: 0;
    border-radius: 0;
  }

  body.v4-skin .result-section-head {
    padding: 16px 0;
  }

  body.v4-skin .result-section-head h3 { font-size: 13.5px; }
  body.v4-skin .section-summary strong { font-size: 13.5px; }

  body.v4-skin .v4-sources { font-size: 11px; }

  /* bottom CTA mobile sur le résultat */
  body.v4-skin .result-side-column.v4-bottom-cta {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 32;
    padding: 12px 18px 18px;
    background: linear-gradient(180deg, rgba(231, 237, 254, 0) 0%, var(--v3-bg-2) 45%);
    border-top: 1px solid rgba(224, 230, 245, 0.6);
    margin: 0;
    gap: 8px;
  }

  body.v4-skin .result-side-column.v4-bottom-cta > .contact-card {
    background: transparent;
    border: 0;
    box-shadow: none;
    padding: 0;
    border-radius: 0;
  }

  body.v4-skin .result-side-column.v4-bottom-cta .contact-card-shell {
    display: none;
  }

  body.v4-skin .result-side-column.v4-bottom-cta .contact-card-actions {
    padding: 0;
    gap: 8px;
  }

  body.v4-skin .result-side-column.v4-bottom-cta .v4-conv-foot {
    display: none;
  }

  body.v4-skin .result-side-column.v4-bottom-cta .v4-cta-secondary-row {
    display: flex;
    gap: 8px;
  }

  body.v4-skin .result-side-column.v4-bottom-cta .v4-cta-quote,
  body.v4-skin .result-side-column.v4-bottom-cta .v4-cta-advisor {
    flex: 1;
    padding: 12px 14px;
    font-size: 13px;
  }

  body.v4-skin .result-side-column.v4-bottom-cta > .v4-aside-card,
  body.v4-skin .result-side-column.v4-bottom-cta > .conversion-offer-card {
    display: none;
  }
}

@media (min-width: 881px) {
  body.v4-skin .v4-cta-secondary-row {
    display: contents;
  }
}

/* ---- desktop : utility wrapper for V4 secondary row ---- */
body.v4-skin .v4-cta-secondary-row {
  display: contents;
}

/* =========================================================
 * WIZARD POLISH PASS — landing header, sidebar legibility,
 * centered step titles, stacked result conversion, devis
 * panel toggle, premium advisor icon, CGV consent stack.
 * Scoped to .v4-skin to keep the legacy paths intact.
 * ========================================================= */

/* ---- Skip link (a11y) ---- */
.skip-link {
  position: absolute;
  inset-inline-start: -9999px;
  top: 12px;
  background: #0f1f5c;
  color: #fff;
  padding: 10px 14px;
  border-radius: 12px;
  font-weight: 600;
  z-index: 1000;
}
.skip-link:focus { inset-inline-start: 12px; outline: 2px solid #fff; }

/* ---- Wizard landing-style header ---- */
body.v4-skin .wizard-site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  background: #ffffff;
  border-bottom: 1px solid rgba(15, 31, 92, 0.08);
  backdrop-filter: saturate(140%) blur(6px);
}
body.v4-skin .wizard-site-header-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 14px 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
body.v4-skin .wizard-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: #0f1f5c;
  font-family: "Instrument Serif", "DM Serif Display", Georgia, serif;
}
body.v4-skin .wizard-brand-mark {
  width: 36px;
  height: 36px;
  border-radius: 12px;
  background: linear-gradient(135deg, #2851F0 0%, #0f1f5c 100%);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: "Instrument Serif", Georgia, serif;
  font-size: 22px;
  letter-spacing: 0.02em;
  box-shadow: 0 6px 16px -8px rgba(40, 81, 240, 0.55);
}
body.v4-skin .wizard-brand-word {
  font-size: 1.35rem;
  letter-spacing: -0.01em;
}
body.v4-skin .wizard-primary-nav {
  display: inline-flex;
  align-items: center;
  gap: 18px;
}
body.v4-skin .wizard-nav-link {
  color: #0f1f5c;
  text-decoration: none;
  font-weight: 500;
  font-size: 0.92rem;
  opacity: 0.86;
  transition: opacity 120ms ease;
}
body.v4-skin .wizard-nav-link:hover { opacity: 1; }
body.v4-skin .wizard-locale-switcher {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px;
  border-radius: 999px;
  background: rgba(40, 81, 240, 0.08);
}
body.v4-skin .wizard-locale-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  height: 26px;
  padding: 0 8px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 600;
  color: #0f1f5c;
  text-decoration: none;
  letter-spacing: 0.04em;
}
body.v4-skin .wizard-locale-link.is-active,
body.v4-skin .wizard-locale-link[aria-current="page"] {
  background: #fff;
  color: #2851F0;
  box-shadow: 0 1px 3px rgba(15, 31, 92, 0.12);
}
body.v4-skin .wizard-nav-cta {
  display: inline-flex;
  align-items: center;
  padding: 9px 16px;
  border-radius: 999px;
  background: #2851F0;
  color: #fff;
  font-weight: 600;
  font-size: 0.88rem;
  text-decoration: none;
  box-shadow: 0 8px 18px -10px rgba(40, 81, 240, 0.65);
  transition: transform 120ms ease, box-shadow 120ms ease;
}
body.v4-skin .wizard-nav-cta:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 22px -10px rgba(40, 81, 240, 0.75);
}
@media (max-width: 860px) {
  body.v4-skin .wizard-site-header-inner {
    padding: 10px 14px;
    gap: 10px;
  }
  body.v4-skin .wizard-brand-word { display: none; }
  body.v4-skin .wizard-nav-link { display: none; }
  body.v4-skin .wizard-primary-nav { gap: 10px; }
  body.v4-skin .wizard-nav-cta { padding: 7px 12px; font-size: 0.82rem; }
  body.v4-skin .wizard-locale-link { min-width: 28px; height: 24px; font-size: 0.72rem; }
}

/* ---- Sidebar: VOTRE SIMULATION + stepper labels in electric blue ---- */
body.v4-skin .sidebar-card .eyebrow {
  color: #2851F0;
  font-weight: 700;
  letter-spacing: 0.14em;
  opacity: 1;
}
body.v4-skin .sidebar-card.status-card .eyebrow,
body.v4-skin .sidebar-card.stepper-card .eyebrow {
  color: #2851F0;
}
body.v4-skin #stepper .step-label,
body.v4-skin #stepper .step-title,
body.v4-skin #stepper [class*="step"] > span,
body.v4-skin #stepper button,
body.v4-skin #stepper [role="button"] {
  color: #2851F0;
}
body.v4-skin #stepper [aria-current="step"],
body.v4-skin #stepper .is-current {
  color: #0f1f5c;
}
body.v4-skin #stepper .step-meta,
body.v4-skin #stepper small {
  color: rgba(40, 81, 240, 0.72);
}

body.v4-skin #stepper .step-item.active .step-count {
  color: #fff;
  background: #2851F0;
  border-color: #2851F0;
  z-index: 1;
}

/* ---- Centered step titles on desktop ---- */
@media (min-width: 881px) {
  body.v4-skin .hero-card .hero-copy-block,
  body.v4-skin .stage-card .panel-header,
  body.v4-skin .stage-card > header,
  body.v4-skin .panel.expert-section .panel-header,
  body.v4-skin .nextgen-stage-shell .panel-header {
    text-align: center;
    align-items: center;
  }
  body.v4-skin .hero-card .hero-copy-block > *,
  body.v4-skin .stage-card .panel-header > *,
  body.v4-skin .stage-card > header > * {
    margin-inline: auto;
  }
  body.v4-skin .hero-card .hero-copy-block .eyebrow,
  body.v4-skin .stage-card .panel-header .eyebrow,
  body.v4-skin .stage-card .panel-header .panel-step-label {
    color: #2851F0;
    letter-spacing: 0.14em;
  }
  body.v4-skin .hero-card .hero-copy-block .lede,
  body.v4-skin .stage-card .panel-header p {
    max-width: 64ch;
  }
}

/* ---- Result: stacked vertical layout, no aside ---- */
body.v4-skin .result-body-layout.result-body-layout-stacked,
body.v4-skin .result-body-layout.v4-result-layout-stacked {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
body.v4-skin .result-body-layout.result-body-layout-stacked .result-main-column,
body.v4-skin .result-body-layout.result-body-layout-stacked .result-conversion-column {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
body.v4-skin .result-body-layout.result-body-layout-stacked .result-main-column { order: 1; }
body.v4-skin .result-body-layout.result-body-layout-stacked .result-conversion-column { order: 2; }

/* Remove old desktop sticky-bottom-CTA behavior in stacked mode */
body.v4-skin .result-body-layout-stacked .result-conversion-column {
  position: static;
}

/* ---- Provisional quote: hidden by default, gentle slide-in when open ---- */
body.v4-skin .provisional-quote-panel[hidden] {
  display: none !important;
}
body.v4-skin .provisional-quote-panel.is-open {
  animation: v4-fade-slide 200ms ease;
}
@keyframes v4-fade-slide {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}
body.v4-skin .provisional-quote-panel .lead-panel-head h4 {
  margin: 0;
  font-family: "Instrument Serif", Georgia, serif;
  font-size: 1.35rem;
  color: #0f1f5c;
}

/* ---- Mon devis button: rotate arrow when expanded ---- */
body.v4-skin .v4-cta-quote[aria-expanded="true"] > span:first-child {
  display: inline-block;
  transform: rotate(180deg);
}

/* ---- Premium advisor message bubble icon ---- */
body.v4-skin .v4-msg-icon-bubble {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 10px;
  background: rgba(40, 81, 240, 0.12);
  color: #2851F0;
  margin-inline-end: 8px;
}
body.v4-skin .v4-msg-icon-bubble svg {
  width: 18px;
  height: 18px;
}
body.v4-skin .v4-cta-advisor {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  color: #0f1f5c;
  border-radius: 14px;
  padding: 10px 14px;
  background: #fff;
  border: 1px solid rgba(40, 81, 240, 0.18);
  font-weight: 600;
  font-size: 0.92rem;
  transition: background 120ms ease, border-color 120ms ease, transform 120ms ease;
}
body.v4-skin .v4-cta-advisor:hover {
  background: rgba(40, 81, 240, 0.05);
  border-color: rgba(40, 81, 240, 0.32);
  transform: translateY(-1px);
}

/* ---- Compact conversion-offer-grid (only 2 metrics + bubble) ---- */
body.v4-skin .conversion-offer-grid-compact {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
@media (max-width: 720px) {
  body.v4-skin .conversion-offer-grid-compact {
    grid-template-columns: 1fr;
  }
}
body.v4-skin .conversion-offer-metric-label-with-bubble {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

/* ---- CGV consent stack (compact card-style checkboxes) ---- */
body.v4-skin .lead-consent-stack {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 8px;
  padding: 14px;
  border-radius: 16px;
  background: rgba(40, 81, 240, 0.06);
  border: 1px solid rgba(40, 81, 240, 0.12);
}
body.v4-skin .lead-consent-row {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr);
  align-items: start;
  column-gap: 12px;
  cursor: pointer;
  font-size: 0.9rem;
  color: #0f1f5c;
  line-height: 1.4;
}
body.v4-skin .lead-consent-row input[type="checkbox"] {
  appearance: auto;
  -webkit-appearance: checkbox;
  justify-self: start;
  align-self: start;
  margin: 0.16em 0 0;
  width: 18px;
  min-width: 18px;
  height: 18px;
  min-height: 18px;
  padding: 0;
  border-radius: 3px;
  background: initial;
  box-shadow: none;
  accent-color: #2851F0;
  cursor: pointer;
}
body.v4-skin .lead-consent-text {
  display: block;
  min-width: 0;
}
body.v4-skin .lead-consent-text a {
  color: #2851F0;
  font-weight: 600;
}
body.v4-skin .lead-consent-text a:hover { text-decoration: underline; }
body.v4-skin #lead-submit-btn[disabled] {
  opacity: 0.55;
  cursor: not-allowed;
}

/* ---- Lead capture reveal animation when opening checkout panel ---- */
body.v4-skin .lead-capture-reveal:not([hidden]) {
  animation: v4-fade-slide 220ms ease;
}

/* =========================================================
 * CORRECTION PASS (PR #85)
 * - Centered titles desktop (large screens)
 * - Mobile duplicate "Profil du véhicule" hidden
 * - Devis panel: defense-in-depth hidden by default
 * - Mobile: result hero/accordions visible before CTA block
 * - CTA "Commencer mon dossier" balanced layout
 * - Premium advisor envelope icon
 * ========================================================= */

/* Mobile: hide duplicate vehicle profile heading inside stage card */
@media (max-width: 880px) {
  body.v4-skin .stage-block-head-mobile-hidden {
    display: none !important;
  }
}

/* Center all main step titles on desktop (incl. large screens) */
@media (min-width: 881px) {
  body.v4-skin .hero-card .hero-copy-block,
  body.v4-skin .nextgen-stage-shell .panel-header,
  body.v4-skin .stage-panel .stage-block-head,
  body.v4-skin .stage-panel .panel-header,
  body.v4-skin .panel.expert-section .panel-header {
    text-align: center !important;
    align-items: center !important;
  }
  body.v4-skin .hero-card .hero-copy-block > *,
  body.v4-skin .nextgen-stage-shell .panel-header > *,
  body.v4-skin .stage-panel .stage-block-head > *,
  body.v4-skin .stage-panel .panel-header > * {
    margin-inline: auto;
  }
  body.v4-skin .hero-card .hero-copy-block,
  body.v4-skin .stage-panel .stage-block-head {
    max-width: 720px;
    margin-inline: auto;
  }
  body.v4-skin .stage-block-head .title-with-info {
    justify-content: center;
  }
  body.v4-skin .result-card.result-overview-shell h1,
  body.v4-skin .result-card.result-overview-shell h2,
  body.v4-skin .result-card.result-overview-shell h3,
  body.v4-skin .result-card.result-overview-shell .result-overview-label {
    text-align: center;
  }
}

/* Provisional quote: harden default hidden state with class gate */
body.v4-skin .provisional-quote-panel {
  display: none;
}
body.v4-skin .provisional-quote-panel.is-open {
  display: block;
  animation: v4-fade-slide 200ms ease;
}
body.v4-skin .provisional-quote-panel[hidden] {
  display: none !important;
}

/* CTA "Commencer mon dossier" — balanced layout (label centered, amount right) */
body.v4-skin .v4-cta-primary {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 12px;
  padding-inline: 18px;
  text-align: center;
}
body.v4-skin .v4-cta-primary > .v4-cta-label {
  grid-column: 2;
  font-weight: 700;
}
body.v4-skin .v4-cta-primary > .v4-cta-amount {
  grid-column: 3;
  justify-self: end;
  font-weight: 700;
  opacity: 0.95;
}

/* Premium advisor envelope icon — slightly larger + soft halo */
body.v4-skin .v4-msg-icon-bubble {
  width: 30px;
  height: 30px;
  background: rgba(40, 81, 240, 0.10);
  box-shadow: inset 0 0 0 1px rgba(40, 81, 240, 0.16);
}
body.v4-skin .v4-msg-icon-bubble svg {
  width: 18px;
  height: 18px;
}

/* Mobile: ensure result hero + accordions visible above CTA block */
@media (max-width: 880px) {
  body.v4-skin .result-body-layout.result-body-layout-stacked {
    padding-bottom: 24px;
  }
  body.v4-skin .result-body-layout.result-body-layout-stacked .result-main-column { order: 1; }
  body.v4-skin .result-body-layout.result-body-layout-stacked .result-conversion-column { order: 2; }
  /* Defensive: ensure no fixed/sticky leftover pulls the conversion block up */
  body.v4-skin .result-body-layout.result-body-layout-stacked .result-conversion-column,
  body.v4-skin .result-body-layout.result-body-layout-stacked .result-side-column {
    position: static !important;
    inset: auto !important;
    box-shadow: none !important;
  }
  /* Hero estimation card stays at top */
  body.v4-skin .result-overview-shell {
    order: 0;
  }
}

/* =========================================================
 * CORRECTION PASS ROUND 3 (PR #85)
 * - Hard-center step titles (defeat #hero-title max-width: 10ch)
 * - Top CTA "Nouvelle simulation" centered
 * - Inline info bubbles in vehicle profile (no line-break)
 * - Greyed-out BOE-derived fields on desktop
 * - Result: hide eyebrow + taxes caption, center titles + sources
 * - Result detail breathing room + centered
 * - Edit-quote button visible borders
 * ========================================================= */

/* --- Hero / step titles: hard center, full-width text, responsive --- */
body.v4-skin #hero-title,
body.v4-skin #hero-eyebrow,
body.v4-skin #hero-copy {
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

body.v4-skin .hero-copy-block {
  text-align: center;
  align-items: center;
  justify-items: center;
}

body.v4-skin .hero-copy-block > * {
  margin-inline: auto;
  max-width: 100%;
}

/* Stage panel titles (Quel type de véhicule, etc.) - center on all desktop widths */
body.v4-skin .stage-card .panel-header,
body.v4-skin .stage-card .stage-block-head,
body.v4-skin .nextgen-stage-shell .panel-header,
body.v4-skin .panel.expert-section .panel-header,
body.v4-skin .stage-panel .stage-block-head,
body.v4-skin .stage-panel .panel-header {
  text-align: center;
  align-items: center;
}

body.v4-skin .stage-card .panel-header > *,
body.v4-skin .stage-card .stage-block-head > *,
body.v4-skin .nextgen-stage-shell .panel-header > *,
body.v4-skin .panel.expert-section .panel-header > *,
body.v4-skin .stage-panel .stage-block-head > *,
body.v4-skin .stage-panel .panel-header > * {
  margin-left: auto;
  margin-right: auto;
}

/* Top toolbar new-quote CTA: center the button in toolbar-actions */
body.v4-skin .toolbar-actions {
  justify-content: center;
}

body.v4-skin #new-quote-btn {
  margin-inline: auto;
}

/* --- Vehicle profile: inline info bubble flowing with title text --- */
body.v4-skin .title-with-info,
body.v4-skin .stage-block-head .title-with-info {
  display: block;
  flex-wrap: initial;
}

body.v4-skin .title-with-info h3,
body.v4-skin .title-with-info h2,
body.v4-skin .stage-block-head .title-with-info h3,
body.v4-skin .stage-block-head .title-with-info h2 {
  display: inline;
  margin: 0;
}

body.v4-skin .title-with-info .info-bubble,
body.v4-skin .stage-block-head .title-with-info .info-bubble {
  display: inline-block;
  vertical-align: middle;
  margin-left: 6px;
}

body.v4-skin .origin-country-card .stage-block-head.compact-head {
  max-width: 100%;
  margin-inline: auto;
  text-align: center;
  justify-items: center;
}

body.v4-skin .origin-country-card .title-with-info {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-align: center;
}

body.v4-skin .origin-country-card .title-with-info h3 {
  display: inline;
  font-family: var(--v3-body);
  font-size: clamp(1.18rem, 1.03rem + 0.35vw, 1.42rem);
  font-weight: 750;
  line-height: 1.15;
  letter-spacing: 0;
}

body.v4-skin .origin-country-card .info-bubble {
  width: 16px;
  height: 16px;
  margin-left: 0;
  flex: 0 0 auto;
}

body.v4-skin .origin-country-card .info-bubble-trigger {
  width: 16px;
  min-width: 16px;
  height: 16px;
  min-height: 16px;
  font-size: 0.6rem;
}

body.v4-skin .origin-country-card .selected-place-card {
  justify-content: center;
  text-align: center;
}

body.v4-skin .origin-country-card .selected-country-display {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

body.v4-skin .origin-country-card .country-flag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 22px;
  border-radius: 6px;
  background: rgba(245, 248, 255, 0.92);
  box-shadow:
    inset 0 0 0 1px rgba(6, 18, 48, 0.1),
    0 6px 12px rgba(16, 36, 84, 0.08);
  font-size: 1.12rem;
  line-height: 1;
}

body.v4-skin .origin-country-card > .field.nextgen-field {
  margin-top: 18px;
}

body.v4-skin .choice-deck[data-field-name="seller_regime"] .stage-block-head.compact-head {
  max-width: 100%;
  margin-inline: auto;
  text-align: center;
  justify-items: center;
}

body.v4-skin .choice-deck[data-field-name="seller_regime"] .title-with-info {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-align: center;
}

body.v4-skin .choice-deck[data-field-name="seller_regime"] .title-with-info h3 {
  display: inline;
  font-family: var(--v3-body);
  font-size: clamp(1.18rem, 1.03rem + 0.35vw, 1.42rem);
  font-weight: 750;
  line-height: 1.15;
  letter-spacing: 0;
}

body.v4-skin .choice-deck[data-field-name="seller_regime"] .info-bubble {
  width: 16px;
  height: 16px;
  margin-left: 0;
  flex: 0 0 auto;
}

body.v4-skin .choice-deck[data-field-name="seller_regime"] .info-bubble-trigger {
  width: 16px;
  min-width: 16px;
  height: 16px;
  min-height: 16px;
  font-size: 0.6rem;
}

body.v4-skin .choice-deck[data-field-name="homologation_path"] .stage-block-head.compact-head {
  max-width: 100%;
  margin-inline: auto;
  text-align: center;
  justify-items: center;
}

body.v4-skin .choice-deck[data-field-name="homologation_path"] .title-with-info {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-align: center;
}

body.v4-skin .choice-deck[data-field-name="homologation_path"] .title-with-info h3 {
  display: inline;
  font-family: var(--v3-body);
  font-size: clamp(1.18rem, 1.03rem + 0.35vw, 1.42rem);
  font-weight: 750;
  line-height: 1.15;
  letter-spacing: 0;
}

body.v4-skin .choice-deck[data-field-name="homologation_path"] .info-bubble {
  width: 16px;
  height: 16px;
  margin-left: 0;
  flex: 0 0 auto;
}

body.v4-skin .choice-deck[data-field-name="homologation_path"] .info-bubble-trigger {
  width: 16px;
  min-width: 16px;
  height: 16px;
  min-height: 16px;
  font-size: 0.6rem;
}

body.v4-skin .vehicle-reference-card .stage-block-head.compact-head {
  max-width: 100%;
  margin-inline: auto;
  text-align: center;
  justify-items: center;
}

body.v4-skin .vehicle-reference-card .title-with-info {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-align: center;
}

body.v4-skin .vehicle-reference-card .title-with-info h3 {
  display: inline;
  font-family: var(--v3-body);
  font-size: clamp(1.18rem, 1.03rem + 0.35vw, 1.42rem);
  font-weight: 750;
  line-height: 1.15;
  letter-spacing: 0;
}

body.v4-skin .vehicle-reference-card .info-bubble {
  width: 16px;
  height: 16px;
  margin-left: 0;
  flex: 0 0 auto;
}

body.v4-skin .vehicle-reference-card .info-bubble-trigger {
  width: 16px;
  min-width: 16px;
  height: 16px;
  min-height: 16px;
  font-size: 0.6rem;
}

body.v4-skin .vehicle-reference-card .field-head {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-align: center;
}

body.v4-skin .vehicle-reference-card .field-head .field-title {
  flex: 0 0 auto;
}

body.v4-skin .vehicle-reference-card .field-head .info-bubble {
  width: 16px;
  height: 16px;
  margin-left: 0;
  flex: 0 0 auto;
}

body.v4-skin .vehicle-reference-card .field-head .info-bubble-trigger {
  width: 16px;
  min-width: 16px;
  height: 16px;
  min-height: 16px;
  font-size: 0.6rem;
}

body.v4-skin .official-autofill-card .stage-block-head.compact-head {
  max-width: 100%;
  margin-inline: auto;
  text-align: center;
  justify-items: center;
}

body.v4-skin .official-autofill-card .title-with-info {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-align: center;
}

body.v4-skin .official-autofill-card .title-with-info h3 {
  display: inline;
  font-family: var(--v3-body);
  font-size: clamp(1.18rem, 1.03rem + 0.35vw, 1.42rem);
  font-weight: 750;
  line-height: 1.15;
  letter-spacing: 0;
}

body.v4-skin .official-autofill-card .info-bubble {
  width: 16px;
  height: 16px;
  margin-left: 0;
  flex: 0 0 auto;
}

body.v4-skin .official-autofill-card .info-bubble-trigger {
  width: 16px;
  min-width: 16px;
  height: 16px;
  min-height: 16px;
  font-size: 0.6rem;
}

body.v4-skin .official-autofill-card .mini-form-grid {
  margin-top: 14px;
}

body.v4-skin .official-autofill-card .field > span,
body.v4-skin .official-autofill-card .field .field-head {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  margin-bottom: 8px;
  text-align: center;
}

body.v4-skin .official-autofill-card label.field.nextgen-field > span {
  display: flex !important;
  justify-content: center;
  text-align: center;
}

@media (max-width: 700px) {
  body.v4-skin .stage-card .stage-block-head,
  body.v4-skin .stage-card .compact-head,
  body.v4-skin .stage-card .panel-header {
    text-align: center;
    justify-items: center;
  }

  body.v4-skin .stage-card .title-with-info,
  body.v4-skin .stage-card .field-head,
  body.v4-skin .stage-card label.field > span,
  body.v4-skin .stage-card div.field > span {
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: 100%;
    text-align: center;
  }

  body.v4-skin .stage-card .title-with-info h2,
  body.v4-skin .stage-card .title-with-info h3,
  body.v4-skin .stage-card .stage-block-head h2,
  body.v4-skin .stage-card .stage-block-head h3 {
    text-align: center;
  }

  body.v4-skin .stage-card .info-bubble {
    width: 16px;
    height: 16px;
    flex: 0 0 16px;
    margin-left: 0;
  }

  body.v4-skin .stage-card .info-bubble-trigger {
    width: 16px;
    min-width: 16px;
    height: 16px;
    min-height: 16px;
    padding: 0;
    font-size: 0.6rem;
    line-height: 1;
  }

  body.v4-skin .stage-card .field {
    text-align: center;
  }
}

/* --- BOE-derived fields: visibly greyed/disabled on desktop --- */
body.v4-skin .stage-card input[readonly],
body.v4-skin .stage-card select[disabled],
body.v4-skin .stage-card input[disabled],
body.v4-skin .stage-card .field.is-readonly input,
body.v4-skin .stage-card .field.is-readonly select,
body.v4-skin .stage-card .field.is-readonly textarea,
body.v4-skin .stage-card .field.is-disabled input,
body.v4-skin .stage-card .field.is-disabled select,
body.v4-skin .stage-card .field.is-locked input,
body.v4-skin .stage-card .field.is-locked select,
body.v4-skin .stage-card .field[data-locked="true"] input,
body.v4-skin .stage-card .field[data-locked="true"] select,
body.v4-skin .stage-card .field.is-derived input,
body.v4-skin .stage-card .field.is-derived select {
  background: rgba(15, 31, 92, 0.05) !important;
  color: rgba(15, 31, 92, 0.55) !important;
  border-color: rgba(15, 31, 92, 0.12) !important;
  cursor: not-allowed;
  -webkit-text-fill-color: rgba(15, 31, 92, 0.55);
  opacity: 1;
}

body.v4-skin .stage-card .field.is-readonly,
body.v4-skin .stage-card .field.is-disabled,
body.v4-skin .stage-card .field.is-derived,
body.v4-skin .stage-card .field[data-locked="true"] {
  opacity: 0.92;
}

body.v4-skin .stage-card .field.is-readonly > span,
body.v4-skin .stage-card .field.is-disabled > span,
body.v4-skin .stage-card .field.is-derived > span,
body.v4-skin .stage-card .field[data-locked="true"] > span {
  color: rgba(15, 31, 92, 0.6);
}

/* --- Result page: center titles, hide eyebrow & taxes caption --- */
body.v4-skin .result-overview-shell .result-overview-label,
body.v4-skin .result-overview-shell .result-overview-eyebrow,
body.v4-skin .result-card.result-overview-shell .result-amount-eyebrow {
  display: none;
}

body.v4-skin .result-card.result-overview-shell .result-amount-line {
  display: none;
}

body.v4-skin .result-overview-shell h1,
body.v4-skin .result-overview-shell h2,
body.v4-skin .result-overview-shell h3,
body.v4-skin .result-overview-shell .result-overview-title,
body.v4-skin .result-overview-shell .result-amount-label {
  text-align: center;
  margin-inline: auto;
}

/* Result detail breathing room + centered */
body.v4-skin .result-detail-section,
body.v4-skin .result-detail-shell {
  margin-top: 28px;
}

body.v4-skin .result-detail-section .panel-header,
body.v4-skin .result-detail-shell .panel-header,
body.v4-skin .result-detail-section > h2,
body.v4-skin .result-detail-section > h3 {
  text-align: center;
  align-items: center;
}

body.v4-skin .result-detail-section > h2,
body.v4-skin .result-detail-section > h3 {
  margin-inline: auto;
}

/* Sources officielles: electric blue + centered */
body.v4-skin .result-sources-row,
body.v4-skin .v4-result-sources,
body.v4-skin .result-card .sources-line {
  text-align: center;
  color: #2851F0;
  font-weight: 600;
}

body.v4-skin .result-sources-row a,
body.v4-skin .v4-result-sources a,
body.v4-skin .result-card .sources-line a {
  color: #2851F0;
}

/* Edit-info button visible borders */
body.v4-skin .result-edit-btn,
body.v4-skin button.result-edit-btn {
  border: 1.5px solid rgba(40, 81, 240, 0.45);
  background: #fff;
  color: #2851F0;
  border-radius: 999px;
  padding: 10px 18px;
  font-weight: 600;
}

body.v4-skin .result-edit-btn:hover {
  border-color: rgba(40, 81, 240, 0.85);
  background: rgba(40, 81, 240, 0.06);
}

/* CTA Commencer mon dossier: ensure label centered + responsive */
body.v4-skin .v4-cta-primary {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 10px;
  padding-inline: 18px;
  text-align: center;
}

body.v4-skin .v4-cta-primary > .v4-cta-label {
  grid-column: 2;
  justify-self: center;
  font-weight: 700;
  white-space: nowrap;
}

body.v4-skin .v4-cta-primary > .v4-cta-amount {
  grid-column: 3;
  justify-self: end;
  font-weight: 700;
}

/* Desktop result actions: center primary/edit CTAs inside the conversion card */
body.v4-skin .contact-card-actions {
  align-items: center;
}

body.v4-skin .contact-card-actions > * {
  margin-inline: auto;
}

body.v4-skin .contact-card-actions #conversion-primary-btn.v4-cta-primary {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  justify-content: initial;
  width: min(100%, 520px);
}

body.v4-skin .contact-card-actions #conversion-primary-btn.v4-cta-primary > .v4-cta-label {
  grid-column: 2;
  justify-self: center;
}

body.v4-skin .contact-card-actions #conversion-primary-btn.v4-cta-primary > .v4-cta-amount {
  grid-column: 3;
  justify-self: end;
}

body.v4-skin .contact-card-actions .result-edit-btn {
  width: min(100%, 520px);
  justify-content: center;
}

@media (max-width: 520px) {
  body.v4-skin .v4-cta-primary {
    grid-template-columns: 1fr;
    gap: 4px;
  }
  body.v4-skin .v4-cta-primary > .v4-cta-label,
  body.v4-skin .v4-cta-primary > .v4-cta-amount {
    grid-column: 1;
    justify-self: center;
  }
}

/* Result cleanup pass: remove internal-looking noise and center conversion copy */
body.v4-skin .v4-sources,
body.v4-skin .result-sources-row,
body.v4-skin .v4-result-sources,
body.v4-skin .result-card .sources-line {
  justify-content: center;
  text-align: center;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

body.v4-skin #result-panel > .result-overview-shell {
  margin-top: 0;
  margin-bottom: 14px;
}

@media (max-width: 640px) {
  body.v4-skin.result-stage-active .content {
    gap: 4px;
  }

  body.v4-skin #result-panel > .result-overview-shell {
    margin-top: 0;
    margin-bottom: 10px;
  }
}

body.v4-skin #result-panel > .result-overview-shell .result-overview-main {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  text-align: center;
}

body.v4-skin #result-panel > .result-overview-shell .grand-total {
  display: block;
  width: 100%;
  margin: 0 auto;
  color: var(--v3-blue);
  font-family: var(--v3-sans);
  font-size: clamp(40px, 5.8vw, 62px);
  font-weight: 650;
  font-feature-settings: "lnum" 1, "tnum" 1;
  font-variant-numeric: lining-nums tabular-nums;
  letter-spacing: 0;
  line-height: 1.05;
  text-align: center;
  text-shadow: 0 10px 24px rgba(40, 81, 240, 0.14);
}

body.v4-skin #result-panel > .result-overview-shell .result-amount-caption {
  display: block;
  margin: 12px 0 0;
  color: rgba(10, 27, 69, 0.62);
  font-size: 14px;
  font-weight: 500;
}

body.v4-skin #result-panel > .result-overview-shell .result-overview-sources {
  margin-top: 22px;
  color: var(--v3-navy);
  font-weight: 500;
}

body.v4-skin #result-panel > .result-overview-shell .result-overview-sources b {
  color: var(--v3-navy);
  font-weight: 600;
}

@media (max-width: 480px) {
  body.v4-skin #result-panel > .result-overview-shell .grand-total {
    font-size: clamp(34px, 11vw, 48px);
    font-weight: 620;
  }

  body.v4-skin #result-panel > .result-overview-shell .result-amount-caption {
    font-size: 13px;
  }

  body.v4-skin #result-panel > .result-overview-shell .result-overview-sources {
    gap: 6px;
    margin-top: 20px;
    font-size: 11.5px;
  }
}

body.v4-skin .document-inline-card .stage-block-head.compact-head {
  max-width: 100%;
  margin-inline: auto;
  text-align: center;
  justify-items: center;
}

body.v4-skin .document-inline-card .stage-block-head.compact-head .title-with-info {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-align: center;
}

body.v4-skin .document-inline-card .stage-block-head.compact-head .title-with-info h2,
body.v4-skin .document-inline-card .stage-block-head.compact-head .title-with-info h3 {
  display: inline;
  font-size: clamp(30px, 5.2vw, 44px);
  line-height: 1.05;
}

body.v4-skin .document-inline-card .stage-block-head.compact-head .info-bubble {
  width: 16px;
  height: 16px;
  margin-left: 2px;
  flex: 0 0 auto;
}

body.v4-skin .document-inline-card .stage-block-head.compact-head .info-bubble-trigger {
  width: 16px;
  min-width: 16px;
  height: 16px;
  min-height: 16px;
  padding: 0;
  font-size: 10px;
  line-height: 1;
}

body.v4-skin .document-inline-card .file-field input[type="file"] {
  min-height: 64px;
  padding: 10px 14px;
  border-radius: 18px;
  border-color: rgba(40, 81, 240, 0.20);
  background: linear-gradient(180deg, #FFFFFF 0%, #F7F9FF 100%);
  color: var(--v3-navy);
  cursor: pointer;
}

body.v4-skin .document-inline-card .file-field input[type="file"]::file-selector-button {
  margin-right: 14px;
  border: 0;
  border-radius: 999px;
  padding: 11px 18px;
  background: var(--v3-blue);
  color: #FFFFFF;
  font-family: var(--v3-sans);
  font-weight: 800;
  box-shadow: 0 12px 24px rgba(40, 81, 240, 0.20);
  cursor: pointer;
}

body.v4-skin .document-inline-card .file-field input[type="file"]::-webkit-file-upload-button {
  margin-right: 14px;
  border: 0;
  border-radius: 999px;
  padding: 11px 18px;
  background: var(--v3-blue);
  color: #FFFFFF;
  font-family: var(--v3-sans);
  font-weight: 800;
  box-shadow: 0 12px 24px rgba(40, 81, 240, 0.20);
  cursor: pointer;
}

body.v4-skin .document-inline-card .file-field input[type="file"]:hover::file-selector-button,
body.v4-skin .document-inline-card .file-field input[type="file"]:hover::-webkit-file-upload-button {
  background: var(--v3-blue-strong);
}

body.v4-skin .result-line-card .line-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) max-content;
  align-items: center;
  gap: 12px;
  flex-wrap: nowrap;
}

body.v4-skin .result-line-card .line-title-row {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-width: 0;
  max-width: 100%;
}

body.v4-skin .result-line-card .line-title-row strong {
  min-width: 0;
  line-height: 1.25;
}

body.v4-skin .result-line-card .info-bubble {
  flex: 0 0 auto;
  width: 16px;
  height: 16px;
}

body.v4-skin .result-line-card .info-bubble-trigger {
  width: 16px;
  min-width: 16px;
  height: 16px;
  min-height: 16px;
  padding: 0;
  border-radius: 999px;
  font-size: 10px;
  line-height: 1;
}

body.v4-skin .result-line-card .line-amount {
  align-self: center;
  justify-self: end;
  white-space: nowrap;
}

body.v4-skin .v4-conv-head,
body.v4-skin .v4-conv-head .contact-card-copy,
body.v4-skin .v4-conv-head .eyebrow,
body.v4-skin .v4-conv-head h3 {
  text-align: center;
  justify-items: center;
}

body.v4-skin .v4-cta-primary {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  text-align: center;
}

body.v4-skin .v4-cta-primary > .v4-cta-label,
body.v4-skin .v4-cta-primary > .v4-cta-amount {
  grid-column: auto;
  justify-self: auto;
}

body.v4-skin .contact-card-actions #conversion-primary-btn.v4-cta-primary {
  position: relative;
  display: flex;
  justify-content: center;
  padding-left: 96px;
  padding-right: 96px;
}

body.v4-skin .contact-card-actions #conversion-primary-btn.v4-cta-primary > .v4-cta-label {
  display: block;
  width: 100%;
  text-align: center;
  white-space: normal;
}

body.v4-skin .contact-card-actions #conversion-primary-btn.v4-cta-primary > .v4-cta-amount {
  position: absolute;
  right: 32px;
  top: 50%;
  transform: translateY(-50%);
}

@media (max-width: 520px) {
  body.v4-skin .contact-card-actions #conversion-primary-btn.v4-cta-primary {
    padding-left: 72px;
    padding-right: 72px;
  }

  body.v4-skin .contact-card-actions #conversion-primary-btn.v4-cta-primary > .v4-cta-amount {
    right: 24px;
  }
}

body.v4-skin .lead-panel-copy {
  text-align: center;
  justify-items: center;
  margin-inline: auto;
}

body.v4-skin .lead-panel-copy .eyebrow,
body.v4-skin .lead-panel-copy h4,
body.v4-skin .lead-panel-copy p {
  text-align: center;
}

body.v4-skin .lead-panel-copy h4 {
  color: #2851F0;
}

body.v4-skin .lead-panel-copy p {
  max-width: 760px;
  margin-inline: auto;
}

body.v4-skin .lead-capture-panel .lead-form-grid .nextgen-field > span {
  display: flex;
  justify-content: center;
  text-align: center;
  width: 100%;
}

body.v4-skin .lead-contact-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
}

body.v4-skin .lead-contact-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  color: #2851F0;
}

body.v4-skin .lead-contact-icon svg {
  width: 15px;
  height: 15px;
}

body.v4-skin .lead-contact-icon-email {
  background: linear-gradient(180deg, #FFFFFF 0%, #F6F8FF 100%);
  border: 1px solid rgba(40, 81, 240, 0.16);
  box-shadow:
    0 8px 18px rgba(40, 81, 240, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.96);
}

body.v4-skin .lead-contact-icon-whatsapp {
  background: rgba(37, 211, 102, 0.10);
  border: 1px solid rgba(37, 211, 102, 0.22);
  color: #128C4A;
}

body.v4-skin .lead-contact-separator {
  color: rgba(15, 31, 92, 0.45);
  font-weight: 700;
}

body.v4-skin .vehicle-brand-selected-title {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
}

body.v4-skin .vehicle-brand-logo {
  display: inline-grid;
  place-items: center;
  flex: 0 0 30px;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid rgba(15, 31, 92, 0.12);
  color: var(--v3-navy);
  box-shadow:
    0 8px 18px rgba(15, 31, 92, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 0.95);
  overflow: hidden;
}

body.v4-skin .vehicle-brand-logo img,
body.v4-skin .vehicle-brand-logo svg {
  display: block;
  width: 21px;
  height: 21px;
  object-fit: contain;
}

body.v4-skin .vehicle-brand-logo-mercedes svg {
  width: 24px;
  height: 24px;
}

/* Mobile rule: the client tunnel reads as one centered flow. */
@media (max-width: 700px) {
  body.v4-skin #client-stage-card,
  body.v4-skin #client-stage-card .stage-panel,
  body.v4-skin #client-stage-card .stage-inline-card,
  body.v4-skin #client-stage-card .choice-deck,
  body.v4-skin #client-stage-card .lookup-stack,
  body.v4-skin #client-stage-card .selected-reference-card,
  body.v4-skin #client-stage-card .selected-place-card,
  body.v4-skin #client-stage-card .document-inline-card,
  body.v4-skin #client-stage-card .document-workflow-shell,
  body.v4-skin #client-stage-card .document-card,
  body.v4-skin #client-stage-card .empty-state {
    text-align: center !important;
    justify-items: center;
  }

  body.v4-skin #client-stage-card h1,
  body.v4-skin #client-stage-card h2,
  body.v4-skin #client-stage-card h3,
  body.v4-skin #client-stage-card h4,
  body.v4-skin #client-stage-card p,
  body.v4-skin #client-stage-card strong,
  body.v4-skin #client-stage-card small,
  body.v4-skin #client-stage-card .muted-line,
  body.v4-skin #client-stage-card .lede,
  body.v4-skin #client-stage-card .eyebrow,
  body.v4-skin #client-stage-card .panel-step-label,
  body.v4-skin #client-stage-card .field-head,
  body.v4-skin #client-stage-card label.field > span,
  body.v4-skin #client-stage-card div.field > span {
    text-align: center !important;
  }

  body.v4-skin #client-stage-card .title-with-info,
  body.v4-skin #client-stage-card .field-head,
  body.v4-skin #client-stage-card label.field > span,
  body.v4-skin #client-stage-card div.field > span,
  body.v4-skin #client-stage-card .selected-country-display,
  body.v4-skin #client-stage-card .choice-card,
  body.v4-skin #client-stage-card .search-results article {
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: 100%;
  }

  body.v4-skin #client-stage-card input,
  body.v4-skin #client-stage-card select,
  body.v4-skin #client-stage-card textarea {
    text-align: center !important;
    text-align-last: center;
  }

  body.v4-skin #client-stage-card input::placeholder,
  body.v4-skin #client-stage-card textarea::placeholder {
    text-align: center;
  }

  body.v4-skin #client-stage-card .soft-pill,
  body.v4-skin #client-stage-card .status-pill,
  body.v4-skin #client-stage-card .badge {
    margin-inline: auto;
    text-align: center;
    justify-content: center;
  }

  body.v4-skin #client-stage-card .info-bubble {
    width: 16px;
    height: 16px;
    flex: 0 0 16px;
    margin-left: 0;
  }

  body.v4-skin #client-stage-card .info-bubble-trigger {
    width: 16px;
    min-width: 16px;
    height: 16px;
    min-height: 16px;
    padding: 0;
    font-size: 0.6rem;
    line-height: 1;
  }
}

/* Mobile consistency pass: center content without shrinking the cards. */
@media (max-width: 700px) {
  body.v4-skin #client-stage-card .stage-panel,
  body.v4-skin #client-stage-card .choice-deck,
  body.v4-skin #client-stage-card .choice-grid,
  body.v4-skin #client-stage-card .stage-inline-card {
    width: 100%;
    max-width: 100%;
    align-self: stretch;
  }

  body.v4-skin #client-stage-card .choice-grid {
    align-items: stretch;
    justify-items: stretch;
  }

  body.v4-skin #client-stage-card .choice-card,
  body.v4-skin #client-stage-card .toggle-card {
    width: 100%;
    max-width: none;
    min-height: 70px;
    justify-content: center;
  }
}

/* Official reference cards: compact, coherent and visibly validated. */
body.v4-skin .vehicle-reference-card .lookup-stack {
  gap: 12px;
}

body.v4-skin .vehicle-reference-card .lookup-stack > .field.nextgen-field,
body.v4-skin .vehicle-reference-card .lookup-stack > .selected-reference-card,
body.v4-skin .vehicle-reference-card .lookup-stack > .inline-actions {
  width: min(100%, 520px);
  margin-inline: auto;
}

body.v4-skin .vehicle-reference-card .lookup-stack > .field.nextgen-field input {
  width: 100%;
}

body.v4-skin .selected-reference-card-compact {
  position: relative;
  display: grid;
  justify-content: center;
  justify-items: center;
  min-height: 76px;
  padding: 16px 54px 16px 22px;
  text-align: center;
}

body.v4-skin .selected-reference-card-compact > div {
  display: grid;
  justify-items: center;
  gap: 4px;
  min-width: 0;
}

body.v4-skin .selected-reference-card-compact strong {
  font-family: var(--v3-sans);
  font-size: 1rem;
  font-weight: 650;
  line-height: 1.18;
}

body.v4-skin .selected-reference-card-compact p {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.35;
}

body.v4-skin .selected-brand-card {
  min-height: 72px;
}

body.v4-skin .selected-model-card {
  min-height: 82px;
}

body.v4-skin .selected-model-card .vehicle-model-selected-title {
  font-size: 0.96rem;
  font-weight: 620;
}

body.v4-skin .selected-model-card p {
  max-width: 32ch;
}

body.v4-skin .selected-model-card .soft-pill {
  justify-self: center;
  margin-top: 6px;
}

body.v4-skin .selection-check {
  position: absolute;
  right: 14px;
  bottom: 14px;
  display: inline-grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background: #18a957;
  color: #fff;
  font-size: 16px;
  font-weight: 900;
  line-height: 1;
  box-shadow: 0 10px 20px rgba(24, 169, 87, 0.18);
}

body.v4-skin .municipality-selected-card {
  position: relative;
  justify-content: center;
  min-height: 64px;
  padding: 14px 54px 14px 22px;
  text-align: center;
}

body.v4-skin .municipality-selected-main {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
  min-width: 0;
}

body.v4-skin .municipality-selected-main strong {
  font-size: 1rem;
  line-height: 1.15;
}

body.v4-skin .municipality-code-inline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 24px;
  padding: 3px 9px;
  border-radius: 999px;
  border: 1px solid var(--v3-blue-soft);
  background: var(--v3-blue-tint);
  color: var(--v3-blue);
  font-family: var(--v3-mono);
  font-size: 0.82rem;
  font-weight: 700;
}

.wizard-site-footer {
  margin-top: 0;
  border-top: 1px solid rgba(15, 31, 92, 0.1);
  background: #0f1f5c;
  color: rgba(255, 255, 255, 0.72);
}

.wizard-footer-inner {
  width: min(1120px, calc(100% - 40px));
  margin: 0 auto;
  padding: 34px 0;
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto auto;
  align-items: center;
  gap: 22px;
}

.wizard-footer-brand {
  display: grid;
  gap: 10px;
}

.wizard-footer-brand .wizard-brand {
  justify-content: flex-start;
  color: #fff;
}

.wizard-footer-brand .wizard-brand-word {
  color: #fff;
}

.wizard-footer-brand p,
.wizard-footer-note {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.5;
}

.wizard-footer-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 14px 18px;
}

.wizard-footer-links a {
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.92rem;
  font-weight: 700;
  text-decoration: none;
}

.wizard-footer-links a:hover {
  color: #fff;
}

.wizard-footer-note {
  justify-self: end;
  white-space: nowrap;
}

@media (max-width: 820px) {
  .wizard-footer-inner {
    grid-template-columns: 1fr;
    justify-items: start;
  }

  .wizard-footer-links {
    justify-content: flex-start;
  }

  .wizard-footer-note {
    justify-self: start;
    white-space: normal;
  }
}
