:root {
  --bg: #ffffff;
  --bg-subtle: #f3f7f8;
  --surface: #ffffff;
  --text: #16242e;
  --body: #41525f;
  --muted: #5a6b78;
  --border: #e4eaee;
  --border-soft: #eef2f4;
  --primary: #01BCD6;
  --primary-20: rgba(1, 188, 214, 0.2);
  --teaser-bg: rgba(202, 244, 247, 0.4);
  --question-active-bg: rgba(202, 244, 247, 0.18);
  --primary-hover: #02a6bd;
  --primary-deep: #067585;
  --primary-soft: #e3f8fb;
  --primary-muted: #aee6ef;
  --primary-ring: rgba(1, 188, 214, 0.24);
  --accent: #FF9900;
  --accent-10: rgba(255, 153, 0, 0.1);
  --accent-90: rgba(255, 153, 0, 0.9);
  --accent-hover: #e88a00;
  --accent-soft: #fff4e0;
  --accent-deep: #b86e00;
  --success: #067585;
  --success-soft: #e3f8fb;
  --warn: #b46108;
  --warn-soft: #fff3e2;
  --error: #d32f2f;
  --error-soft: #fef2f2;
  --radius: 12px;
  --radius-lg: 16px;
  --font: -apple-system, BlinkMacSystemFont, "PingFang SC", "Helvetica Neue", "Microsoft YaHei", Arial, sans-serif;
  --shadow: 0 1px 2px rgba(20, 32, 43, 0.04), 0 1px 3px rgba(20, 32, 43, 0.05);
  --shadow-lg: 0 6px 20px rgba(20, 32, 43, 0.06), 0 1px 4px rgba(20, 32, 43, 0.05);
  --shadow-accent: 0 6px 18px rgba(1, 188, 214, 0.26);
  --transition: 200ms ease;

  /* Typography scale for product UI with fixed rem */
  --text-xs: 0.75rem;
  --text-sm: 0.8125rem;
  --text-base: 0.875rem;
  --text-md: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --leading-tight: 1.35;
  --leading-normal: 1.5;
  --leading-relaxed: 1.65;

  /* Spacing scale */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --content-max: 880px;

  /* 录入控件 */
  --input-height: 44px;
  --input-height-compact: 44px;
  --input-pad-x: 14px;
  --input-pad-y: 10px;
  --input-border-color: rgba(1, 188, 214, 0.18);
  --input-border: 1px solid var(--input-border-color);
  --input-border-focus: rgba(1, 188, 214, 0.46);
  --input-radius: 12px;
  --input-bg: linear-gradient(180deg, #ffffff 0%, #f8fcfd 100%);
  --input-shadow:
    0 1px 2px rgba(20, 32, 43, 0.03),
    0 6px 18px -10px rgba(20, 32, 43, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.96);
  --input-shadow-focus:
    0 2px 12px -3px rgba(1, 188, 214, 0.28),
    0 0 0 3px var(--primary-ring),
    inset 0 1px 0 rgba(255, 255, 255, 0.96);
  --input-shadow-active:
    0 1px 2px rgba(20, 32, 43, 0.04),
    inset 0 1px 3px rgba(20, 32, 43, 0.06);
  --input-placeholder: #9aa6b2;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

h1, h2, h3 {
  text-wrap: balance;
}

.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 1000;
  padding: 10px 16px;
  background: var(--primary);
  color: #fff;
  font-weight: 600;
  border-radius: 0 0 var(--radius) 0;
  text-decoration: none;
}

.skip-link:focus {
  left: 0;
}

body {
  font-family: var(--font);
  font-size: var(--text-base);
  background: var(--bg);
  color: var(--text);
  line-height: var(--leading-relaxed);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  overflow-x: clip;
}

#app,
.main,
.form-card,
.hero-inner {
  width: 100%;
  max-width: var(--content-max);
}

#app {
  margin-inline: auto;
  width: 100%;
  max-width: var(--content-max);
}

.main {
  width: 100%;
  max-width: var(--content-max);
  margin: var(--space-4) auto 48px;
  padding-inline: var(--space-4);
}

@media (max-width: 640px) {
  .main { margin-top: var(--space-3); padding-bottom: 100px; }
}

/* Grid/flex children must shrink so text can wrap instead of overflowing */
.field-grid > *,
.hero-question-grid > *,
.question-featured > *,
.career-mode-toggle > *,
.segment-row-grid > *,
[class*="field-grid"] > * {
  min-width: 0;
}

p, li, label, summary, .field-hint, .step-intro, .form-section-lead {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.hidden { display: none !important; }

.noscript-banner {
  background: #fef2f2;
  color: #b91c1c;
  padding: 12px 20px;
  text-align: center;
  font-size: 14px;
}

.hero {
  position: relative;
  overflow: hidden;
  background: var(--bg);
  color: var(--text);
  padding: clamp(28px, 6vw, 48px) 20px clamp(32px, 5vw, 44px);
  border-bottom: 1px solid var(--border-soft);
}

.hero-accent-bar {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--primary-deep) 0%, var(--primary) 100%);
  pointer-events: none;
}

.hero::before {
  display: none;
}

.hero-inner { position: relative; max-width: 880px; margin: 0 auto; z-index: 1; }

.hero-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  background: var(--bg-subtle);
  border: 1px solid var(--border);
  padding: 6px 12px;
  border-radius: 999px;
  color: var(--body);
}

.badge-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

.badge-dot-cyan { background: var(--primary); }
.badge-dot-amber { background: var(--accent); }

.hero-eyebrow {
  margin: 0 0 10px;
  font-size: var(--text-sm);
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--primary);
}

.hero-title {
  font-size: var(--text-2xl);
  font-weight: 800;
  line-height: var(--leading-tight);
  letter-spacing: -0.02em;
  color: var(--text);
}

@media (min-width: 641px) {
  .hero-title {
    font-size: 2.125rem;
  }
}

.hero-line { display: block; }

.hero-highlight {
  display: block;
  margin-top: 2px;
  color: var(--accent);
}

.hero-scope-hint {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 14px 0 0;
  padding: 9px 16px;
  font-size: var(--text-md);
  font-weight: 700;
  line-height: var(--leading-normal);
  letter-spacing: 0.01em;
  color: var(--primary);
  background: var(--primary-soft);
  border: 1px solid var(--primary-muted);
  border-radius: 999px;
  box-shadow: 0 1px 0 rgba(1, 188, 214, 0.08);
}

.hero-scope-hint::before {
  content: "";
  flex: none;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--primary);
  box-shadow: 0 0 0 3px rgba(1, 188, 214, 0.18);
}

.hero-lead {
  margin-top: 14px;
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--body);
  max-width: 42rem;
}

.hero-lead strong { color: var(--text); font-weight: 700; }

.hero-questions-panel {
  margin-top: 20px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.hero-questions-head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 6px 12px;
  margin-bottom: 14px;
}

.hero-questions-head strong {
  font-size: 14px;
  color: var(--primary);
}

.hero-questions-head span {
  font-size: 12px;
  color: var(--muted);
}

.hero-q-section-label {
  margin: 0 0 10px;
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.03em;
  color: var(--accent-deep);
}

.hero-q-section-label-muted {
  color: var(--muted);
}

.hero-q-section-label + .hero-question-tags {
  margin-top: 0;
}

.hero-question-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}

.hero-q-card {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  width: 100%;
  min-height: 72px;
  padding: 12px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--text);
  font-family: inherit;
  text-align: left;
  cursor: pointer;
  transition: border-color var(--transition), background var(--transition), box-shadow var(--transition), transform var(--transition);
}

.hero-q-card:hover,
.hero-q-card:focus-visible {
  border-color: var(--primary);
  background: var(--primary-soft);
  box-shadow: var(--shadow-lg);
  outline: none;
}

.hero-q-card:active { transform: scale(0.98); }

.hero-q-icon {
  display: none;
}

.hero-q-body {
  flex: 1;
  min-width: 0;
}

.hero-q-body strong {
  display: block;
  font-size: var(--text-sm);
  line-height: var(--leading-tight);
  margin-bottom: 4px;
  color: var(--text);
}

.hero-q-body span {
  display: block;
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
  color: var(--muted);
}

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

.hero-q-tag {
  padding: 7px 12px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--surface);
  color: var(--body);
  font-family: inherit;
  font-size: 12px;
  line-height: 1.3;
  cursor: pointer;
  transition: border-color var(--transition), background var(--transition), color var(--transition), transform var(--transition);
}

.hero-q-tag:hover,
.hero-q-tag:focus-visible {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--accent-deep);
  outline: none;
}

.hero-more-wrap {
  margin-top: 12px;
  border: 1px dashed var(--border);
  border-radius: var(--radius);
  padding: 10px 12px;
  background: var(--surface);
}

.hero-more-wrap summary {
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  color: var(--primary);
  list-style: none;
}

.hero-more-wrap summary::-webkit-details-marker { display: none; }

.hero-more-wrap[open] summary {
  margin-bottom: 10px;
}

.hero-more-wrap .hero-question-tags {
  max-height: 140px;
  overflow-y: auto;
}

.form-section {
  margin-top: 20px;
}

.form-section-core {
  margin-top: 16px;
  padding: 16px;
  background: var(--bg-subtle);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-lg);
}

.form-section-head {
  margin-bottom: 12px;
}

.form-section-title {
  font-size: var(--text-md);
  font-weight: 700;
  color: var(--text);
  margin: 0;
  line-height: var(--leading-tight);
}

.form-section-lead {
  margin: var(--space-1) 0 0;
  font-size: var(--text-sm);
  color: var(--body);
  line-height: var(--leading-normal);
}

.form-section-details {
  margin-top: 12px;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
}

.form-section-details summary {
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  color: var(--primary);
  list-style: none;
}

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

.form-section-details[open] summary {
  margin-bottom: 10px;
}

.form-section-details .form-section-lead {
  margin-bottom: 12px;
}

.field-grid-core {
  gap: 14px 16px;
}

.gap-section.form-section {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
}

.gap-section .form-section-head {
  margin-bottom: 10px;
}

.gap-section .sub-section-title {
  display: none;
}

.matrix-scroll-hint {
  display: none;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--body);
  padding: 8px 12px;
  margin-bottom: 8px;
  background: var(--bg-subtle);
  border: 1px solid var(--border-soft);
  border-radius: 10px;
}

.matrix-scroll-icon {
  font-weight: 700;
  flex-shrink: 0;
}

@media (max-width: 640px) {
  .matrix-scroll-hint:not(.hidden) {
    display: flex;
  }

  .table-wrap.matrix-wrap {
    max-height: min(58vh, 380px);
    box-shadow: inset -14px 0 14px -12px rgba(21, 32, 43, 0.06);
  }

  .matrix-table .corner,
  .matrix-table .row-head {
    min-width: 72px;
    max-width: 72px;
  }

  .matrix-cell {
    min-width: 52px;
    padding: 6px 4px;
  }

  .cell-monthly { font-size: 11px; }
  .cell-total { font-size: 9px; }

  .field-grid-core {
    grid-template-columns: 1fr;
  }

  .field-grid-core .span-2 {
    grid-column: span 1;
  }
}

@media (min-width: 641px) {
  .field-grid-core {
    grid-template-columns: 1fr 1fr;
  }
}

.hero-cta {
  display: block;
  width: 100%;
  max-width: 360px;
  margin-top: 22px;
  padding: 16px 24px;
  border: none;
  border-radius: var(--radius);
  background: var(--primary);
  color: var(--surface);
  font-family: inherit;
  font-size: 17px;
  font-weight: 800;
  cursor: pointer;
  box-shadow: var(--shadow-accent);
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
}

.hero-cta:hover {
  background: var(--primary-hover);
}

.hero-cta:active {
  transform: scale(0.98);
}

body.flow-started .hero-cta-bar,
body.flow-started #hero-cta,
body.flow-started #data-version {
  display: none !important;
}

.hero-trust {
  margin-top: 14px;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.5;
}

.data-badge { margin-top: var(--space-3); font-size: var(--text-xs); color: var(--muted); line-height: var(--leading-normal); }

/* legacy hero classes removed */
.hero-tag, .hero-desc, .value-cards, .value-card, .hero-outcomes, .outcome-num { display: none; }

.disclaimer {
  padding: 10px 20px;
  font-size: var(--text-sm);
  color: var(--accent-deep);
  background: var(--accent-soft);
  text-align: center;
  border-bottom: 1px solid #ffd699;
}

/* 查数指南 */
.lookup-guide {
  margin-bottom: 14px;
  border: 1.5px solid var(--primary-muted);
  border-radius: var(--radius);
  background: linear-gradient(180deg, var(--primary-soft) 0%, var(--surface) 100%);
  overflow: hidden;
}

.lookup-guide-summary {
  padding: 10px 12px;
  font-size: 13px;
  font-weight: 700;
  color: var(--primary);
  cursor: pointer;
  list-style: none;
  user-select: none;
}

.lookup-guide-summary::-webkit-details-marker { display: none; }

.lookup-guide[open] .lookup-guide-summary {
  border-bottom: 1px solid var(--border);
  background: var(--primary-soft);
}

.lookup-guide-body { padding: 10px 12px 12px; }

.lookup-guide-lead {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.5;
  margin-bottom: 8px;
}

.lookup-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  table-layout: fixed;
}

.lookup-table th,
.lookup-table td {
  padding: 10px 12px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  vertical-align: top;
  line-height: 1.5;
}

.lookup-table th:first-child,
.lookup-table td:first-child {
  width: 25%;
}

.lookup-table th:last-child,
.lookup-table td:last-child {
  width: 75%;
}

.lookup-table th {
  background: #f8fafc;
  font-weight: 600;
}

.lookup-table tr:last-child td,
.lookup-table tr:last-child th { border-bottom: none; }

@media (max-width: 640px) {
  .lookup-table th:first-child,
  .lookup-table td:first-child { width: 25%; font-size: 12px; }
  .lookup-table th:last-child,
  .lookup-table td:last-child { width: 75%; font-size: 12px; }
}

.field-label-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-1) var(--space-2);
  margin-bottom: var(--space-1);
}

.field-label-row label {
  margin: 0;
  min-width: 0;
  flex: 1 1 8rem;
}

.field-hint-inline {
  font-weight: 400;
  color: var(--muted);
  font-size: var(--text-xs);
}

.field-lookup {
  margin: 0;
  font-size: var(--text-xs);
  flex-shrink: 0;
}

.field-lookup summary {
  display: inline-block;
  color: var(--primary);
  font-weight: 600;
  cursor: pointer;
  padding: 0;
  list-style: none;
}

.field-lookup summary::-webkit-details-marker { display: none; }

.field-lookup summary::before {
  content: "? ";
  font-size: 10px;
}

.field-lookup p {
  margin-top: 6px;
  padding: 8px 10px;
  background: var(--primary-soft);
  border-radius: 8px;
  border: 1px solid var(--primary-muted);
  color: var(--body);
  line-height: 1.55;
  font-size: 12px;
}

.field-lookup p strong { color: var(--text); }

.province-source-banner {
  display: flex;
  align-items: flex-start;
  gap: 7px;
  width: 100%;
  margin: 6px 0 0;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.45;
  color: var(--primary);
}

.province-source-banner::before {
  content: "i";
  flex: none;
  width: 14px;
  height: 14px;
  margin-top: 2px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--primary);
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  font-style: italic;
  font-family: Georgia, "Times New Roman", serif;
  line-height: 1;
}

.wizard-progress {
  display: flex;
  align-items: center;
  margin-bottom: 12px;
  padding: 10px 12px;
  background: var(--bg-subtle);
  border-radius: var(--radius-lg);
  border: 0;
  box-shadow: none;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x proximity;
}

@media (max-width: 640px) {
  .wizard-progress {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 6px;
    padding: var(--space-3);
    margin-left: 0;
    margin-right: 0;
    overflow-x: visible;
    scroll-snap-type: none;
  }
  .progress-line { display: none; }
  .progress-step {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 6px;
    min-width: 0;
    flex-shrink: 1;
    padding: 6px 4px;
    margin: 0;
    scroll-snap-align: unset;
  }
  .step-num {
    width: 28px;
    height: 28px;
    font-size: var(--text-xs);
  }
  .wizard-progress .step-text strong {
    font-size: 11px;
    line-height: 1.25;
  }
  .step-text small { display: none; }
}

.progress-step {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
  opacity: 0.45;
  border: none;
  background: transparent;
  font-family: inherit;
  text-align: left;
  padding: 4px 6px;
  margin: -4px -6px;
  border-radius: var(--radius);
  transition: opacity var(--transition), background var(--transition);
}

.progress-step.done {
  cursor: pointer;
  opacity: 1;
}

.progress-step.done:hover {
  background: var(--bg-subtle);
}

.progress-step.done:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.progress-step:not(.done):not(.active) {
  cursor: default;
  pointer-events: none;
}

.progress-step.active,
.progress-step.done {
  opacity: 1;
}

.progress-step.done .step-num { background: var(--primary); }
.progress-step.active .step-num { background: var(--accent-90); box-shadow: none; }

.step-num {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--muted);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
}

.step-text strong { display: block; font-size: var(--text-sm); line-height: var(--leading-tight); }
.step-text small { font-size: var(--text-xs); color: var(--muted); line-height: var(--leading-normal); }

.progress-line { flex: 1; min-width: 20px; height: 2px; background: var(--border); margin: 0 8px; }

.form-card {
  background: var(--surface);
  border-radius: var(--radius-lg);
  padding: 18px 16px;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--border-soft);
}

.step-panel {
  display: none;
  animation: step-enter 220ms ease-out;
}

.step-panel.active { display: block; }

@keyframes step-enter {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .step-panel { animation: none; }
}

.step-header { margin-bottom: var(--space-3); }
.step-header h2 { font-size: var(--text-lg); font-weight: 700; line-height: var(--leading-tight); }

.step-intro {
  margin-top: var(--space-2);
  font-size: var(--text-sm);
  color: var(--body);
  line-height: var(--leading-normal);
  padding: var(--space-3);
  background: var(--primary-soft);
  border-radius: 8px;
  border: 1px solid var(--primary-muted);
}

.field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3) var(--space-4);
}

.field-grid-tight { gap: var(--space-3); }

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

.field-hint-compact {
  display: flex;
  align-items: flex-start;
  gap: 7px;
  margin: 2px 0 0;
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
}

.field-hint-compact::before {
  content: "?";
  flex: none;
  width: 14px;
  height: 14px;
  margin-top: 1px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--primary);
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  line-height: 1;
}

@media (max-width: 640px) {
  .field-grid,
  .field-grid-tight,
  .field-grid-3,
  .field-grid-core {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }
  .span-2,
  #female-type-field {
    grid-column: 1 / -1;
  }
  .form-card { padding: var(--space-4) var(--space-3); }
}
.span-2 { grid-column: span 2; }

.field { display: flex; flex-direction: column; gap: var(--space-1); position: relative; min-width: 0; }
.field label { font-size: var(--text-sm); font-weight: 600; line-height: var(--leading-tight); }
.field-hint {
  display: flex;
  align-items: flex-start;
  gap: 7px;
  font-size: var(--text-xs);
  color: var(--muted);
  line-height: var(--leading-normal);
  margin-bottom: 0;
}

.field-hint::before {
  content: "?";
  flex: none;
  width: 14px;
  height: 14px;
  margin-top: 1px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--primary);
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  line-height: 1;
}
.field-error { font-size: var(--text-xs); color: #dc2626; margin-top: 2px; line-height: var(--leading-normal); }

.field input,
.field select {
  width: 100%;
  min-height: var(--input-height);
  padding: var(--input-pad-y) var(--input-pad-x);
  border: var(--input-border);
  border-radius: var(--input-radius);
  font-family: inherit;
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  background: var(--input-bg);
  color: var(--text);
  appearance: auto;
  -webkit-appearance: menulist;
  position: relative;
  z-index: 2;
  box-sizing: border-box;
  box-shadow: var(--input-shadow);
  transition: border-color var(--transition), box-shadow var(--transition);
}

.field input::placeholder {
  color: var(--input-placeholder);
}

.field input { cursor: text; }
.field select { cursor: pointer; }

.field input:focus,
.field select:focus {
  outline: none;
  border-color: var(--input-border-focus);
  box-shadow: var(--input-shadow-focus);
}

.field input.field-invalid,
.field select.field-invalid { border-color: #dc2626; }

/* 数字录入：统一纯文本框外观，隐藏浏览器 stepper */
#app input[type="number"] {
  -moz-appearance: textfield;
  appearance: textfield;
  -webkit-appearance: textfield;
}

#app input[type="number"]::-webkit-outer-spin-button,
#app input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.preview-box { margin-top: 24px; padding: 18px 20px; background: var(--bg); border-radius: 10px; font-size: 14px; }
.preview-box h3 { font-size: 14px; margin-bottom: 10px; }
.preview-box ul { padding-left: 20px; color: var(--muted); }
.preview-box li { margin-bottom: 6px; }

.form-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
}

.btn-flow-back {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  gap: 0;
  color: #01BCD6;
  font-weight: 600;
  text-align: center;
}

@media (max-width: 640px) {
  .form-actions {
    position: sticky;
    bottom: 0;
    z-index: 100;
    margin-top: var(--space-5);
    margin-left: calc(-1 * var(--space-3));
    margin-right: calc(-1 * var(--space-3));
    padding: var(--space-3) var(--space-3) max(var(--space-3), env(safe-area-inset-bottom));
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(10px);
    border-top: 1px solid var(--border);
    box-shadow: 0 -6px 24px rgba(15, 23, 42, 0.1);
  }
  .form-actions .btn { flex: 1; min-height: 48px; font-size: var(--text-md); }
  .form-actions .btn-ghost { flex: 0 0 auto; min-width: 88px; }
  .action-right { flex: 1; justify-content: flex-end; min-width: 0; }
  .step-indicator { font-size: var(--text-xs); white-space: nowrap; }
}

.action-right { display: flex; align-items: center; gap: 12px; }
.step-indicator { font-size: 13px; color: var(--muted); }

.btn {
  padding: 12px 22px;
  min-height: 44px;
  border-radius: var(--radius);
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  touch-action: manipulation;
  border: none;
  transition: background var(--transition), border-color var(--transition), transform var(--transition);
}

.btn-primary { background: var(--primary); color: #fff; }
.btn-primary:hover { background: var(--primary-hover); }
.btn-primary:focus-visible,
.btn-accent:focus-visible,
.btn-ghost:focus-visible,
.btn-secondary:focus-visible,
.category-tab:focus-visible,
.question-card:focus-visible,
.hero-cta:focus-visible {
  outline: 2px solid var(--primary-deep);
  outline-offset: 2px;
}

.btn-accent:focus-visible {
  outline-color: var(--accent-deep);
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.btn-accent { background: var(--accent); color: #fff; padding: 12px 28px; font-size: 15px; }
.btn-accent:hover { background: var(--accent-hover); }
.btn-ghost, .btn-secondary { background: var(--surface); color: var(--text); border: 1.5px solid var(--border); }
.btn-ghost:hover, .btn-secondary:hover { background: var(--bg-subtle); border-color: var(--primary-muted); }
.btn-recalc { margin-top: 20px; width: 100%; }

.result-empty { text-align: center; padding: 48px 20px; color: var(--muted); }
.result-empty p { font-size: 16px; font-weight: 600; color: var(--text); }

.summary-card {
  margin-bottom: 14px;
}

.matrix-summary {
  padding: 16px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
}

.matrix-summary-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.matrix-summary-eyebrow {
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
}

.matrix-summary-tag {
  flex: none;
  padding: 3px 8px;
  border-radius: 999px;
  background: var(--bg-subtle);
  border: 1px solid var(--border-soft);
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
  white-space: nowrap;
}

.matrix-summary-note {
  margin: 0 0 12px;
  padding: 8px 10px;
  border-radius: 8px;
  background: var(--bg-subtle);
  font-size: 12px;
  line-height: 1.5;
  color: var(--body);
}

.matrix-summary-scenario {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin-bottom: 14px;
}

.matrix-scenario-chip {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  background: var(--primary-soft);
  border: 1px solid var(--primary-muted);
  font-size: 13px;
  font-weight: 700;
  color: var(--primary);
}

.matrix-scenario-sep {
  color: var(--muted);
  font-weight: 600;
}

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

.matrix-metric {
  padding: 10px;
  border-radius: 10px;
  background: var(--bg-subtle);
  border: 1px solid var(--border-soft);
}

.matrix-metric-primary {
  background: linear-gradient(180deg, #f7fdfe 0%, var(--primary-soft) 100%);
  border-color: var(--primary-muted);
}

.matrix-metric-label {
  display: block;
  margin-bottom: 4px;
  font-size: 11px;
  line-height: 1.35;
  color: var(--muted);
}

.matrix-metric-value {
  display: flex;
  flex-direction: row;
  align-items: baseline;
  flex-wrap: nowrap;
  gap: 2px;
  line-height: 1.2;
  font-weight: 700;
  color: var(--text);
}

.matrix-metric-num {
  font-size: 14px;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.matrix-metric-primary .matrix-metric-num {
  font-size: 17px;
  color: var(--primary);
}

.matrix-metric-unit {
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
  white-space: nowrap;
  flex: none;
}

.matrix-metric-primary .matrix-metric-unit {
  color: var(--primary-deep);
}

.matrix-metric-value small {
  margin-left: 1px;
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
}

.matrix-summary-empty-text {
  margin: 8px 0 0;
  font-size: 14px;
  line-height: 1.6;
  color: var(--body);
}

.break-even-box {
  margin-bottom: 16px;
}

.matrix-breakeven {
  padding: 16px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
}

.matrix-breakeven-head {
  margin-bottom: 12px;
}

.matrix-breakeven-title {
  margin: 0 0 4px;
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
}

.matrix-breakeven-lead {
  margin: 0;
  font-size: 12px;
  line-height: 1.5;
  color: var(--muted);
}

.matrix-breakeven-grid {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid var(--border-soft);
  border-radius: 10px;
  overflow: hidden;
}

.matrix-breakeven-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 40px;
  padding: 8px 12px;
  background: #fff;
  border-bottom: 1px solid var(--border-soft);
}

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

.matrix-breakeven-row:nth-child(even) {
  background: var(--bg-subtle);
}

.matrix-breakeven-life {
  flex: none;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}

.matrix-breakeven-answer {
  font-size: 13px;
  font-weight: 700;
  color: var(--primary);
  text-align: right;
}

.matrix-breakeven-row.is-later-better .matrix-breakeven-answer {
  font-weight: 600;
  color: var(--muted);
}

.matrix-breakeven-foot {
  margin: 10px 0 0;
  font-size: 12px;
  line-height: 1.5;
  color: var(--muted);
}

.result-section-title { font-size: 16px; font-weight: 700; margin-bottom: 4px; }
.table-legend { font-size: 12px; color: var(--muted); margin-bottom: 12px; }

.table-wrap { overflow-x: auto; border: 1px solid var(--border); border-radius: 10px; }

.result-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.result-table th, .result-table td { padding: 12px 14px; text-align: left; border-bottom: 1px solid var(--border); }
.result-table th { background: var(--bg); font-size: var(--text-xs); color: var(--muted); font-weight: 600; }
.result-table tr:last-child td { border-bottom: none; }
.result-table tr.recommended { background: var(--primary-soft); }
.result-table tr.recommended td:first-child::after { content: " 推荐"; color: var(--primary); font-size: var(--text-xs); }

.tag-ok { color: var(--success); font-weight: 600; }
.tag-no { color: #dc2626; font-weight: 600; }

.extra-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 20px; }
@media (max-width: 640px) { .extra-cards { grid-template-columns: 1fr; } }

.mini-card { background: var(--bg); border-radius: 10px; padding: 18px; font-size: 13px; }
.mini-card h4 { font-size: 14px; font-weight: 700; margin-bottom: 10px; }
.mini-card p { color: var(--muted); margin-bottom: 6px; }
.mini-card strong { color: var(--primary-deep); }

.warnings-box { margin-top: 16px; padding: 14px 16px; background: var(--warn-soft); border-radius: 10px; font-size: 13px; color: var(--warn); }
.warnings-box ul { margin-top: 8px; padding-left: 18px; }

.footer {
  text-align: center;
  padding: 24px 20px;
  font-size: 12px;
  color: var(--muted);
  background: var(--bg);
  border-top: 1px solid var(--border-soft);
}

.sub-section {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}

.sub-section h3 { font-size: 14px; margin-bottom: 6px; }

.compare-input-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 16px;
  align-items: start;
  margin-top: 12px;
}

.compare-col {
  background: var(--bg);
  padding: 16px;
  border-radius: 10px;
}

.compare-col strong { display: block; margin-bottom: 12px; font-size: 14px; }
.compare-col label { display: block; font-size: 12px; margin-top: 10px; margin-bottom: 4px; color: var(--muted); }
.compare-col input { width: 100%; padding: 8px 10px; border: 1px solid var(--border); border-radius: 8px; }

.compare-vs {
  align-self: center;
  font-weight: 700;
  color: var(--muted);
  padding-top: 40px;
}

.result-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--border);
}

.result-tab {
  padding: 10px 16px;
  border: none;
  background: none;
  font-family: inherit;
  font-size: 14px;
  cursor: pointer;
  color: var(--muted);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}

.result-tab.active { color: var(--primary); border-bottom-color: var(--primary); font-weight: 600; }

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

.matrix-legend {
  margin-bottom: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  background: var(--bg-subtle);
  border: 1px solid var(--border-soft);
  font-size: 12px;
  line-height: 1.5;
  color: var(--body);
}

.table-wrap.matrix-wrap {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: #fff;
  overflow: auto;
  max-width: 100%;
  max-height: min(56vh, 420px);
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  box-shadow: var(--shadow);
}

.matrix-table {
  width: max-content;
  min-width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 12px;
}

.matrix-table th,
.matrix-table td {
  border-right: 1px solid var(--border-soft);
  border-bottom: 1px solid var(--border-soft);
  vertical-align: middle;
}

.matrix-table tr:last-child th,
.matrix-table tr:last-child td {
  border-bottom: 0;
}

.matrix-table th:last-child,
.matrix-table td:last-child {
  border-right: 0;
}

.matrix-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  padding: 8px 4px;
  background: var(--bg-subtle);
  text-align: center;
  font-weight: 600;
}

.matrix-table .corner {
  left: 0;
  z-index: 4;
  min-width: 78px;
  max-width: 78px;
  padding: 10px 8px;
  text-align: left;
  vertical-align: bottom;
  background: var(--bg-subtle);
  box-shadow: 4px 0 8px -4px rgba(21, 32, 43, 0.08);
}

.matrix-corner {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.matrix-corner-y,
.matrix-corner-x {
  display: block;
  font-size: 10px;
  line-height: 1.35;
  font-weight: 600;
  color: var(--muted);
}

.matrix-h-num {
  display: block;
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  font-variant-numeric: tabular-nums;
  line-height: 1.2;
}

.matrix-h-suffix {
  display: block;
  margin-top: 1px;
  font-size: 10px;
  font-weight: 500;
  color: var(--muted);
  line-height: 1.2;
}

.matrix-table .row-head {
  position: sticky;
  left: 0;
  z-index: 1;
  min-width: 78px;
  max-width: 78px;
  padding: 8px 10px;
  background: #fff;
  text-align: left;
  box-shadow: 4px 0 8px -4px rgba(21, 32, 43, 0.08);
}

.matrix-row-label {
  display: flex;
  align-items: baseline;
  gap: 1px;
}

.matrix-row-num {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

.matrix-row-suffix {
  font-size: 11px;
  font-weight: 500;
  color: var(--muted);
}

.matrix-row-tag {
  display: inline-block;
  margin-top: 4px;
  padding: 1px 6px;
  border-radius: 999px;
  background: var(--primary-soft);
  border: 1px solid var(--primary-muted);
  color: var(--primary-deep);
  font-size: 9px;
  font-weight: 600;
  line-height: 1.35;
  white-space: nowrap;
}

.matrix-cell {
  min-width: 56px;
  padding: 7px 5px;
  cursor: pointer;
  background: #fff;
  transition: background 0.15s ease-out;
  text-align: center;
}

.matrix-table tbody tr:nth-child(even) .matrix-cell {
  background: #fafcfd;
}

.matrix-cell-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
}

.cell-monthly {
  font-size: 12px;
  font-weight: 700;
  color: var(--text);
  font-variant-numeric: tabular-nums;
  line-height: 1.2;
  white-space: nowrap;
}

.cell-total {
  font-size: 10px;
  font-weight: 500;
  color: var(--muted);
  line-height: 1.2;
  white-space: nowrap;
}

.matrix-cell:hover:not(.cell-invalid) {
  background: #eefafb !important;
}

.matrix-cell:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: -2px;
}

.cell-best {
  background: var(--primary-soft) !important;
  box-shadow: inset 0 0 0 2px var(--primary);
}

.cell-best .cell-monthly {
  color: var(--primary-deep);
}

.cell-breakeven:not(.cell-best) {
  box-shadow: inset 0 0 0 1px var(--primary-muted);
}

.cell-invalid {
  opacity: 0.32;
  pointer-events: none;
}

.cell-anchor:not(.cell-best) {
  background: #fff !important;
  box-shadow: inset 0 0 0 1px var(--primary-muted);
}

.cell-detail {
  margin-top: 12px;
  padding: 16px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: 14px;
}

.cell-detail h4 {
  margin: 0 0 12px;
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.5;
}

.detail-grid {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 8px 16px;
}

.detail-split { margin-top: 10px; font-size: 12px; color: var(--muted); }

.compare-summary {
  padding: 14px 16px;
  background: var(--primary-soft);
  border-radius: var(--radius);
  margin-bottom: 16px;
  font-size: 14px;
  line-height: 1.7;
}

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

.compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.compare-table th,
.compare-table td {
  padding: 12px 14px;
  border: 1px solid var(--border);
  text-align: left;
}

.compare-table th { background: var(--bg); }

.compare-section {
  margin-bottom: 28px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--border);
}

.compare-section:last-child { border-bottom: none; margin-bottom: 0; }

.compare-section h3 { font-size: 15px; margin-bottom: 6px; }

.compare-tab-hint { margin-bottom: 16px; }

.compare-inline-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 148px), 1fr));
  gap: var(--space-3);
  margin: var(--space-3) 0 var(--space-4);
}

.compare-inline-grid label {
  display: block;
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 4px;
}

.compare-inline-grid input {
  width: 100%;
  min-height: var(--input-height-compact);
  padding: var(--input-pad-y) var(--input-pad-x);
  border: var(--input-border);
  border-radius: var(--input-radius);
  background: var(--input-bg);
  box-shadow: var(--input-shadow);
  box-sizing: border-box;
}

.btn-pick {
  margin-top: 10px;
  margin-right: 8px;
  padding: 6px 12px;
  font-size: 12px;
  border: 1px solid var(--primary);
  background: #fff;
  color: var(--primary);
  border-radius: 6px;
  cursor: pointer;
}

.btn-pick:hover { background: var(--primary-soft); }

.verdict-early { color: var(--success); font-weight: 600; }
.verdict-late { color: var(--primary-deep); font-weight: 600; }
.verdict-equal { color: var(--muted); }

.rank-best { background: var(--primary-soft); font-weight: 600; }

.policy-banner {
  padding: 12px 16px;
  background: var(--primary-soft);
  border: 1px solid var(--primary-muted);
  border-radius: var(--radius);
  margin-bottom: 20px;
  font-size: 13px;
  line-height: 1.6;
}

.contribution-eligibility-banner {
  padding: 12px 16px;
  background: var(--success-soft);
  border: 1px solid var(--primary-muted);
  border-radius: var(--radius);
  margin-bottom: 20px;
  font-size: 13px;
  line-height: 1.6;
}

.contribution-eligibility-banner strong { color: var(--success); }
.contribution-eligibility-banner p { margin: 6px 0 0; }
.contribution-eligibility-banner .field-hint { margin-top: 8px; margin-bottom: 0; }

.career-mode-field { margin-bottom: 20px; }
.career-mode-field > .field-hint { margin-top: 12px; }
.career-mode-toggle {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 8px;
}
.career-mode-option {
  display: block;
  cursor: pointer;
  min-width: 0;
}
.career-mode-option input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}
.career-mode-card {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 48px;
  padding: 10px 12px;
  border: 2px solid var(--border);
  border-radius: 12px;
  background: #fff;
  transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
}
.career-mode-radio {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  border: 2px solid #cbd5e1;
  border-radius: 50%;
  background: #fff;
  position: relative;
}
.career-mode-radio::after {
  content: '';
  position: absolute;
  inset: 3px;
  border-radius: 50%;
  background: transparent;
  transition: background 0.15s;
}
.career-mode-label {
  flex: 1;
  min-width: 0;
  font-size: var(--text-sm);
  line-height: var(--leading-tight);
}

@media (max-width: 640px) {
  .career-mode-toggle {
    grid-template-columns: 1fr;
  }
  .career-mode-card {
    min-height: 44px;
  }
}
.career-mode-option input:checked + .career-mode-card {
  border-color: var(--primary);
  background: var(--primary-soft);
  box-shadow: 0 0 0 1px var(--primary-ring);
}
.career-mode-option input:checked + .career-mode-card .career-mode-radio {
  border-color: var(--primary);
}
.career-mode-option input:checked + .career-mode-card .career-mode-radio::after {
  background: var(--primary);
}
.career-mode-option input:focus-visible + .career-mode-card {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.career-segments {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 0;
}
.career-segment-row {
  padding: 10px 12px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 8px;
}
.segment-row-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 6px;
}
.segment-row-head strong { font-size: 13px; }
.btn-remove-segment {
  border: none;
  background: transparent;
  color: #dc2626;
  font-size: 13px;
  cursor: pointer;
  padding: 4px 8px;
}
.btn-remove-segment:disabled { color: var(--muted); cursor: not-allowed; }
#multi-career-fields #btn-add-segment {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 44px;
  margin-top: 16px;
  margin-bottom: 16px;
  box-sizing: border-box;
}
#multi-career-summary {
  margin-top: 0;
}
.segment-row-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 148px), 1fr));
  gap: var(--space-2);
}
.segment-row-grid .field { margin: 0; }
.segment-row-grid label { font-size: var(--text-xs); margin-bottom: 2px; display: block; }
.segment-row-grid input,
.segment-row-grid select {
  width: 100%;
  min-height: var(--input-height-compact);
  padding: var(--input-pad-y) var(--input-pad-x);
  border: var(--input-border);
  border-radius: var(--input-radius);
  font-size: var(--text-sm);
  background: var(--input-bg);
  box-shadow: var(--input-shadow);
  box-sizing: border-box;
}

.gap-fields-grid { margin-top: 12px; }
.gap-guidance-banner {
  margin-top: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--border-soft);
}
.gap-guidance-inner {
  padding: 12px 14px;
  border-radius: 12px;
  background: linear-gradient(180deg, #f4fcfd 0%, #fafefe 100%);
  border: 1px solid rgba(1, 188, 214, 0.12);
}
.gap-guidance-inner.is-warning {
  background: linear-gradient(180deg, #fff8f0 0%, #fffdf9 100%);
  border-color: rgba(255, 153, 0, 0.22);
}
.gap-guidance-title {
  margin: 0 0 10px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--primary);
}
.gap-guidance-summary {
  margin: 0;
  font-size: 13px;
  line-height: 1.55;
  color: var(--body);
}
.gap-guidance-summary strong { color: var(--text); font-weight: 700; }
.gap-guidance-alert {
  margin: 0 0 10px;
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(255, 153, 0, 0.1);
  font-size: 12px;
  line-height: 1.5;
  color: var(--accent-deep);
}
.gap-guidance-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.gap-guidance-metric {
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(1, 188, 214, 0.1);
}
.gap-guidance-metric span {
  display: block;
  font-size: 11px;
  line-height: 1.35;
  color: var(--muted);
}
.gap-guidance-metric strong {
  display: block;
  margin-top: 2px;
  font-size: 14px;
  line-height: 1.35;
  color: var(--text);
  font-weight: 700;
}
.gap-guidance-foot {
  margin: 10px 0 0;
  font-size: 12px;
  line-height: 1.5;
  color: var(--muted);
}
#btn-gap-compare { margin-top: 10px; }

.question-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px;
  margin-bottom: 24px;
}

.question-category-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}

.category-tab {
  padding: 8px 16px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: #fff;
  font-family: inherit;
  font-size: 13px;
  cursor: pointer;
  color: var(--muted);
}

.category-tab.active {
  background: var(--primary-soft);
  border-color: var(--primary);
  color: var(--primary);
  font-weight: 600;
}

.question-picker-compact {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  gap: 8px;
  padding: 0;
}

.question-picker-root {
  margin-bottom: 16px;
}

.question-choice-stage {
  display: grid;
  gap: var(--space-3);
}

.question-choice-stage .policy-banner,
.question-choice-stage .question-category-tabs,
.question-choice-stage .question-picker-root {
  margin-bottom: 0;
}

.question-choice-stage.field-invalid {
  padding: var(--space-3);
  border: 1.5px solid #dc2626;
  border-radius: var(--radius);
  background: #fff7f7;
}

.question-choice-stage > .field-error {
  margin: 0;
  padding: 10px 12px;
  border-radius: var(--radius);
  background: #fef2f2;
}

.question-spotlight {
  margin-bottom: 12px;
}

.question-spotlight-label {
  margin: 0 0 10px;
  font-size: 15px;
  font-weight: 700;
  color: var(--primary);
}

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

.question-card-featured {
  display: block;
  padding: 14px;
  border-radius: 14px;
  min-height: 88px;
}

.question-icon {
  flex-shrink: 0;
  font-size: 26px;
  line-height: 1;
  margin-top: 2px;
}

.question-card-body {
  flex: 1;
  min-width: 0;
}

.question-card-featured strong {
  font-size: 14px;
  line-height: 1.35;
  margin-bottom: 4px;
}

.question-hook {
  display: block;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.45;
  font-weight: 400;
}

.question-teaser {
  display: inline-block;
  margin-top: var(--space-2);
  padding: 3px 8px;
  border-radius: 999px;
  background: var(--teaser-bg);
  color: var(--primary-deep);
  font-size: var(--text-xs);
  font-weight: 700;
  max-width: 100%;
  line-height: var(--leading-tight);
}

.question-more-wrap {
  margin-top: 4px;
  border: 0;
  border-radius: 0;
  padding: 0;
  background: transparent;
}

.question-more-wrap summary {
  cursor: pointer;
  font-size: 13px;
  font-weight: 700;
  color: var(--primary);
  list-style: none;
  padding: 4px 0 10px;
}

.question-more-wrap summary::-webkit-details-marker { display: none; }

.question-more-wrap[open] summary {
  margin-bottom: 2px;
}

.question-more-wrap .question-picker-compact {
  max-height: none;
  overflow: visible;
  margin-bottom: 0;
}

.question-picker-compact .question-card,
.question-picker-compact .question-card-featured {
  display: block;
  width: 100%;
  min-width: 0;
  flex: none;
  padding: 14px;
  border-radius: 14px;
  min-height: 58px;
  text-align: left;
}

.question-picker-compact .question-card span,
.question-picker-compact .question-hook {
  display: block;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.45;
  font-weight: 400;
}

.question-picker-compact .question-card strong,
.question-picker-compact .question-card-featured strong {
  display: block;
  font-size: 14px;
  font-weight: 600;
  margin: 0 0 4px;
  line-height: 1.4;
  white-space: normal;
}

.question-workspace {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px;
  background: var(--bg-subtle);
  margin-top: 4px;
}

.question-data-fields {
  display: grid;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--border);
}

.question-data-fields > .lookup-guide,
.question-data-fields > .contribution-eligibility-banner,
.question-data-fields > .form-section,
.question-data-fields > details {
  margin-top: 0;
  margin-bottom: 0;
}

.workspace-head {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--border);
}

.account-balance-estimate {
  margin: 4px 0 8px;
  color: var(--primary);
  font-weight: 500;
}

.btn-link {
  display: inline-block;
  margin-top: 6px;
  padding: 0;
  border: none;
  background: none;
  font: inherit;
  font-size: 13px;
  color: var(--primary);
  text-decoration: underline;
  cursor: pointer;
}

.btn-link:hover {
  color: var(--primary);
}

.workspace-label {
  font-size: var(--text-xs);
  color: var(--muted);
  margin: 0 0 var(--space-1);
}

.workspace-head-main {
  flex: 1;
  min-width: 0;
}

.workspace-head h3 {
  margin: 0 0 var(--space-1);
  font-size: var(--text-lg);
  line-height: var(--leading-tight);
}

.workspace-subtitle {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--muted);
  line-height: var(--leading-normal);
}

.question-plain-intro {
  margin: 12px 0 0;
  padding: 12px 14px;
  background: var(--primary-soft);
  border: 1px solid var(--primary-muted);
  border-radius: var(--radius);
  font-size: 13px;
  line-height: 1.65;
  color: var(--text);
}

.compare-table .row-recommended {
  background: var(--primary-soft);
}
.compare-table .row-recommended td {
  font-weight: 600;
}
.compare-table .row-recommended td:first-child {
  color: var(--primary);
}

.btn-sm {
  padding: 6px 12px;
  font-size: 13px;
}

.workspace-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 16px;
  flex-wrap: wrap;
}

.workspace-action-hint {
  margin: 0;
}

.inline-answer {
  margin-top: 16px;
}

.inline-answer:not(.hidden) {
  animation: step-enter 220ms ease-out;
}

@media (prefers-reduced-motion: reduce) {
  .inline-answer:not(.hidden) { animation: none; }
}

.answer-eyebrow,
.answer-result-eyebrow {
  margin: 0 0 8px;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--primary);
}

.answer-panel {
  padding: 16px 18px;
  background: #f8fafc;
  border: 1px solid var(--border);
  border-radius: 12px;
}

.answer-main {
  margin: 0 0 12px;
  font-size: 16px;
  line-height: 1.65;
  color: var(--text);
}

.answer-main:last-child {
  margin-bottom: 0;
}

.answer-main strong {
  color: var(--primary);
  font-weight: 600;
}

.answer-list {
  margin: 0 0 12px;
  padding-left: 18px;
  line-height: 1.65;
  font-size: 14px;
}

.answer-list li {
  margin-bottom: 6px;
}

.answer-list li:last-child {
  margin-bottom: 0;
}

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

.answer-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.answer-table th,
.answer-table td {
  padding: 8px 10px;
  border-bottom: 1px solid var(--border);
  text-align: left;
}

.answer-table th {
  color: var(--muted);
  font-weight: 500;
  font-size: 12px;
}

.answer-table tr.row-best {
  background: var(--primary-soft);
  font-weight: 600;
}

.answer-tag-group {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 4px;
}

.answer-tag {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  line-height: 1.35;
  white-space: nowrap;
}

.answer-tag-recommend {
  background: var(--accent-90);
  color: #fff;
  box-shadow: none;
}

.answer-tag-original {
  background: #fff;
  color: var(--primary-deep);
  border: 1px solid var(--primary-muted);
}

.answer-tag-statutory {
  background: var(--primary-20);
  color: var(--primary-deep);
  border: 1px solid rgba(1, 188, 214, 0.28);
}

.answer-tag-delay-max,
.answer-tag-early {
  background: var(--bg-subtle);
  color: var(--body);
  border: 1px solid var(--border);
  font-weight: 600;
}

.answer-tag-policy {
  background: var(--bg-subtle);
  color: var(--primary-deep);
  border: 1px solid var(--border-soft);
}

.answer-tag-muted {
  background: var(--bg-subtle);
  color: var(--muted);
  border: 1px solid var(--border-soft);
  font-weight: 600;
}

.matrix-drawer {
  margin-top: 20px;
  padding: 12px 16px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 12px;
}

.matrix-drawer summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--primary);
  padding: 4px 0;
}

.matrix-drawer[open] summary {
  margin-bottom: 12px;
}

#workspace-inputs .sub-section {
  margin-top: 12px;
}

#workspace-inputs .sub-section.hidden {
  display: none;
}

.question-card {
  text-align: left;
  width: 100%;
  min-width: 0;
  padding: var(--space-4);
  border: 2px solid var(--border);
  border-radius: 12px;
  background: #fff;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  font-family: inherit;
}

.question-card strong {
  display: block;
  font-size: var(--text-base);
  line-height: var(--leading-tight);
  margin-bottom: var(--space-1);
}

.question-card span {
  display: block;
  font-size: var(--text-sm);
  color: var(--muted);
  line-height: var(--leading-normal);
}

.question-card:hover { border-color: var(--primary); background: #f8fafc; }

.question-card.active {
  border-color: var(--primary);
  background: var(--question-active-bg);
}

.question-group-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--muted);
  margin: 8px 0 12px;
  grid-column: 1 / -1;
}

.question-grid-secondary {
  margin-bottom: 16px;
}

.answer-bullets {
  margin: 12px 0;
  padding-left: 20px;
  line-height: 1.7;
  font-size: 14px;
}

.answer-bullets li { margin-bottom: 6px; }

.answer-bullet-section {
  list-style: none;
  margin: 14px 0 6px -20px;
  padding-left: 0;
  font-weight: 600;
  color: var(--primary);
  font-size: 0.95rem;
}

.answer-bullet-section:first-child {
  margin-top: 0;
}

.answer-details {
  margin-top: 12px;
  font-size: 0.92rem;
}

.answer-details summary {
  cursor: pointer;
  color: var(--primary);
  user-select: none;
}

.answer-details .answer-table-wrap {
  margin-top: 8px;
}

.answer-subtable-title {
  margin: 20px 0 10px;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text);
}

.compare-table-compact th,
.compare-table-compact td {
  font-size: 0.88rem;
  padding: 8px 10px;
}

.answer-verdict {
  padding: 18px 20px;
  margin-bottom: 20px;
  background: linear-gradient(180deg, #f0fafc 0%, var(--primary-soft) 100%);
  border: 2px solid var(--primary-muted);
  border-radius: var(--radius-lg);
}

.answer-verdict-error {
  background: var(--error-soft);
  border-color: #fca5a5;
}

.answer-verdict-label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--primary);
  margin-bottom: 8px;
}

.answer-verdict-error .answer-verdict-label { color: #dc2626; }

.answer-verdict-text {
  font-size: 17px;
  line-height: 1.75;
  color: #0f172a;
  margin: 0;
}

.answer-verdict-text strong { color: var(--primary-deep); }

.answer-lead {
  font-size: 14px;
  line-height: 1.75;
  margin-bottom: 16px;
}

.answer-lead strong { color: var(--primary); }

.matrix-tab-hint { margin-bottom: 16px; }

#question-answer h3 {
  font-size: 16px;
  margin-bottom: 12px;
}

.hero-question-grid-four {
  grid-template-columns: repeat(2, 1fr);
}

.gap-situation-picker {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 8px;
}

.gap-situation-option {
  display: block;
  cursor: pointer;
}

.gap-situation-option input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.gap-situation-card {
  display: block;
  padding: 14px 16px;
  border: 2px solid var(--border);
  border-radius: var(--radius);
  background: #fff;
  transition: border-color 0.15s, background 0.15s;
}

.gap-situation-card strong {
  display: block;
  font-size: 14px;
  margin-bottom: 4px;
}

.gap-situation-card small {
  display: block;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.45;
}

.gap-situation-option input:checked + .gap-situation-card {
  border-color: var(--primary);
  background: var(--primary-soft);
}

.gap-situation-option:hover .gap-situation-card {
  border-color: var(--primary-muted);
}

.question-group {
  margin-bottom: 16px;
}

.question-group-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--muted);
  margin: 0 0 8px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}

.question-group-cards {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

@media (max-width: 640px) {
  .compare-input-grid { grid-template-columns: 1fr; }
  .compare-vs { padding: 0; text-align: center; }
  .compare-inline-grid { grid-template-columns: 1fr; }
  .hero-highlight { display: block; }
  .hero-question-grid { grid-template-columns: 1fr; }
  .hero-q-body strong { font-size: var(--text-base); }
  .hero-questions-head { flex-direction: column; align-items: flex-start; }
  .hero-questions-head strong { font-size: var(--text-md); }
  .hero-questions-head span { font-size: var(--text-xs); }
  .hero-questions-panel { padding: var(--space-4); }
  .question-featured { grid-template-columns: 1fr; }
  .question-card-featured { min-height: 0; }
  .question-picker-compact { gap: var(--space-2); }
  .question-card { padding: var(--space-3) var(--space-4); font-size: var(--text-sm); min-height: 48px; }
  .question-workspace { padding: var(--space-4); }
  .segment-row-grid { grid-template-columns: 1fr; }
  .footer { padding: var(--space-4); font-size: var(--text-xs); line-height: var(--leading-relaxed); padding-bottom: max(var(--space-4), env(safe-area-inset-bottom)); }
}

.mobile-select-button {
  display: none;
}

.mobile-picker {
  position: fixed;
  inset: 0;
  z-index: 1000;
  width: 100vw;
  max-width: 100vw;
}

.mobile-picker-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.38);
}

.mobile-picker-sheet {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  max-height: min(78vh, 620px);
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: 18px 18px 0 0;
  box-shadow: 0 -18px 40px rgba(15, 23, 42, 0.18);
  overflow: hidden;
}

.mobile-picker-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 18px 12px;
  border-bottom: 1px solid var(--border-soft);
}

.mobile-picker-head strong {
  font-size: 16px;
  line-height: var(--leading-tight);
}

.mobile-picker-head button {
  border: none;
  background: transparent;
  color: var(--primary);
  font: inherit;
  font-size: 14px;
  font-weight: 700;
  padding: 6px 0;
}

.mobile-picker-search-wrap {
  padding: 10px 16px;
  border-bottom: 1px solid var(--border-soft);
}

.mobile-picker-search-wrap input {
  width: 100%;
  min-height: 40px;
  border: var(--input-border);
  border-radius: var(--input-radius);
  padding: var(--input-pad-y) var(--input-pad-x);
  font: inherit;
  font-size: 14px;
  background: var(--input-bg);
  box-shadow: var(--input-shadow);
}

.mobile-picker-options {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 6px 0 max(12px, env(safe-area-inset-bottom));
}

.mobile-picker-option {
  width: 100%;
  min-height: 50px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 18px;
  border: none;
  border-bottom: 1px solid var(--border-soft);
  background: #fff;
  color: var(--text);
  font: inherit;
  font-size: 16px;
  text-align: left;
}

.mobile-picker-option small {
  flex-shrink: 0;
  color: var(--muted);
  font-size: 12px;
}

.mobile-picker-option.active {
  color: var(--primary);
  background: var(--primary-soft);
  font-weight: 700;
}

.mobile-picker-empty {
  padding: 24px 18px;
  color: var(--muted);
  text-align: center;
}

body.mobile-picker-open {
  overflow: hidden;
}

.question-workspace {
  display: flex;
  flex-direction: column;
}

.workspace-head { order: 0; }
#workspace-inputs { order: 1; }
.workspace-actions { order: 2; }
.inline-answer { order: 3; }
.matrix-drawer { order: 4; }

@media (max-width: 640px) {
  :root {
    --radius: 10px;
    --radius-lg: 14px;
    --text-base: 0.9375rem;
    --text-md: 1rem;
  }

  body {
    background: #ffffff;
    line-height: 1.5;
  }

  #app {
    max-width: 480px;
    min-height: 100dvh;
    background: #ffffff;
  }

  .hero {
    padding: max(20px, calc(env(safe-area-inset-top) + 12px)) 18px 20px;
    border-bottom: 0;
    background: linear-gradient(180deg, #e3f5f8 0%, #eef6f7 55%, #f3f5f7 100%);
  }

  .hero-accent-bar {
    height: 3px;
  }

  .hero-badges {
    gap: 6px;
    margin-bottom: 10px;
  }

  .hero-badge {
    padding: 4px 8px;
    font-size: 11px;
    border-radius: 8px;
  }

  .hero-eyebrow {
    margin-bottom: 6px;
    font-size: 12px;
  }

  .hero-title {
    font-size: 27px;
    font-weight: 800;
    letter-spacing: -0.01em;
    line-height: 1.28;
  }

  .hero-lead {
    margin-top: 8px;
    max-width: none;
    font-size: 13px;
    line-height: 1.55;
  }

  .hero-questions-panel {
    margin-top: 12px;
    padding: 0;
    border-radius: 0;
    background: transparent;
  }

  .hero-questions-head {
    margin-bottom: 10px;
    gap: 2px;
  }

  .hero-q-section-label {
    margin-bottom: 8px;
    letter-spacing: 0;
  }

  .hero-question-grid {
    display: flex;
    gap: 8px;
    margin: 0;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 2px;
  }

  .hero-q-card {
    flex: 0 0 78%;
    min-height: 64px;
    padding: 13px 14px;
    scroll-snap-align: start;
    border: 1px solid #dceef0;
    border-radius: 14px;
    box-shadow: 0 1px 3px rgba(20, 32, 43, 0.05);
  }

  .hero-q-body strong {
    font-size: 15px;
  }

  .hero-q-body span {
    display: none;
  }

  .hero-more-wrap {
    display: none;
  }

  .hero-cta {
    max-width: none;
    min-height: 52px;
    margin-top: 18px;
    padding: 14px 18px;
    border-radius: 14px;
    font-size: 17px;
    font-weight: 800;
    background: linear-gradient(135deg, #07b6cf 0%, var(--primary-deep) 100%);
    box-shadow: 0 8px 20px rgba(3, 126, 144, 0.32);
  }

  .hero-trust,
  .data-badge {
    margin-top: 8px;
    font-size: 11px;
  }

  .disclaimer {
    padding: 8px 16px;
    font-size: 12px;
    line-height: 1.45;
  }

  .main {
    margin: 0 auto;
    padding: 10px 12px 118px;
  }

  .wizard-progress {
    position: sticky;
    top: 0;
    z-index: 50;
    margin: 0 0 10px;
    padding: 8px 2px;
    background: var(--bg);
    border: 0;
    border-radius: 0;
    box-shadow: none;
  }

  .progress-step {
    min-height: 42px;
    border-radius: 10px;
  }

  .progress-step.active {
    background: var(--accent-soft);
  }

  .progress-step.done {
    background: var(--primary-soft);
  }

  .step-num {
    width: 24px;
    height: 24px;
  }

  .form-card {
    padding: 0;
    border: none;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
  }

  .step-panel.active {
    min-height: calc(100dvh - 156px);
  }

  .step-header {
    margin-bottom: 12px;
    padding: 16px;
    background: #fff;
    border: 0;
    border-radius: 16px;
    box-shadow: 0 1px 3px rgba(20, 32, 43, 0.06);
  }

  .step-header h2 {
    font-size: 20px;
    font-weight: 800;
    letter-spacing: -0.01em;
  }

  .step-intro {
    margin-top: 6px;
    padding: 0;
    border: 0;
    background: transparent;
    font-size: 13px;
    color: var(--muted);
  }

  .lookup-guide {
    margin-bottom: 10px;
    border: 1px solid var(--border-soft);
    border-radius: 14px;
    background: #fff;
  }

  .lookup-guide-summary {
    padding: 12px 14px;
    font-size: 13px;
  }

  .lookup-guide-body {
    padding: 4px 12px 12px;
  }

  .field-grid,
  .field-grid-tight,
  .field-grid-3,
  .field-grid-core {
    display: block;
    border: 0;
    border-radius: 16px;
    background: #fff;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(20, 32, 43, 0.06), 0 1px 1px rgba(20, 32, 43, 0.04);
  }

  .field {
    min-height: 58px;
    padding: 12px 14px;
    border-bottom: 1px solid var(--border-soft);
    gap: 6px;
  }

  .field:last-child,
  .field-grid > .field:last-child,
  .field-grid-core > .field:last-child {
    border-bottom: 0;
  }

  .field label,
  .field-label,
  .field-label-row label {
    font-size: 13px;
    color: var(--body);
  }

  .field-label-row {
    margin-bottom: 0;
  }

  .field-lookup {
    display: none;
  }

  .field-hint {
    font-size: 12px;
  }

  .field input:not([type="radio"]):not([type="checkbox"]) {
    min-height: var(--input-height-compact);
    padding: var(--input-pad-y) var(--input-pad-x);
    border: var(--input-border);
    border-radius: var(--input-radius);
    background: var(--input-bg);
    box-shadow: var(--input-shadow);
    font-size: 16px;
    text-align: right;
    box-sizing: border-box;
  }

  .field input::placeholder {
    color: var(--input-placeholder);
  }

  .field select.mobile-native-select {
    position: absolute;
    width: 1px;
    height: 1px;
    min-height: 1px;
    opacity: 0;
    pointer-events: none;
  }

  .field select.mobile-native-select + .mobile-select-button,
  .segment-row-grid select.mobile-native-select + .mobile-select-button {
    display: flex;
  }

  .mobile-select-button {
    width: 100%;
    min-height: var(--input-height-compact);
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    padding: var(--input-pad-y) var(--input-pad-x);
    border: var(--input-border);
    border-radius: var(--input-radius);
    background: var(--input-bg);
    box-shadow: var(--input-shadow);
    color: var(--text);
    font: inherit;
    font-size: 16px;
    text-align: right;
    box-sizing: border-box;
    transition: border-color var(--transition), box-shadow var(--transition), transform 120ms ease;
  }

  .mobile-select-button:active:not(:disabled) {
    transform: scale(0.992);
    box-shadow: var(--input-shadow-active);
  }

  .mobile-select-button::after {
    content: "";
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    border: 0;
    transform: none;
    background-color: var(--primary);
    opacity: 0.62;
    -webkit-mask: var(--chev-down) center / 13px 13px no-repeat;
    mask: var(--chev-down) center / 13px 13px no-repeat;
  }

  .mobile-select-button.is-placeholder {
    color: #9aa6b2;
  }

  .form-section,
  .form-section-core,
  .form-section-details,
  .gap-section.form-section,
  #multi-career-fields {
    margin-top: 12px;
    padding: 16px;
    border: 0;
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 1px 3px rgba(20, 32, 43, 0.06);
  }

  .form-section-core .field-grid,
  .gap-section .field-grid,
  .form-section-details .field-grid {
    margin-top: 10px;
    border-color: var(--border-soft);
  }

  .career-mode-field {
    margin: 0 0 12px;
    padding: 16px;
    border: 0;
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 1px 3px rgba(20, 32, 43, 0.06);
  }

  .career-mode-toggle {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .career-mode-card,
  .gap-situation-card {
    min-height: 46px;
    padding: 10px 12px;
    border-width: 1.5px;
    border-radius: 12px;
  }

  .career-mode-radio {
    display: none;
  }

  .contribution-eligibility-banner,
  .policy-banner {
    margin-bottom: 10px;
    border-radius: 14px;
    background: #fff;
  }

  .question-choice-stage {
    gap: 10px;
  }

  .question-category-tabs {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    padding: 4px;
    border-radius: 12px;
    background: #eef3f6;
  }

  .category-tab {
    min-height: 36px;
    border: 0;
    border-radius: 10px;
    background: transparent;
  }

  .category-tab.active {
    background: #fff;
    box-shadow: var(--shadow);
  }

  .question-featured {
    display: flex;
    flex-direction: column;
    gap: 8px;
  }

  .question-card {
    min-height: 58px;
    padding: 12px 14px;
    border-width: 1px;
    border-radius: 14px;
    box-shadow: none;
  }

  .question-card strong {
    font-size: 15px;
  }

  .question-card span,
  .question-hook {
    font-size: 12px;
  }

  .question-picker-compact .question-card,
  .question-picker-compact .question-card-featured {
    width: 100%;
    border-radius: 14px;
  }

  .question-more-wrap {
    border: 0;
    border-radius: 0;
    background: transparent;
    padding: 0;
  }

  .question-workspace {
    margin-top: 0;
    padding: 0;
    border: 0;
    background: transparent;
  }

  .workspace-head {
    margin-bottom: 12px;
    padding: 18px 16px;
    border: 0;
    border-radius: 16px;
    background: linear-gradient(180deg, #f0fafc 0%, #ffffff 70%);
    box-shadow: 0 1px 3px rgba(20, 32, 43, 0.06);
  }

  .workspace-head h3 {
    font-size: 18px;
  }

  .question-plain-intro {
    margin-top: 10px;
    padding: 10px 12px;
    font-size: 12px;
    border-radius: 10px;
  }

  .question-data-fields {
    gap: 10px;
    margin-bottom: 10px;
    padding-bottom: 0;
    border-bottom: 0;
  }

  #workspace-inputs .sub-section {
    margin-top: 12px;
    padding: 16px;
    border: 0;
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 1px 3px rgba(20, 32, 43, 0.06);
  }

  #workspace-inputs .sub-section .field-grid {
    margin-top: 10px;
  }

  .workspace-actions {
    position: sticky;
    bottom: 0;
    z-index: 90;
    margin: 12px -12px 0;
    padding: 10px 12px max(10px, env(safe-area-inset-bottom));
    border-top: 1px solid var(--border-soft);
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(10px);
  }

  .workspace-actions .btn {
    width: 100%;
    min-height: 48px;
  }

  .workspace-action-hint {
    display: none;
  }

  .inline-answer {
    margin-top: 0;
  }

  .inline-answer .answer-panel,
  .answer-verdict {
    margin-bottom: 10px;
    padding: 16px;
    border: 1px solid var(--border-soft);
    border-radius: 14px;
    background: #fff;
  }

  .answer-main {
    font-size: 16px;
    line-height: 1.7;
  }

  .question-workspace.answer-ready:not(.editing-answer) #workspace-inputs,
  .question-workspace.answer-ready:not(.editing-answer) #btn-run-question,
  .question-workspace.answer-ready:not(.editing-answer) .workspace-action-hint {
    display: none;
  }

  .question-workspace.answer-ready:not(.editing-answer) .inline-answer {
    order: 1;
  }

  .question-workspace.answer-ready:not(.editing-answer) .workspace-actions {
    order: 2;
    justify-content: stretch;
  }

  .question-workspace.answer-ready.editing-answer .inline-answer {
    margin-top: 10px;
  }

  .matrix-drawer {
    border-radius: 14px;
  }

  .form-actions {
    position: sticky;
    bottom: 0;
    z-index: 95;
    margin: 12px -12px 0;
    padding: 10px 12px max(10px, env(safe-area-inset-bottom));
  }

  .form-actions .btn {
    min-height: 48px;
    border-radius: 12px;
  }

  .action-right {
    flex: 1;
  }

  .action-right .btn-primary {
    flex: 1;
  }

  .step-indicator {
    display: none;
  }

  .form-card[data-current-step="3"] > .form-actions {
    position: static;
    display: flex;
    justify-content: flex-start;
    margin: 10px 0 0;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
  }

  .form-card[data-current-step="3"] > .form-actions .action-right {
    display: none;
  }

  .form-card[data-current-step="3"] > .form-actions .btn-ghost {
    flex: 0 0 auto;
    min-width: 96px;
    background: #fff;
  }

  .footer {
    display: none;
  }
}



/* ============================================================
   开屏(Hero)彻底重构 — 大号钩子问题卡，强冲击力，极简文案
   ============================================================ */
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;}

.hero{
  background:linear-gradient(168deg,#d6f0f4 0%,#e7f4f6 46%,var(--bg-subtle) 100%);
  border-bottom:0;
  padding:max(24px,calc(env(safe-area-inset-top) + 16px)) 20px 24px;
}
.hero-accent-bar{height:4px;background:linear-gradient(90deg,var(--primary-deep),var(--primary));}
.hero-inner{max-width:520px;}
.hero-eyebrow{margin:0 0 12px;font-size:12px;font-weight:800;letter-spacing:.14em;color:var(--primary-deep);}
.hero-title{font-size:31px;font-weight:800;line-height:1.2;letter-spacing:-0.02em;color:var(--text);}
.hero-line{display:block;}
.hero-highlight{display:block;margin-top:3px;color:var(--accent);}
.hero-lead{margin-top:13px;font-size:14px;line-height:1.6;color:var(--body);max-width:none;}
.hero-lead strong{color:var(--primary-deep);font-weight:800;}

.hero-questions-panel{margin-top:20px;padding:0;border:0;background:transparent;}
.hero-q-section-label{display:none;}
.hero-question-grid{display:flex;flex-direction:column;gap:10px;overflow:visible;margin:0;}
.hero-q-card{
  position:relative;display:flex;align-items:center;gap:13px;width:100%;flex:none;
  min-height:60px;padding:15px 16px;border:0;border-radius:16px;background:#fff;
  box-shadow:0 1px 3px rgba(20,32,43,.07),0 8px 20px rgba(20,32,43,.045);
  text-align:left;cursor:pointer;font-family:inherit;
  transition:transform .15s ease,box-shadow .15s ease;
}
.hero-q-card::before{
  content:"?";flex:none;width:36px;height:36px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;font-weight:800;color:#fff;
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-deep) 100%);
}
.hero-q-card::after{
  content:"";flex:none;width:8px;height:8px;margin-left:2px;
  border-right:2.5px solid #c4ced6;border-bottom:2.5px solid #c4ced6;
  transform:rotate(-45deg);
}
.hero-q-card:hover{box-shadow:0 2px 6px rgba(20,32,43,.1),0 12px 26px rgba(3,118,136,.1);}
.hero-q-card:active{transform:scale(.985);}
.hero-q-card .hero-q-body{flex:1;min-width:0;}
.hero-q-body strong{display:block;font-size:16px;font-weight:700;line-height:1.3;color:var(--text);margin:0;}
.hero-q-body span{display:block;font-size:12.5px;line-height:1.45;color:var(--muted);margin-top:3px;}

.hero-more-wrap{display:block;margin-top:14px;border:0;background:transparent;padding:0;text-align:center;}
.hero-more-wrap summary{color:var(--primary-deep);font-size:13px;font-weight:700;list-style:none;}
.hero-more-wrap summary::-webkit-details-marker{display:none;}
.hero-more-wrap[open]{padding:0;}
.hero-more-wrap[open] summary{margin-bottom:0;}
.hero-question-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:12px;max-height:none;}
.hero-q-tag{padding:8px 13px;border:1px solid #cfe6ea;border-radius:999px;background:#fff;color:var(--primary-deep);font-family:inherit;font-size:12.5px;font-weight:600;cursor:pointer;}

.hero-cta{
  display:block;width:100%;max-width:none;margin-top:22px;min-height:54px;
  padding:15px 20px;border:0;border-radius:16px;font-size:17px;font-weight:800;color:#fff;
  background:linear-gradient(135deg,#07b6cf 0%,var(--primary-deep) 100%);
  box-shadow:0 10px 24px rgba(3,118,136,.34);cursor:pointer;font-family:inherit;
  transition:transform .15s ease;
}
.hero-cta:hover{background:linear-gradient(135deg,#06acc4 0%,#075c69 100%);}
.hero-cta:active{transform:scale(.99);}
.data-badge{margin-top:13px;font-size:11px;color:#9aa6b0;text-align:center;line-height:1.4;}


/* ============================================================
   分屏呈现：开屏=第0屏；点击后逐屏推进（小程序式）
   ============================================================ */
@media (max-width: 640px) {
  /* 开屏前：只显示开屏，隐藏流程与结果 */
  body:not(.flow-started) .main { display: none; }
  .disclaimer { display: none; }

  /* 顶部 App Bar 仅在流程内出现 */
  .flow-appbar { display: none; }
  body.flow-started .flow-appbar {
    display: flex; align-items: center; gap: 6px;
    position: sticky; top: 0; z-index: 60;
    height: 50px; margin: 0 -12px; padding: 0 8px 0 2px;
    background: rgba(255,255,255,.94);
    -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--border-soft);
  }
  .flow-appbar-back {
    border: 0; background: transparent; font: inherit; font-size: 15px;
    color: var(--primary); font-weight: 600;
    padding: 8px 10px 8px 8px; display: flex; align-items: center; gap: 5px;
    cursor: pointer;
  }
  .flow-appbar-back::before {
    content: ""; width: 9px; height: 9px; flex: none;
    border-left: 2px solid var(--primary-deep);
    border-bottom: 2px solid var(--primary-deep);
    transform: rotate(45deg);
  }
  .flow-appbar-title { font-size: 16px; font-weight: 700; color: var(--text); }
  .flow-appbar-spacer { flex: 1; }

  /* 开屏后：整屏体验 */
  body.flow-started .hero { display: none; }
  body.flow-started #app { min-height: 100dvh; }

  /* 步骤条置于 App Bar 之下 */
  body.flow-started .wizard-progress { top: 0; z-index: 55; }
}



/* ============================================================
   精修层 — 统一排版刻度 / 单一青色体系 / 极简步骤条 / 精致卡片
   ============================================================ */
@media (max-width: 640px) {
  /* —— 单色青系：去掉杂糅的橙色，整体更高级 —— */
  .hero-highlight { color: var(--primary-deep); }
  .progress-step.active .step-num { background: var(--accent-90); box-shadow: none; }
  .progress-step.active { background: transparent; }
  .hero-q-section-label, .hero-questions-head strong { color: var(--primary-deep); }
  .question-spotlight-label { color: var(--primary); }
  .question-teaser { background: var(--teaser-bg); color: var(--primary-deep); }

  /* —— 统一字号 / 字重刻度 —— */
  .flow-appbar-title { font-size: 15px; font-weight: 600; letter-spacing: 0; }
  .flow-appbar-back { font-size: 14px; font-weight: 500; }
  .step-header h2 { font-size: 19px; font-weight: 700; letter-spacing: -0.01em; line-height: 1.35; color: var(--text); }
  .step-intro { font-size: 12.5px; font-weight: 400; line-height: 1.55; color: var(--muted); }
  .form-section-title, .workspace-head h3, .sub-section h3, .gap-situation-card strong { font-size: 15px; font-weight: 600; letter-spacing: -0.01em; }
  .form-section-lead, .field-hint, .field-hint-compact, .question-hook, .gap-situation-card small { font-size: 12px; font-weight: 400; line-height: 1.5; color: var(--muted); }
  .field label, .field-label, .field-label-row label { font-size: 13px; font-weight: 500; color: var(--muted); letter-spacing: 0; }
  .field input, .field select, .mobile-select-button { font-size: 15px; font-weight: 500; }
  .question-card strong { font-size: 15px; font-weight: 600; letter-spacing: -0.01em; }
  .workspace-label { font-size: 11px; font-weight: 600; letter-spacing: .08em; color: var(--muted); }
  .answer-main { font-size: 15px; line-height: 1.7; }

  /* —— 屏标题轻量化：去掉笨重白卡，标题落在浅灰底上 —— */
  .step-header { background: transparent; box-shadow: none; border: 0; padding: 8px 2px 2px; margin-bottom: 10px; }

  /* —— 极简步骤条 —— */
  .wizard-progress { padding: 10px 6px; gap: 0; box-shadow: none; border: 0; background: var(--bg); }
  .progress-step { gap: 6px; }
  .step-num { width: 22px; height: 22px; font-size: 11px; font-weight: 700; }
  .step-text strong { font-size: 12px; font-weight: 600; }
  .progress-step:not(.active):not(.done) .step-num { background: #cdd6dd; }
  .progress-step:not(.active):not(.done) .step-text strong { color: #9aa6b0; }
  .progress-step.done .step-text strong { color: var(--primary-deep); }
  .progress-step.active .step-text strong { color: var(--text); }

  /* —— 卡片质感：发丝边 + 极柔分层阴影 —— */
  .field-grid, .field-grid-tight, .field-grid-3, .field-grid-core,
  .form-section, .form-section-core, .form-section-details, .gap-section.form-section,
  #multi-career-fields, #workspace-inputs .sub-section, .career-mode-field,
  .lookup-guide, .contribution-eligibility-banner, .policy-banner {
    box-shadow: 0 1px 2px rgba(20,32,43,.03), 0 10px 24px -16px rgba(20,32,43,.2);
    border: 1px solid #edf1f3;
  }
  .field { border-bottom-color: #eef2f4; }

  /* —— 工作区标题卡更克制 —— */
  .workspace-head { background: #fff; padding: 16px; }
  .workspace-head h3 { font-size: 17px; font-weight: 700; }
  .workspace-subtitle { font-size: 12.5px; color: var(--muted); }

  /* —— 答案卡：像一张结论卡 —— */
  .inline-answer .answer-panel, .answer-verdict {
    border: 1px solid #e4eef0;
    box-shadow: 0 1px 2px rgba(20,32,43,.03), 0 12px 28px -18px rgba(3,118,136,.3);
  }
  .answer-main strong { color: var(--primary-deep); font-weight: 700; }

  /* —— 按钮精修 —— */
  .btn-accent { background: linear-gradient(135deg, #07b6cf 0%, var(--primary-deep) 100%); box-shadow: 0 8px 20px -6px rgba(3,118,136,.4); }
  .btn-ghost, .btn-secondary { border: 1px solid #d7e2e6; color: var(--primary-deep); font-weight: 600; background: #fff; }
  .hero-cta { background: linear-gradient(135deg, #06acc6 0%, #0a6c7b 100%); box-shadow: 0 10px 26px -8px rgba(3,118,136,.45); }

  /* —— hero 标题与正文统一 —— */
  .hero-title { font-size: 29px; }
  .hero-q-body strong { font-size: 15.5px; font-weight: 700; }
  .hero-q-body span { font-size: 12px; }
  .hero-q-card::before { background: var(--primary-deep); }
}


/* ============================================================
   v2 改造层 — 主色 #01BCD6 / 点缀 #FF9900 · 一行式表单 · 精致控件
   ============================================================ */
:root {
  --chev-down: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  --chev-left: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M15 6l-6 6 6 6'/%3E%3C/svg%3E");
}

/* 点缀色回归：标题高亮用橙色 */
.hero-highlight { color: var(--accent); }

@media (max-width: 640px) {
  /* —— 步骤条：青=已完成，橙=当前步 —— */
  .wizard-progress {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    padding: 14px 8px 12px;
    gap: 6px;
    background: var(--bg);
    border: 0;
  }
  .progress-step { flex-direction: column; align-items: center; gap: 7px; padding: 2px 0; }
  .step-num {
    width: 30px; height: 30px; border-radius: 50%;
    font-size: 13px; font-weight: 700;
    background: #e6edf1; color: #9aa6b0; box-shadow: none;
    transition: background .2s ease, color .2s ease, box-shadow .2s ease;
  }
  .progress-step.done .step-num { background: var(--primary); color: #fff; }
  .progress-step.active .step-num {
    background: var(--accent-90); color: #fff;
    box-shadow: none;
  }
  .progress-step.active { background: transparent; }
  .step-text { text-align: center; }
  .step-text strong { font-size: 11px; font-weight: 600; line-height: 1.25; }
  .progress-step:not(.active):not(.done) .step-text strong { color: #aab4bd; }
  .progress-step.active .step-text strong { color: var(--text); }
  .progress-step.done .step-text strong { color: var(--primary-deep); }

  /* —— 一行式表单：左标签 右数值（含下拉），提示自动换到下一行 —— */
  .field {
    display: flex; flex-direction: row; flex-wrap: wrap; align-items: center;
    column-gap: 14px; row-gap: 4px;
    padding: 14px 16px; min-height: 54px;
  }
  .field > label,
  .field > .field-label,
  .field > .field-label-row { order: 0; margin: 0; flex: 0 1 auto; }
  .field > .field-label-row { display: flex; align-items: center; }
  .field-label-row label { flex: 0 0 auto; }
  .field-hint-inline { display: none; }
  .field > input,
  .field > .mobile-select-button { order: 1; flex: 1 1 auto; min-width: 0; width: auto; text-align: right; }
  .field > .field-hint,
  .field > .field-error,
  .field > .field-lookup,
  .field > .account-balance-estimate,
  .field > .btn-link,
  .field > .province-source-banner { order: 2; flex: 0 0 100%; text-align: left; }
  .field > label,
  .field > .field-label,
  .field-label-row label { color: var(--muted); font-weight: 500; }

  /* —— 下拉箭头：清爽的圆角雪佛龙，替换粗糙的方块边 —— */
  .mobile-select-button { gap: 6px; color: var(--text); }
  .mobile-select-button::after {
    content: ""; width: 18px; height: 18px; flex: none; border: 0; transform: none;
    background-color: var(--primary);
    opacity: 0.62;
    -webkit-mask: var(--chev-down) center / 13px 13px no-repeat;
    mask: var(--chev-down) center / 13px 13px no-repeat;
  }
  .mobile-select-button.is-placeholder { color: #9aa6b2; }

  /* —— 身份选择：与 question-spotlight 一致 —— */
  .identity-stage { margin-bottom: 12px; }
  .identity-stage .field {
    display: flex !important;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 0;
    background: transparent;
    border: 0;
    border-radius: 0;
    border-bottom: 0;
  }
  .identity-stage .field > .field-label-row { display: none; }
  .identity-stage .field > .mobile-select-button {
    order: 1;
    width: 100%;
    flex: none;
    justify-content: space-between;
    text-align: left;
    min-height: var(--input-height);
    padding: var(--input-pad-y) var(--input-pad-x);
    border: var(--input-border);
    border-radius: var(--input-radius);
    background: var(--input-bg);
    box-shadow: var(--input-shadow);
    font-size: 15px;
    font-weight: 600;
    letter-spacing: -0.01em;
    color: var(--text);
  }

  /* —— 顶部返回箭头：清爽雪佛龙 —— */
  .flow-appbar-back { gap: 2px; }
  .flow-appbar-back::before {
    content: ""; width: 20px; height: 20px; flex: none; border: 0; transform: none;
    background-color: var(--primary-deep);
    -webkit-mask: var(--chev-left) center / 16px 16px no-repeat;
    mask: var(--chev-left) center / 16px 16px no-repeat;
  }

  /* —— 推荐问题：青色引导小标 + 选中态 —— */
  .question-spotlight-label { color: var(--primary); display: flex; align-items: center; }
  .question-spotlight-label::before {
    content: ""; width: 6px; height: 6px; margin-right: 7px;
    border-radius: 50%; background: var(--primary); flex: none;
  }
  .question-card.active {
    border-color: var(--primary); background: var(--question-active-bg);
    box-shadow: 0 0 0 1px var(--primary-ring);
  }
  .question-teaser { background: var(--teaser-bg); color: var(--primary-deep); }

  /* —— CTA / 主按钮统一新主色 —— */
  .hero-cta { background: linear-gradient(135deg, #06c4dd 0%, var(--primary-deep) 100%); box-shadow: 0 10px 26px -8px rgba(1, 160, 184, .5); }
  .hero-cta:hover { background: linear-gradient(135deg, #04b6cf 0%, #055e6b 100%); }
  .btn-accent { background: linear-gradient(135deg, #06c4dd 0%, var(--primary-deep) 100%); box-shadow: 0 8px 20px -6px rgba(1, 160, 184, .45); }
  .hero-q-card::before { background: linear-gradient(135deg, var(--primary) 0%, var(--primary-deep) 100%); }
}


/* ============================================================
   v3 改造层 — 统一字号字重 · 答案独立页 · 全宽问题框 · 表格不折行
   ============================================================ */
/* 统一“修改信息”入口：隐藏散落在卡片里的按钮，全部走底部按钮栏 */
#btn-back-basics, .workspace-actions { display: none !important; }

@media (max-width: 640px) {
  /* ---------- 1. 统一字号 / 字重（只用 400 / 600 / 700） ---------- */
  #app input, #app select, #app button, #app textarea { font-weight: 400; }
  .step-header h2 { font-size: 19px; font-weight: 700; letter-spacing: -0.01em; color: var(--text); }
  .step-intro { font-size: 13px; font-weight: 400; color: var(--muted); }
  .workspace-head h3, .form-section-title, .sub-section h3,
  .gap-situation-card strong, .career-mode-label,
  .answer-subtable-title, .mini-card h4 { font-size: 16px; font-weight: 700; letter-spacing: -0.01em; color: var(--text); }
  .workspace-subtitle, .form-section-lead, .field-hint, .field-hint-compact,
  .question-hook, .question-card span, .gap-situation-card small,
  .table-legend, .matrix-legend { font-size: 12.5px; font-weight: 400; color: var(--muted); line-height: 1.5; }
  .field > label, .field-label, .field-label-row label { font-size: 14px; font-weight: 500; color: var(--muted); }
  .field > input, .field > .mobile-select-button { font-size: 15px; font-weight: 600; color: var(--text); }
  .question-card strong { font-size: 15px; font-weight: 600; color: var(--text); }
  .btn, .hero-cta { font-weight: 600; }
  .answer-main { font-size: 15px; font-weight: 400; line-height: 1.7; }
  .answer-main strong, .answer-verdict-text strong, .answer-lead strong { font-weight: 700; }
  .answer-verdict-text { font-size: 16px; font-weight: 400; line-height: 1.7; }
  .answer-verdict-label, .workspace-label { font-size: 11px; font-weight: 700; letter-spacing: .12em; }
  .answer-eyebrow, .answer-result-eyebrow { font-size: 15px; font-weight: 700; letter-spacing: .06em; }
  .answer-lead { font-size: 14px; font-weight: 400; }
  .answer-bullets, .answer-list, .answer-table, .compare-table, .result-table { font-size: 13px; }
  .matrix-metric-num { font-size: 14px; }
  .matrix-metric-primary .matrix-metric-num { font-size: 16px; }

  /* ---------- 2. 当前问题 + 解释框：顶到屏幕左右边缘 ---------- */
  .question-workspace { padding: 0; background: transparent; border: 0; }
  .workspace-head {
    margin: 0 -12px 14px; border-radius: 0;
    padding: 16px; border: 0;
    background: linear-gradient(180deg, var(--primary-soft) 0%, #fff 82%);
    box-shadow: inset 0 -1px 0 var(--border-soft);
  }
  .question-plain-intro {
    margin: 10px -16px 0; border-radius: 0;
    border-left: 0; border-right: 0;
    padding: 13px 16px; background: #fff;
    border-top: 1px solid var(--primary-muted);
    border-bottom: 1px solid var(--primary-muted);
  }

  /* ---------- 3. 答案独立页（step4） ---------- */
  .answer-head { margin: 4px 2px 14px; padding: 0; }
  .answer-eyebrow,
  .answer-result-eyebrow { margin: 0 0 8px; font-size: 15px; color: var(--primary); }
  #answer-q-title { font-size: 21px; font-weight: 700; line-height: 1.32; letter-spacing: -0.01em; color: var(--text); }
  .step-panel[data-step="4"] .inline-answer { margin: 0; }
  .step-panel[data-step="4"] .answer-panel,
  .step-panel[data-step="4"] .answer-verdict {
    margin: 0 -12px 12px; border-radius: 0; border-left: 0; border-right: 0;
  }
  .step-panel[data-step="4"] .matrix-drawer { margin: 0 -12px; border-radius: 0; border-left: 0; border-right: 0; }

  /* ---------- 4. 底部按钮栏：每步统一一个动作 ---------- */
  .form-card[data-current-step="3"] > .form-actions,
  .form-card[data-current-step="4"] > .form-actions {
    position: sticky; bottom: 0; z-index: 95;
    display: flex; justify-content: space-between; align-items: center;
    margin: 14px -12px 0; padding: 10px 12px max(10px, env(safe-area-inset-bottom));
    border-top: 1px solid var(--border);
    background: rgba(255, 255, 255, .96); backdrop-filter: blur(10px);
    box-shadow: 0 -6px 24px rgba(15, 23, 42, .08);
  }
  .form-card[data-current-step="3"] > .form-actions .action-right { display: flex; }
  .form-card[data-current-step="4"] > .form-actions .action-right { display: none; }
  .form-card[data-current-step="4"] > .form-actions .btn-ghost#btn-prev {
    flex: 1; min-height: 50px; border: 0; border-radius: 12px;
    background: var(--primary-soft); color: var(--primary-deep); font-weight: 600;
  }

  .form-actions .btn-flow-back {
    flex: 0 0 auto;
    min-width: 72px;
    min-height: 50px;
    padding: 0 12px;
    border: 0;
    border-radius: 12px;
    background: transparent;
    color: #01BCD6;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    gap: 0;
    text-align: center;
  }

  /* ---------- 5. 对比类表格仍横向滑动；答案表在下方改为卡片 ---------- */
  #inline-answer .compare-table,
  #inline-answer .result-table { white-space: nowrap; }
  #inline-answer .compare-table th,
  #inline-answer .compare-table td,
  #inline-answer .result-table th,
  #inline-answer .result-table td { white-space: nowrap; }
  #inline-answer .compare-table-wrap,
  #inline-answer .table-wrap {
    overflow-x: auto; -webkit-overflow-scrolling: touch;
    border: 1px solid var(--border); border-radius: 12px; background: #fff;
  }
  #inline-answer .answer-table-wrap {
    overflow-x: visible;
    border: 0;
    border-radius: 0;
    background: transparent;
  }
  #inline-answer .compare-table th,
  #inline-answer .compare-table td { padding: 9px 12px; }
}


/* ============================================================
   v4 改造层 — 扁平高级（去渐变）· 网格表单（名称数值同行）· 推荐卡统一
   ============================================================ */
@media (max-width: 640px) {
  /* ---------- A. 表单：网格定位，名称与数值永远同一行 ---------- */
  .field {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    column-gap: 12px; row-gap: 4px;
    padding: 14px 16px; min-height: 54px;
  }
  .field > label,
  .field > .field-label,
  .field > .field-label-row { grid-column: 1; grid-row: 1; margin: 0; }
  .field > input,
  .field > .mobile-select-button {
    grid-column: 2; grid-row: 1; justify-self: end;
    width: auto; max-width: 100%; text-align: right;
  }
  .field > .field-hint,
  .field > .field-error,
  .field > .field-lookup,
  .field > .account-balance-estimate,
  .field > .btn-link,
  .field > .province-source-banner { grid-column: 1 / -1; margin: 0; }
  .field > input { min-width: 6ch; }

  /* 身份：标签第一行，选项框第二行 */
  .identity-stage .field {
    display: block !important;
    grid-template-columns: unset;
  }
  .identity-stage .field > .field-label-row { display: none; }
  .identity-stage .field > .mobile-select-button {
    grid-column: unset;
    grid-row: unset;
    width: 100%;
    justify-self: stretch;
    text-align: left;
  }

  /* ---------- B. 去渐变 · 扁平高级 ---------- */
  .hero { background: #ffffff !important; border-bottom: 1px solid var(--border-soft); }
  .hero-accent-bar { background: var(--primary) !important; }
  .hero-cta {
    background: var(--primary) !important;
    box-shadow: 0 8px 18px -10px rgba(1, 188, 214, .7) !important;
  }
  .hero-cta:hover { background: var(--primary-hover) !important; }
  .hero-q-card { box-shadow: 0 1px 3px rgba(20, 32, 43, .06) !important; border: 1px solid var(--border-soft) !important; }
  .hero-q-card::before { background: var(--primary) !important; }
  .btn-accent, .btn-primary { background: var(--primary) !important; box-shadow: none !important; }
  .btn-primary:active, .btn-accent:active { background: var(--primary-hover) !important; }
  .workspace-head { background: #ffffff !important; }
  .answer-verdict { background: var(--primary-soft) !important; border-color: var(--primary-muted) !important; }

  /* ---------- C. “还能算另外 X 个问题”展开后与默认卡一致 ---------- */
  .hero-question-tags { flex-direction: column; gap: 10px; max-height: none; }
  .hero-q-tag {
    display: flex; align-items: center; gap: 13px;
    width: 100%; padding: 15px 16px; border-radius: 14px;
    border: 1px solid var(--border-soft); background: #fff;
    box-shadow: 0 1px 3px rgba(20, 32, 43, .06);
    font-size: 15px; font-weight: 600; color: var(--text);
    text-align: left; justify-content: flex-start;
  }
  .hero-q-tag::before {
    content: "?"; flex: none; width: 34px; height: 34px; border-radius: 11px;
    display: flex; align-items: center; justify-content: center;
    background: var(--primary); color: #fff; font-size: 18px; font-weight: 700;
  }
  .hero-q-tag::after {
    content: ""; flex: none; width: 8px; height: 8px; margin-left: auto;
    border-right: 2px solid #c4ced6; border-bottom: 2px solid #c4ced6;
    transform: rotate(-45deg);
  }

  /* ---------- D. “缴费经历”切换：标签不折行 ---------- */
  .career-mode-label { white-space: nowrap; font-size: 14px; font-weight: 600; }
  .career-mode-card { justify-content: center; }

  /* ---------- E. 矩阵表：单行紧凑 ---------- */
  .matrix-cell { min-width: 52px; }
  .matrix-table .row-head { font-size: 12px; }

  /* ---------- F. 答案要点列表：清爽 ---------- */
  .answer-bullets { padding-left: 0; list-style: none; margin: 10px 0; }
  .answer-bullets li {
    position: relative; padding: 9px 0 9px 18px; margin: 0;
    border-bottom: 1px solid var(--border-soft);
    font-size: 13.5px; line-height: 1.55;
  }
  .answer-bullets li::before {
    content: ""; position: absolute; left: 3px; top: 16px;
    width: 5px; height: 5px; border-radius: 50%; background: var(--primary);
  }
  .answer-bullets li:last-child { border-bottom: 0; }
  .answer-bullet-section { margin: 12px 0 2px; padding-left: 0; }
  .answer-bullet-section::before { display: none; }
}


/* ============================================================
   v5 改造层 — 更小左右留白 · 首页广告式（竖排，不可误点）
   ============================================================ */
@media (max-width: 640px) {
  /* ---------- 更小的左右留白，更高级 ---------- */
  .main { padding-left: 8px !important; padding-right: 8px !important; }

  /* ---------- 首页 = 广告：竖排展示，不再左右滑动，弱化“点我测算” ---------- */
  .hero { padding-left: 16px !important; padding-right: 16px !important; }
  .hero-eyebrow { letter-spacing: .14em; }
  .hero-title { font-size: 28px; line-height: 1.25; }
  .hero-scope-hint {
    margin-top: 12px;
    padding: 8px 14px;
    font-size: 15px;
  }
  .hero-lead { font-size: 13.5px; color: var(--body); }
  .hero-lead strong { color: var(--primary-deep); }

  .hero-questions-panel {
    margin-top: 16px !important;
    padding: 0 !important; background: transparent !important; border: 0 !important;
  }

  /* 竖排卡片，撑满宽度，标题不再奇怪折行 */
  .hero-question-grid {
    display: flex !important; flex-direction: column !important;
    gap: 10px !important; overflow: visible !important; margin: 0 !important;
    padding: 0 !important;
  }
  .hero-q-card {
    flex: none !important; width: 100% !important;
    display: flex !important; align-items: center; gap: 12px;
    min-height: 0 !important; padding: 14px !important;
    border-radius: 14px !important; border: 1px solid var(--border-soft) !important;
    background: #fff !important; box-shadow: 0 1px 2px rgba(20, 32, 43, .05) !important;
    scroll-snap-align: none !important;
  }
  .hero-q-card::after { display: none !important; }      /* 去箭头：不像“点击进入” */
  .hero-q-card::before {
    content: "" !important; flex: none; width: 8px !important; height: 8px !important;
    border-radius: 50% !important; background: var(--primary) !important;
  }
  .hero-q-body { flex: 1; min-width: 0; }
  .hero-q-body strong {
    display: block; font-size: 15px; font-weight: 600; line-height: 1.4;
    color: var(--text); text-wrap: pretty;
  }
  .hero-q-body span { display: block !important; font-size: 12.5px; color: var(--muted); margin-top: 3px; line-height: 1.45; }

  /* “还能算另外 X 个问题”展开：竖排，与默认卡片一致 */
  .hero-more-wrap { display: block !important; margin-top: 12px; border: 0; background: transparent; padding: 0; text-align: left; }
  .hero-more-wrap summary { color: var(--primary-deep); font-weight: 700; font-size: 13px; padding: 4px 2px; }
  .hero-question-tags { display: flex !important; flex-direction: column !important; gap: 10px !important; margin-top: 12px !important; max-height: none !important; }
  .hero-q-tag {
    display: flex !important; align-items: center; gap: 12px;
    width: 100%; padding: 14px !important; border-radius: 14px;
    border: 1px solid var(--border-soft); background: #fff;
    box-shadow: 0 1px 2px rgba(20, 32, 43, .05);
    font-size: 15px; font-weight: 600; color: var(--text); justify-content: flex-start;
  }
  .hero-q-tag::before {
    content: ""; flex: none; width: 8px; height: 8px; border-radius: 50%; background: var(--primary);
  }
  .hero-q-tag::after { display: none; }

  /* 唯一入口：开始测算 */
  .hero-cta { margin-top: 20px !important; }
}


/* ============================================================
   v6 改造层 — 首页只读广告 · CTA 固定底部 · 更紧留白
   ============================================================ */
@media (max-width: 640px) {
  /* 留白再收紧 */
  .main { padding-left: 6px !important; padding-right: 6px !important; }

  /* 首页问题：纯展示，不可点击 */
  .hero-q-card, .hero-q-tag { pointer-events: none !important; cursor: default !important; }
  .hero-q-card:active, .hero-q-card:hover { transform: none !important; box-shadow: 0 1px 2px rgba(20, 32, 43, .05) !important; }
  .hero-more-wrap { display: none !important; }

  /* 删除「开始测算」下方文案 */
  .data-badge { display: none !important; }

  /* 「开始测算」固定在页面底部，稳定可见 */
  body:not(.flow-started) .hero { padding-bottom: 96px !important; }
  body:not(.flow-started) .hero-cta {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 80;
    width: auto !important; max-width: none !important; margin: 0 !important;
    border-radius: 0 !important; min-height: 56px;
    padding: 15px 16px; padding-bottom: max(14px, env(safe-area-inset-bottom));
    box-shadow: 0 -6px 22px rgba(15, 23, 42, .12);
  }
}


/* ============================================================
   v7 改造层 — 顶栏精简(返回+细进度同行) · 操作按钮吸底 · 名称不折行 · 结果页设计
   ============================================================ */
.appbar-progress { display: none; }

@media (max-width: 640px) {
  /* ---------- 4. 顶栏已移除，恢复四步步骤条 ---------- */
  .wizard-progress {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 6px !important;
    padding: 12px 8px !important;
  }
  .wizard-progress .progress-step {
    min-width: 0;
    padding: 2px 0 !important;
  }
  .wizard-progress .step-text strong {
    font-size: 11px !important;
    line-height: 1.25;
    word-break: keep-all;
  }
  .appbar-progress { display: none !important; }

  /* ---------- 5. 删除“选好身份后…”提示卡 ---------- */
  #policy-bounds-banner { display: none !important; }

  /* ---------- 6. 所有主操作按钮吸底 ---------- */
  .form-actions,
  .form-card[data-current-step="3"] > .form-actions,
  .form-card[data-current-step="4"] > .form-actions {
    position: fixed !important; left: 0; right: 0; bottom: 0; z-index: 95;
    display: flex; align-items: center; gap: 10px;
    margin: 0 !important;
    padding: 10px 12px max(10px, env(safe-area-inset-bottom)) !important;
    background: rgba(255, 255, 255, .97); -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
    border-top: 1px solid var(--border); box-shadow: 0 -6px 22px rgba(15, 23, 42, .1);
  }
  .form-actions .btn { flex: 1; min-height: 48px; }
  .form-actions .btn-flow-back { flex: 0 0 auto; min-width: 72px; }
  .form-card[data-current-step="4"] > .form-actions #btn-flow-back,
  .form-card[data-current-step="4"] > .form-actions #btn-prev {
    flex: 1;
    min-width: 0;
  }

  /* ---------- 7. 名称固定一行 · 数值右对齐（修两行/折行） ---------- */
  .field { grid-template-columns: auto minmax(0, 1fr) !important; }
  .field > label, .field > .field-label, .field-label-row label { white-space: nowrap; }
  .field > input, .field > .mobile-select-button { justify-self: end; }
  .identity-stage .field { display: block !important; grid-template-columns: unset !important; }
  .identity-stage .field > .field-label-row { white-space: normal; display: none; }
  .identity-stage .field > .mobile-select-button { justify-self: stretch; width: 100%; text-align: left; }

  /* 缴费经历：标题一行、选项一行 */
  .career-mode-field { display: block !important; }
  .career-mode-field .field-label { display: block; margin-bottom: 10px; font-size: 14px; font-weight: 600; color: var(--text); }
  .career-mode-field .career-mode-toggle { margin-top: 0; }
  .career-mode-field > .field-hint { margin-top: 10px; }

  /* ---------- 9. 结果页：更有设计感的结论卡 ---------- */
  .step-panel[data-step="4"] .answer-panel {
    padding: 18px 16px;
    background: #fff; border: 1px solid var(--border-soft);
  }
  .answer-main { font-size: 17px !important; line-height: 1.7; }
  .answer-main strong { color: var(--primary-deep); }
  .answer-list {
    margin: 14px 0 0; padding: 14px 0 0; list-style: none;
    border-top: 1px solid var(--border-soft);
  }
  .answer-list li {
    position: relative; padding: 9px 0 9px 16px; margin: 0;
    border-bottom: 1px solid var(--border-soft);
    font-size: 15px; line-height: 1.55; color: var(--body);
  }
  .answer-list li:last-child { border-bottom: 0; }
  .answer-list li::before {
    content: ""; position: absolute; left: 2px; top: 16px;
    width: 5px; height: 5px; border-radius: 50%; background: var(--primary);
  }
  .answer-list li strong { color: var(--primary-deep); font-weight: 700; }
  .answer-details { margin-top: 14px; }
  .answer-details summary { font-size: 14px; font-weight: 600; color: var(--primary-deep); }
}


/* ============================================================
   v8 小程序真机稳定层 — 防放大 / 防漂移 / 统一安全边距
   ============================================================ */
@media (max-width: 640px) {
  :root {
    --mobile-gutter: 10px;
    --mobile-card-radius: 14px;
  }

  html,
  body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
    overscroll-behavior-x: none;
    -webkit-text-size-adjust: 100%;
  }

  body {
    touch-action: manipulation;
  }

  #app {
    width: 100%;
    max-width: 480px;
    overflow-x: hidden;
  }

  .main {
    padding-left: var(--mobile-gutter) !important;
    padding-right: var(--mobile-gutter) !important;
  }

  .hero {
    padding-left: var(--mobile-gutter) !important;
    padding-right: var(--mobile-gutter) !important;
  }

  body.flow-started .flow-appbar {
    margin-left: calc(-1 * var(--mobile-gutter)) !important;
    margin-right: calc(-1 * var(--mobile-gutter)) !important;
    padding-left: var(--mobile-gutter) !important;
    padding-right: var(--mobile-gutter) !important;
  }

  .field input,
  .field select,
  .field textarea,
  .field > input,
  .field > .mobile-select-button,
  .mobile-picker-search-wrap input,
  .segment-row-grid input,
  .segment-row-grid select,
  .compare-inline-grid input,
  .compare-col input {
    font-size: 16px !important;
  }

  .field > input {
    min-width: 7ch;
  }

  .mobile-select-button {
    min-width: 0;
  }

  body.mobile-picker-open {
    position: fixed;
    left: 0;
    right: 0;
    width: 100%;
    overflow: hidden;
  }

  .mobile-picker-sheet {
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    border-radius: 18px 18px 0 0;
    max-height: min(78vh, 620px);
  }

  .mobile-picker-head,
  .mobile-picker-search-wrap {
    padding-left: max(16px, env(safe-area-inset-left));
    padding-right: max(16px, env(safe-area-inset-right));
  }

  .mobile-picker-option,
  .mobile-picker-empty {
    padding-left: max(16px, env(safe-area-inset-left));
    padding-right: max(16px, env(safe-area-inset-right));
  }

  .mobile-picker-backdrop {
    touch-action: none;
  }

  .step-panel[data-step="4"] .answer-panel,
  .step-panel[data-step="4"] .answer-verdict,
  .step-panel[data-step="4"] .matrix-drawer,
  .workspace-head,
  .question-plain-intro {
    margin-left: 0 !important;
    margin-right: 0 !important;
    border-left: 1px solid var(--border-soft) !important;
    border-right: 1px solid var(--border-soft) !important;
    border-radius: var(--mobile-card-radius) !important;
  }

  .workspace-head {
    padding-left: var(--mobile-gutter) !important;
    padding-right: var(--mobile-gutter) !important;
  }

  .question-plain-intro {
    padding-left: var(--mobile-gutter) !important;
    padding-right: var(--mobile-gutter) !important;
  }

  #inline-answer .compare-table-wrap,
  #inline-answer .table-wrap,
  .table-wrap,
  .matrix-wrap {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
  }

  #inline-answer .answer-table-wrap {
    max-width: 100%;
    overflow-x: visible;
    overscroll-behavior-x: auto;
  }

  #inline-answer .compare-table,
  #inline-answer .result-table {
    width: max-content;
    min-width: 100%;
  }

  #inline-answer .answer-table {
    width: 100%;
    min-width: 0;
  }

  .hero-questions-panel {
    margin-top: 18px;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0;
    background: transparent !important;
    box-shadow: none !important;
  }

  .hero-q-caption {
    display: none !important;
  }

  .hero-q-card,
  .hero-q-tag {
    pointer-events: none !important;
    user-select: none;
    cursor: default !important;
  }

  .hero-q-card {
    padding: 14px 16px !important;
    border: 1px solid var(--border-soft) !important;
    background: #fff !important;
    box-shadow: 0 1px 2px rgba(20, 32, 43, 0.03) !important;
  }

  .hero-q-card::before,
  .hero-q-card:nth-child(3n + 1)::before,
  .hero-q-card:nth-child(3n + 2)::before,
  .hero-q-card:nth-child(3n)::before {
    background: var(--primary) !important;
  }

  .hero-q-card::after,
  .hero-q-tag::after {
    display: none !important;
  }

  .hero-q-card:hover,
  .hero-q-card:active,
  .hero-q-card:focus-visible {
    transform: none !important;
    box-shadow: 0 1px 2px rgba(20, 32, 43, .05) !important;
    outline: none !important;
  }

  body:not(.flow-started) .hero {
    padding-bottom: calc(68px + env(safe-area-inset-bottom)) !important;
  }

  body:not(.flow-started) .hero-cta-bar {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 2147483647 !important;
    width: 100vw !important;
    min-width: 100vw !important;
    max-width: 100vw !important;
    box-sizing: border-box !important;
    padding: 10px 0 max(10px, env(safe-area-inset-bottom)) !important;
    background: rgba(255, 255, 255, .97) !important;
    border-top: 1px solid var(--border) !important;
    box-shadow: 0 -6px 20px rgba(15, 23, 42, .10) !important;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
  }

  body:not(.flow-started) .hero-cta {
    position: static !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    border-radius: 0 !important;
    box-sizing: border-box !important;
    height: 48px !important;
    min-height: 48px !important;
    padding: 0 16px !important;
    line-height: 1 !important;
    margin: 0 !important;
    box-shadow: none !important;
  }
}


/* ============================================================
   v9 字体统一层 — 单一刻度 · 三字重体系（400 / 600 / 700）
   ============================================================ */
@media (max-width: 640px) {
  :root {
    --fw-body: 400;
    --fw-ui: 600;
    --fw-title: 700;
    --fs-caption: 12px;
    --fs-label: 13px;
    --fs-body: 14px;
    --fs-value: 15px;
    --fs-section: 16px;
    --fs-page: 19px;
  }

  body,
  #app {
    font-size: var(--fs-body);
    font-weight: var(--fw-body);
  }

  /* 说明 / 辅助 */
  .step-intro,
  .form-section-lead,
  .field-hint,
  .field-hint-compact,
  .question-hook,
  .workspace-subtitle,
  .gap-situation-card small,
  .table-legend,
  .matrix-legend,
  .footer,
  .flow-appbar-back {
    font-size: var(--fs-caption) !important;
    font-weight: var(--fw-body) !important;
  }

  /* 区块引导（含身份、推荐问题） */
  .question-spotlight-label {
    font-size: 15px !important;
    font-weight: var(--fw-title) !important;
    color: var(--primary) !important;
  }

  /* 表单：左标签 */
  .field > label,
  .field-label,
  .field-label-row label,
  .career-mode-label {
    font-size: var(--fs-label) !important;
    font-weight: var(--fw-ui) !important;
  }

  /* 表单：右数值 / 下拉 */
  .field > input,
  .field > select,
  .field > .mobile-select-button,
  .mobile-select-button,
  .mobile-picker-option,
  .segment-row-grid input,
  .segment-row-grid select {
    font-size: var(--fs-value) !important;
    font-weight: var(--fw-ui) !important;
  }

  /* 问题卡 / 主按钮 */
  .question-card,
  .question-card strong,
  .hero-q-tag,
  .btn,
  .btn-primary,
  .btn-accent,
  .btn-ghost,
  .btn-secondary,
  .category-tab,
  .mobile-picker-head button {
    font-size: var(--fs-value) !important;
    font-weight: var(--fw-ui) !important;
  }

  /* 页面 / 区块标题 */
  .step-header h2,
  #answer-q-title {
    font-size: var(--fs-page) !important;
    font-weight: var(--fw-title) !important;
  }

  .workspace-head h3,
  .form-section-title,
  .sub-section h3,
  .answer-subtable-title,
  .mini-card h4,
  .gap-situation-card strong {
    font-size: var(--fs-section) !important;
    font-weight: var(--fw-title) !important;
  }

  .workspace-label,
  .answer-verdict-label {
    font-size: var(--fs-caption) !important;
    font-weight: var(--fw-title) !important;
  }

  .answer-eyebrow,
  .answer-result-eyebrow {
    font-size: 15px !important;
    font-weight: var(--fw-title) !important;
    color: var(--primary) !important;
  }

  /* 正文 / 答案 */
  .answer-main,
  .answer-verdict-text,
  .answer-lead {
    font-size: var(--fs-value) !important;
    font-weight: var(--fw-body) !important;
  }

  .answer-main strong,
  .answer-verdict-text strong,
  .answer-lead strong {
    font-weight: var(--fw-title) !important;
  }

  /* 修正 v3 全局 400 重置造成的按钮发虚 */
  #app input,
  #app select,
  #app textarea {
    font-weight: var(--fw-ui) !important;
  }

  #app button:not(.hero-cta):not(.hero-q-card) {
    font-weight: var(--fw-ui) !important;
  }

  /* 开屏保留更重字重 */
  .hero-title,
  .hero-eyebrow,
  .hero-lead strong,
  .hero-q-body strong,
  .hero-more-wrap summary {
    font-weight: 800;
  }

  .hero-cta {
    font-size: 17px !important;
    font-weight: 800 !important;
  }
}


/* ============================================================
   v10 hero 问题列表 — 无外层框 · 卡片直出 · 统一青点
   ============================================================ */
@media (max-width: 640px) {
  .hero-questions-panel {
    margin-top: 16px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .hero-q-caption {
    display: none !important;
  }

  .hero-question-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  .hero-q-card {
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
    width: 100% !important;
    min-height: 0 !important;
    padding: 14px 16px !important;
    border: 1px solid var(--border-soft) !important;
    border-radius: 12px !important;
    background: #fff !important;
    box-shadow: 0 1px 2px rgba(20, 32, 43, 0.03) !important;
  }

  .hero-q-card::before {
    content: "" !important;
    flex: none !important;
    width: 6px !important;
    height: 6px !important;
    margin-top: 7px !important;
    border-radius: 50% !important;
    background: var(--primary) !important;
    font-size: 0 !important;
    line-height: 0 !important;
  }

  .hero-q-card:nth-child(3n + 1)::before,
  .hero-q-card:nth-child(3n + 2)::before,
  .hero-q-card:nth-child(3n)::before,
  .hero-q-card::before {
    background: var(--primary) !important;
  }

  .hero-q-card::after {
    display: none !important;
  }

  .hero-q-body strong {
    font-size: 15px !important;
    font-weight: 600 !important;
    line-height: 1.45 !important;
    color: var(--text) !important;
  }

  .hero-q-body span {
    display: block !important;
    font-size: 12px !important;
    color: var(--muted) !important;
    margin-top: 4px !important;
    line-height: 1.5 !important;
  }

  .hero-q-card:hover,
  .hero-q-card:active,
  .hero-q-card:focus-visible {
    transform: none !important;
    border-color: var(--border-soft) !important;
    background: #fff !important;
    box-shadow: 0 1px 2px rgba(20, 32, 43, 0.03) !important;
  }
}


/* ============================================================
   v11 更多问题 — 展开后与推荐问题卡片完全一致
   ============================================================ */
@media (max-width: 640px) {
  .question-more-wrap {
    margin-top: 8px !important;
    border: 0 !important;
    padding: 0 !important;
    background: transparent !important;
  }

  .question-more-wrap summary {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 0 10px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    color: var(--primary) !important;
  }

  .question-more-wrap summary::after {
    content: "";
    width: 7px;
    height: 7px;
    flex: none;
    border-right: 2px solid var(--primary);
    border-bottom: 2px solid var(--primary);
    transform: rotate(45deg);
    margin-top: -2px;
    transition: transform 0.15s ease;
  }

  .question-more-wrap[open] summary::after {
    transform: rotate(-135deg);
    margin-top: 2px;
  }

  .question-more-wrap .question-picker-compact {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    max-height: none !important;
    overflow: visible !important;
    padding: 0 !important;
  }

  .question-picker-compact .question-card,
  .question-picker-compact .question-card-featured {
    width: 100% !important;
    min-height: 58px !important;
    padding: 12px 14px !important;
    border: 1px solid var(--border) !important;
    border-radius: 14px !important;
    background: #fff !important;
    box-shadow: none !important;
    text-align: left !important;
  }

  .question-picker-compact .question-card.active,
  .question-picker-compact .question-card-featured.active {
    border-color: var(--primary) !important;
    background: var(--question-active-bg) !important;
    box-shadow: 0 0 0 1px var(--primary-ring) !important;
  }

  .question-picker-compact .question-card strong,
  .question-picker-compact .question-card-featured strong {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: var(--text) !important;
  }

  .question-picker-compact .question-hook,
  .question-picker-compact .question-card span {
    display: block !important;
    font-size: 12px !important;
    color: var(--muted) !important;
    margin-top: 3px !important;
  }
}


/* ============================================================
   v12 计发基数 — 堆叠布局，输入框全宽
   ============================================================ */
@media (max-width: 640px) {
  #custom-base-field {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px;
    grid-template-columns: unset !important;
  }

  #custom-base-field > .field-label-row {
    margin-bottom: 0;
    width: 100%;
  }

  #custom-base-field > input {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    text-align: left !important;
    justify-self: stretch !important;
    box-sizing: border-box;
  }
}


/* ============================================================
   v13 开屏问题卡 — 三隅微光（小光斑 · 非对称 · 纸感白底）
   ============================================================ */
.hero-q-card {
  --hero-q-surface:
    radial-gradient(80px 58px at calc(100% - 14px) 10px, rgba(1, 188, 214, 0.05) 0%, transparent 100%),
    radial-gradient(68px 50px at 12px 10px, rgba(227, 248, 251, 0.38) 0%, transparent 100%),
    radial-gradient(84px 62px at calc(100% - 10px) calc(100% - 10px), rgba(1, 188, 214, 0.028) 0%, transparent 100%),
    #ffffff;
  position: relative;
  isolation: isolate;
  overflow: hidden;
  border: none !important;
  background: var(--hero-q-surface) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.96),
    0 2px 6px rgba(20, 32, 43, 0.04),
    0 14px 36px -22px rgba(3, 118, 136, 0.11) !important;
}

@media (max-width: 640px) {
  .hero-q-card,
  .hero-q-card:hover,
  .hero-q-card:active,
  .hero-q-card:focus-visible {
    border: none !important;
    background: var(--hero-q-surface) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.96),
      0 2px 6px rgba(20, 32, 43, 0.04),
      0 14px 36px -22px rgba(3, 118, 136, 0.11) !important;
    outline: none !important;
  }
}

@media (prefers-reduced-transparency: reduce) {
  .hero-q-card {
    --hero-q-surface: #ffffff;
  }
}


/* ============================================================
   v14 流程顶栏 — 贴页面上边缘 · 安全区 · 全宽
   ============================================================ */
@media (max-width: 640px) {
  body.flow-started #app {
    padding-top: 0 !important;
  }

  body.flow-started .main {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  body.flow-started .flow-appbar {
    position: sticky;
    top: 0;
    z-index: 60;
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    margin-top: 0 !important;
    padding-top: env(safe-area-inset-top, 0);
    padding-right: max(10px, env(safe-area-inset-right, 0px)) !important;
    padding-left: max(10px, env(safe-area-inset-left, 0px)) !important;
    padding-bottom: 0 !important;
    min-height: calc(50px + env(safe-area-inset-top, 0px));
    height: auto;
    box-sizing: border-box;
    background: rgba(255, 255, 255, 0.97);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--border-soft);
  }
}


/* ============================================================
   v14 录入控件统一 — 全页边框 / 圆角 / 聚焦 / 条件隐藏
   ============================================================ */
.field input:not([type="radio"]):not([type="checkbox"]):focus-visible,
.field select:focus-visible,
.segment-row-grid input:focus-visible,
.segment-row-grid select:focus-visible,
.compare-inline-grid input:focus-visible,
.mobile-select-button:focus-visible {
  outline: none;
  border-color: var(--input-border-focus);
  box-shadow: var(--input-shadow-focus);
}

@media (max-width: 640px) {
  /* 一行式：标签左、录入框右，控件带边框 */
  .field > input:not([type="radio"]):not([type="checkbox"]),
  .field > .mobile-select-button {
    min-height: var(--input-height-compact) !important;
    padding: var(--input-pad-y) var(--input-pad-x) !important;
    border: var(--input-border) !important;
    border-radius: var(--input-radius) !important;
    background: var(--input-bg) !important;
    box-shadow: var(--input-shadow) !important;
    box-sizing: border-box;
  }

  .field > input:not([type="radio"]):not([type="checkbox"]) {
    min-width: 8ch;
    max-width: 100%;
  }

  .field > .mobile-select-button {
    justify-content: space-between;
    gap: 6px;
  }

  /* 身份 / 计发基数：标签上、控件下、全宽左对齐 */
  .identity-stage .field > .mobile-select-button,
  #custom-base-field > input {
    width: 100% !important;
    max-width: 100% !important;
    text-align: left !important;
    justify-self: stretch !important;
  }

  .identity-stage .field > .mobile-select-button {
    min-height: var(--input-height) !important;
    font-weight: 600;
  }

  /* 分段经历：小字段纵向堆叠 */
  .segment-row-grid .field {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 4px;
    padding: 0 !important;
    min-height: 0 !important;
    border-bottom: 0 !important;
    grid-template-columns: unset !important;
  }

  .segment-row-grid input,
  .segment-row-grid select,
  .segment-row-grid .mobile-select-button {
    width: 100% !important;
    text-align: left !important;
    justify-self: stretch !important;
  }

  .segment-row-grid .mobile-select-button {
    justify-content: space-between;
  }

  /* 对比区 */
  .compare-inline-grid input {
    text-align: left !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  #workspace-inputs .sub-section .field > .mobile-select-button {
    width: 100% !important;
    text-align: left !important;
    justify-content: space-between;
  }

  /* .field display 强制规则会盖掉 .hidden */
  .field.hidden,
  .field-grid .field.hidden,
  #gap-years-field.hidden,
  #gap-repaid-field.hidden {
    display: none !important;
  }
}


/* ============================================================
   v15 录入栏位 — 一栏一卡 · 标签在上 · 控件全宽一致
   ============================================================ */
@media (max-width: 640px) {
  /* 栏位组：不再合并成一张列表卡 */
  .field-grid,
  .field-grid-tight,
  .field-grid-3,
  .field-grid-core,
  .gap-fields-grid,
  #workspace-inputs .sub-section .field-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    padding: 0 !important;
    margin-top: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  /* 区块容器只保留标题，不再套一层大白卡 */
  .form-section-core,
  .gap-section.form-section,
  .form-section-details {
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .form-section-core .form-section-head,
  .gap-section .form-section-head {
    padding: 0 2px 10px;
    margin-bottom: 0;
  }

  .form-section-core .form-section-title,
  .gap-section .form-section-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--text);
  }

  .form-section-core .form-section-lead,
  .gap-section .form-section-lead {
    margin-top: 4px;
  }

  .gap-section .form-section-lead.field-hint {
    display: flex;
    align-items: flex-start;
    gap: 7px;
    margin-top: 6px;
    color: var(--primary);
    font-weight: 500;
    font-size: 12px;
    line-height: 1.5;
  }

  /* 标准录入栏：独立卡片 + 纵向堆叠 */
  .field-grid > .field,
  .field-grid-tight > .field,
  .field-grid-core > .field,
  .gap-fields-grid > .field,
  #workspace-inputs .sub-section > .field {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
    grid-template-columns: unset !important;
    min-height: 0 !important;
    padding: 14px 16px !important;
    border: 1px solid #edf1f3 !important;
    border-radius: 14px !important;
    background: #fff !important;
    box-shadow: 0 1px 2px rgba(20, 32, 43, .03), 0 8px 20px -14px rgba(20, 32, 43, .16) !important;
  }

  .field-grid > .field:last-child,
  .field-grid-tight > .field:last-child,
  .field-grid-core > .field:last-child,
  .gap-fields-grid > .field:last-child {
    border-bottom: 1px solid #edf1f3 !important;
  }

  .field-grid > .field > label,
  .field-grid-tight > .field > label,
  .field-grid-core > .field > label,
  .gap-fields-grid > .field > label,
  #workspace-inputs .sub-section > .field > label,
  .field-grid > .field > .field-label-row,
  .field-grid-tight > .field > .field-label-row,
  .field-grid-core > .field > .field-label-row,
  .gap-fields-grid > .field > .field-label-row,
  #workspace-inputs .sub-section > .field > .field-label-row {
    width: 100% !important;
    margin: 0 !important;
    white-space: normal !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--text) !important;
    grid-column: unset !important;
    grid-row: unset !important;
    order: unset !important;
  }

  .field-grid > .field > .field-label-row label,
  .field-grid-tight > .field > .field-label-row label,
  .field-grid-core > .field > .field-label-row label,
  .gap-fields-grid > .field > .field-label-row label,
  #workspace-inputs .sub-section > .field > .field-label-row label {
    white-space: normal !important;
    font-weight: 600 !important;
    color: var(--text) !important;
  }

  .field-grid > .field > input:not([type="radio"]):not([type="checkbox"]),
  .field-grid-tight > .field > input:not([type="radio"]):not([type="checkbox"]),
  .field-grid-core > .field > input:not([type="radio"]):not([type="checkbox"]),
  .gap-fields-grid > .field > input:not([type="radio"]):not([type="checkbox"]),
  #workspace-inputs .sub-section > .field > input:not([type="radio"]):not([type="checkbox"]),
  .field-grid > .field > .mobile-select-button,
  .field-grid-tight > .field > .mobile-select-button,
  .field-grid-core > .field > .mobile-select-button,
  .gap-fields-grid > .field > .mobile-select-button,
  #workspace-inputs .sub-section > .field > .mobile-select-button {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    text-align: left !important;
    justify-content: space-between !important;
    justify-self: stretch !important;
    align-self: stretch !important;
    flex: none !important;
    order: unset !important;
    grid-column: unset !important;
    grid-row: unset !important;
  }

  .field-grid > .field > .field-hint,
  .field-grid-tight > .field > .field-hint,
  .field-grid-core > .field > .field-hint,
  .gap-fields-grid > .field > .field-hint,
  #workspace-inputs .sub-section > .field > .field-hint,
  .field-grid > .field > .province-source-banner,
  .field-grid-tight > .field > .province-source-banner,
  .field-grid-core > .field > .province-source-banner,
  .field-grid > .field > .account-balance-estimate,
  .field-grid-core > .field > .account-balance-estimate,
  .field-grid > .field > .field-error,
  .field-grid-core > .field > .field-error,
  .field-grid > .field > .btn-link,
  .field-grid-core > .field > .btn-link {
    width: 100% !important;
    order: unset !important;
    grid-column: unset !important;
    margin: 0 !important;
  }

  .field-grid-core > .field.span-2,
  .field-grid-tight > .field.span-2 {
    grid-column: unset !important;
  }
}


/* ============================================================
   v16 步骤条 — 单行紧凑：数字 + 文案并排
   ============================================================ */
@media (max-width: 640px) {
  .wizard-progress {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    padding: 6px 2px !important;
    gap: 0 !important;
    margin-bottom: 8px !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: var(--bg) !important;
    border: 0 !important;
    box-sizing: border-box;
  }

  .wizard-progress .progress-step {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
    width: 100% !important;
    min-height: 0 !important;
    min-width: 0 !important;
    padding: 2px 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
    box-sizing: border-box;
  }

  .wizard-progress .progress-step:first-of-type {
    justify-content: flex-start !important;
  }

  .wizard-progress .progress-step:last-of-type {
    justify-content: flex-end !important;
  }

  .wizard-progress .step-num {
    width: 18px !important;
    height: 18px !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    flex: none !important;
    box-shadow: none !important;
  }

  .wizard-progress .progress-step.active .step-num {
    background: var(--accent-90) !important;
    color: #fff !important;
    box-shadow: none !important;
  }

  .wizard-progress .step-text {
    min-width: 0;
    flex: 0 1 auto;
    text-align: center;
  }

  .wizard-progress .step-text strong {
    display: inline !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
    white-space: nowrap;
    text-align: center;
  }
}


/* ============================================================
   v21 开屏问题卡 — 渐变最终层（覆盖 #fff 重置 · 与 v13 同栈）
   ============================================================ */
.hero-q-card {
  overflow: hidden;
}

@media (max-width: 640px) {
  .hero-q-card,
  .hero-q-card:hover,
  .hero-q-card:active,
  .hero-q-card:focus-visible {
    background: var(--hero-q-surface, #ffffff) !important;
    border: none !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.96),
      0 2px 6px rgba(20, 32, 43, 0.04),
      0 14px 36px -22px rgba(3, 118, 136, 0.11) !important;
    outline: none !important;
  }
}


/* ============================================================
   v22 开屏问题卡 — 边缘最终层（去描边 · 统一 hover）
   ============================================================ */
@media (max-width: 640px) {
  .hero-q-card,
  .hero-q-card:hover,
  .hero-q-card:active,
  .hero-q-card:focus-visible {
    border: 0 !important;
    border-color: transparent !important;
  }
}


/* ============================================================
   v18 流程页全白底（最终层）
   ============================================================ */
@media (max-width: 640px) {
  html,
  body,
  body.flow-started,
  #app,
  body.flow-started #app,
  .main,
  body.flow-started .main {
    background: #ffffff !important;
  }
}


/* ============================================================
   v20 步骤条 — 四步等分 · 与 step-header 左右对齐
   ============================================================ */
@media (max-width: 640px) {
  body.flow-started .wizard-progress,
  .wizard-progress {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 2px !important;
    padding-right: 2px !important;
    gap: 0 !important;
    box-sizing: border-box;
  }

  .wizard-progress .progress-step:first-of-type {
    justify-content: flex-start !important;
  }

  .wizard-progress .progress-step:last-of-type {
    justify-content: flex-end !important;
  }

  .wizard-progress .progress-step:not(:first-of-type):not(:last-of-type) {
    justify-content: center !important;
  }
}


/* ============================================================
   v23 步骤条 — 短线连接 · 等间距 · 与 step-header 对齐
   ============================================================ */
@media (max-width: 640px) {
  body.flow-started .wizard-progress,
  .wizard-progress {
    display: grid !important;
    grid-template-columns: auto 1fr auto 1fr auto 1fr auto !important;
    align-items: center !important;
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 6px 2px !important;
    gap: 0 !important;
    box-sizing: border-box;
  }

  .wizard-progress .progress-line {
    display: block !important;
    width: 10px !important;
    height: 1px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 999px !important;
    background: rgba(186, 198, 207, 0.38) !important;
    justify-self: center !important;
    align-self: center !important;
  }

  .wizard-progress .progress-step {
    display: flex !important;
    flex: none !important;
    width: auto !important;
    max-width: none !important;
    justify-content: center !important;
  }

  .wizard-progress .progress-step:first-of-type {
    justify-self: start !important;
  }

  .wizard-progress .progress-step:last-of-type {
    justify-self: end !important;
  }
}


/* ============================================================
   v23 开屏 — 右上背景插画 + 白底渐隐（仅首页 hero）
   ============================================================ */
body:not(.flow-started) .hero {
  position: relative;
  overflow: hidden;
  background: #ffffff !important;
  border-bottom: 0 !important;
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.hero-bg img {
  position: absolute;
  top: max(-6px, env(safe-area-inset-top, 0px));
  right: -18px;
  width: min(68vw, 320px);
  height: auto;
  object-fit: contain;
  object-position: top right;
  user-select: none;
  -webkit-user-drag: none;
}

.hero-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.04) 42%, rgba(255, 255, 255, 0.72) 72%, #ffffff 86%),
    linear-gradient(90deg, rgba(255, 255, 255, 0.82) 0%, rgba(255, 255, 255, 0.28) 34%, rgba(255, 255, 255, 0) 62%);
}

body:not(.flow-started) .hero-inner {
  position: relative;
  z-index: 1;
}

@media (min-width: 641px) {
  .hero-bg img {
    right: -12px;
    width: min(44vw, 460px);
  }
}

@media (prefers-reduced-transparency: reduce) {
  .hero-bg::after {
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.55) 0%, #ffffff 72%),
      linear-gradient(90deg, rgba(255, 255, 255, 0.85) 0%, rgba(255, 255, 255, 0.35) 45%, rgba(255, 255, 255, 0) 70%);
  }
}


/* ============================================================
   v24 底部操作栏 — 答案页双按钮等宽
   ============================================================ */
@media (max-width: 640px) {
  .form-card > .form-actions {
    display: grid !important;
    grid-template-columns: minmax(92px, 31%) minmax(0, 1fr);
    column-gap: 10px !important;
    row-gap: 0;
    align-items: stretch;
  }

  .form-card[data-current-step="1"] > .form-actions {
    grid-template-columns: minmax(0, 1fr);
  }

  .form-card[data-current-step="1"] > .form-actions .action-right {
    grid-column: 1 / -1;
    display: flex !important;
  }

  .form-card[data-current-step="2"] > .form-actions #btn-prev,
  .form-card[data-current-step="3"] > .form-actions #btn-prev {
    grid-column: 1;
    grid-row: 1;
  }

  .form-card[data-current-step="2"] > .form-actions .action-right,
  .form-card[data-current-step="3"] > .form-actions .action-right {
    grid-column: 2;
    grid-row: 1;
    display: flex !important;
  }

  .form-card[data-current-step="4"] > .form-actions {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }

  .form-card[data-current-step="4"] > .form-actions #btn-flow-back {
    grid-column: 1;
    grid-row: 1;
  }

  .form-card[data-current-step="4"] > .form-actions #btn-prev {
    grid-column: 2;
    grid-row: 1;
  }

  .form-card[data-current-step="4"] > .form-actions .action-right {
    display: none !important;
  }

  .form-card > .form-actions .action-right {
    flex: none !important;
    width: 100%;
    min-width: 0;
  }

  .form-card > .form-actions #btn-prev,
  .form-card > .form-actions #btn-flow-back,
  .form-card > .form-actions .action-right .btn-primary {
    width: 100%;
    min-width: 0 !important;
    max-width: none !important;
    min-height: 48px !important;
    margin: 0 !important;
    flex: none !important;
    border-radius: 12px !important;
    box-sizing: border-box;
  }

  .form-card > .form-actions #btn-prev,
  .form-card > .form-actions #btn-flow-back {
    padding: 0 10px !important;
    font-size: var(--text-base) !important;
    font-weight: 600 !important;
    border: 1px solid var(--border) !important;
    background: #fff !important;
    box-shadow: none !important;
    justify-content: center !important;
    text-align: center !important;
    position: relative !important;
  }

  .form-card > .form-actions #btn-prev {
    color: var(--primary-deep) !important;
  }

  .form-card > .form-actions #btn-flow-back {
    color: #01BCD6 !important;
  }

  .form-card > .form-actions .action-right .btn-primary,
  .form-card[data-current-step="4"] > .form-actions #btn-prev {
    padding: 0 14px !important;
    border: 0 !important;
    background: var(--primary) !important;
    color: #fff !important;
    font-weight: 600 !important;
    box-shadow: none !important;
  }

  .form-card > .form-actions .action-right .btn-primary {
    flex: 1;
    width: 100%;
  }
}


/* ============================================================
   v25 中断快览 — 嵌入「是否已补缴」卡片内
   ============================================================ */
@media (max-width: 640px) {
  .gap-fields-grid > #gap-repaid-field .gap-guidance-banner {
    width: 100%;
    margin-top: 4px;
    padding-top: 10px;
    border-top: 1px solid #eef2f4;
  }

  .gap-fields-grid > #gap-repaid-field .gap-guidance-inner {
    padding: 11px 12px;
    border-radius: 11px;
  }

  .gap-fields-grid > #gap-repaid-field .gap-guidance-metrics {
    gap: 6px;
  }

  .gap-fields-grid > #gap-repaid-field .gap-guidance-metric {
    padding: 7px 8px;
  }

  .gap-fields-grid > #gap-repaid-field .gap-guidance-metric strong {
    font-size: 13px;
  }
}


/* ============================================================
   v26 答案明细表 — 手机端卡片化，无需横滑
   ============================================================ */
@media (max-width: 640px) {
  #inline-answer .answer-table-wrap {
    overflow: visible;
    margin-top: 12px;
  }

  #inline-answer .answer-table {
    display: block;
    width: 100%;
    min-width: 0;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 13px;
  }

  #inline-answer .answer-table thead {
    display: none;
  }

  #inline-answer .answer-table tbody {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }

  #inline-answer .answer-table tr {
    display: block;
    border: 1px solid var(--border);
    border-radius: 12px;
    background: #fff;
    overflow: hidden;
    box-shadow: var(--shadow);
  }

  #inline-answer .answer-table tr.row-best {
    border-color: var(--primary-muted);
    box-shadow: inset 0 0 0 1px var(--primary-muted);
  }

  #inline-answer .answer-table td {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr);
    column-gap: 10px;
    align-items: start;
    padding: 10px 12px;
    border-bottom: 1px solid var(--border-soft);
    white-space: normal;
    word-break: break-word;
    text-align: left;
    line-height: 1.45;
  }

  #inline-answer .answer-table td::before {
    content: attr(data-label);
    font-size: 11px;
    font-weight: 600;
    color: var(--muted);
    line-height: 1.35;
  }

  #inline-answer .answer-table td[data-label=""]::before {
    content: none;
  }

  #inline-answer .answer-table td:first-child {
    display: block;
    padding: 12px 12px 10px;
    border-bottom: 1px solid var(--border-soft);
    background: var(--primary-20);
    font-size: 15px;
    font-weight: 700;
    color: var(--text);
  }

  #inline-answer .answer-table td:first-child::before {
    display: none;
  }

  #inline-answer .answer-table td:last-child {
    border-bottom: 0;
    font-weight: 700;
    color: var(--text);
  }

  #inline-answer .answer-subtable-title {
    margin-top: 16px;
  }

  /* 几岁领对比：紧凑双行卡片，避免四行堆叠过高 */
  #inline-answer .answer-table--ladder tbody {
    gap: 8px;
  }

  #inline-answer .answer-table--ladder tr {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-rows: auto auto;
    grid-template-areas:
      "age note"
      "monthly net";
    gap: 4px 12px;
    padding: 10px 12px;
    min-height: 0;
    height: auto;
    overflow: visible;
  }

  #inline-answer .answer-table--ladder tr.row-best {
    border-color: var(--primary-muted);
    background: linear-gradient(180deg, rgba(1, 188, 214, 0.1) 0%, #fff 72%);
    box-shadow: inset 0 0 0 1px var(--primary-muted);
  }

  #inline-answer .answer-table--ladder td {
    display: block;
    padding: 0;
    border: 0;
    min-height: 0;
  }

  #inline-answer .answer-table--ladder td::before {
    display: none;
  }

  #inline-answer .answer-table--ladder td:first-child {
    grid-area: age;
    background: transparent;
    padding: 0;
    font-size: 16px;
    font-weight: 700;
    color: var(--text);
    line-height: 1.2;
  }

  #inline-answer .answer-table--ladder td:nth-child(2) {
    grid-area: note;
    justify-self: end;
    align-self: start;
    display: flex;
    justify-content: flex-end;
    flex-wrap: nowrap;
    gap: 4px;
    text-align: right;
    max-width: none;
    width: auto;
  }

  #inline-answer .answer-table--ladder td:nth-child(2) .answer-tag-group {
    display: inline-flex;
    flex-wrap: nowrap;
    justify-content: flex-end;
    align-items: center;
    gap: 4px;
    white-space: nowrap;
  }

  #inline-answer .answer-table--ladder td:nth-child(3) {
    grid-area: monthly;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.25;
    color: var(--primary-deep);
    font-variant-numeric: tabular-nums;
  }

  #inline-answer .answer-table--ladder td:nth-child(4) {
    grid-area: net;
    justify-self: end;
    align-self: end;
    text-align: right;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.25;
    color: var(--body);
    font-variant-numeric: tabular-nums;
  }

  #inline-answer .answer-table--ladder td:nth-child(4)::before {
    display: inline;
    content: "净拿 ";
    font-size: 11px;
    font-weight: 600;
    color: var(--muted);
  }
}


/* ============================================================
   v27 顾问式小程序视觉层 — 流程校正 + 视觉系统收口
   ============================================================ */
:root {
  --advisor-bg: #f4f8f7;
  --advisor-surface: #ffffff;
  --advisor-surface-2: #f8fbfa;
  --advisor-ink: #17262d;
  --advisor-body: #465a63;
  --advisor-muted: #71828a;
  --advisor-line: #e2ebeb;
  --advisor-line-soft: #edf3f3;
  --advisor-primary: #087f8f;
  --advisor-primary-2: #0aa7b7;
  --advisor-primary-soft: #e7f7f7;
  --advisor-gold: #a66d16;
  --advisor-gold-soft: #fff5df;
  --advisor-radius: 14px;
  --advisor-radius-lg: 18px;
  --mini-gutter: 12px;
  --bottom-action-height: 68px;
}

html {
  background: var(--advisor-bg);
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  background: var(--advisor-bg);
  color: var(--advisor-ink);
  overscroll-behavior-x: none;
}

@media (min-width: 641px) {
  body {
    background: #eaf2f1;
  }

  #app {
    max-width: 430px;
    min-height: 100vh;
    background: var(--advisor-bg);
    box-shadow: 0 24px 70px rgba(14, 34, 38, 0.12);
  }

  .main,
  .hero-inner,
  .form-card {
    max-width: 430px;
  }

  body:not(.flow-started) .main {
    display: none;
  }
}

@media (max-width: 640px) {
  html,
  body,
  #app {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
    background: var(--advisor-bg) !important;
  }

  body {
    touch-action: pan-y;
  }

  body.mobile-picker-open {
    touch-action: none;
  }

  #app {
    margin: 0 auto;
  }

  #app input,
  #app select,
  #app textarea,
  #app button {
    font-family: var(--font);
  }

  #app input,
  #app textarea,
  .mobile-select-button,
  .mobile-picker-search-wrap input {
    font-size: 16px !important;
  }

  body:not(.flow-started) .main,
  body:not(.flow-started) .disclaimer,
  body:not(.flow-started) .footer,
  body:not(.flow-started) #data-version {
    display: none !important;
  }

  body:not(.flow-started) .hero {
    min-height: 100dvh;
    padding: max(24px, env(safe-area-inset-top)) var(--mini-gutter)
      calc(88px + env(safe-area-inset-bottom)) !important;
    background:
      radial-gradient(circle at 82% 12%, rgba(10, 167, 183, 0.18) 0, rgba(10, 167, 183, 0) 34%),
      linear-gradient(180deg, #f5fbfb 0%, #ffffff 54%, #f4f8f7 100%) !important;
    border-bottom: 0 !important;
  }

  .hero-bg img {
    top: 4px;
    right: -34px;
    width: min(70vw, 292px);
    opacity: 0.72;
  }

  .hero-bg::after {
    background:
      linear-gradient(180deg, rgba(245, 251, 251, 0.08) 0%, rgba(255, 255, 255, 0.66) 56%, #f4f8f7 92%),
      linear-gradient(90deg, rgba(245, 251, 251, 0.94) 0%, rgba(255, 255, 255, 0.64) 44%, rgba(255, 255, 255, 0) 74%) !important;
  }

  body:not(.flow-started) .hero-inner {
    max-width: none;
    min-height: calc(100dvh - 128px - env(safe-area-inset-bottom));
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
  }

  .hero-eyebrow {
    width: max-content;
    margin: 10px 0 16px !important;
    padding: 5px 10px;
    border: 1px solid rgba(8, 127, 143, 0.18);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.78);
    color: var(--advisor-primary) !important;
    font-size: 12px !important;
    font-weight: 700;
    letter-spacing: 0 !important;
  }

  .hero-title {
    max-width: 10em;
    color: var(--advisor-ink) !important;
    font-size: 30px !important;
    line-height: 1.16 !important;
    letter-spacing: 0 !important;
    font-weight: 800 !important;
  }

  .hero-highlight {
    color: var(--advisor-primary) !important;
  }

  .hero-scope-hint {
    display: flex !important;
    align-items: flex-start;
    gap: 8px;
    width: fit-content;
    max-width: min(100%, 312px);
    margin: 14px 0 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: var(--advisor-body) !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 1.55 !important;
    letter-spacing: 0 !important;
  }

  .hero-scope-hint::before {
    width: 7px !important;
    height: 7px !important;
    margin-top: 7px;
    background: var(--advisor-gold) !important;
    box-shadow: 0 0 0 4px rgba(166, 109, 22, 0.12) !important;
  }

  .hero-questions-panel {
    margin-top: 28px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .hero-questions-head {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin: 0 2px 10px !important;
  }

  .hero-questions-head strong {
    color: var(--advisor-ink) !important;
    font-size: 15px !important;
    font-weight: 700 !important;
  }

  .hero-questions-head span {
    color: var(--advisor-muted) !important;
    font-size: 12px !important;
    line-height: 1.3;
    white-space: nowrap;
  }

  .hero-question-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    margin: 0 !important;
  }

  .hero-q-card,
  .hero-q-card:hover,
  .hero-q-card:active,
  .hero-q-card:focus-visible {
    position: relative;
    display: block !important;
    min-height: 0 !important;
    padding: 13px 14px 13px 34px !important;
    border: 1px solid rgba(226, 235, 235, 0.95) !important;
    border-radius: var(--advisor-radius) !important;
    background: rgba(255, 255, 255, 0.9) !important;
    color: var(--advisor-ink) !important;
    box-shadow: 0 2px 8px rgba(14, 34, 38, 0.045) !important;
    pointer-events: none !important;
    cursor: default !important;
    user-select: none;
    transform: none !important;
    outline: none !important;
  }

  .hero-q-card::before,
  .hero-q-card:nth-child(3n + 1)::before,
  .hero-q-card:nth-child(3n + 2)::before,
  .hero-q-card:nth-child(3n)::before {
    content: "";
    position: absolute;
    left: 15px;
    top: 19px;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--advisor-primary-2) !important;
    box-shadow: 0 0 0 4px rgba(10, 167, 183, 0.1);
  }

  .hero-q-card::after,
  .hero-q-tag::after {
    display: none !important;
  }

  .hero-q-kicker {
    display: inline-flex;
    margin-bottom: 4px;
    color: var(--advisor-gold);
    font-size: 11px;
    font-weight: 700;
    line-height: 1;
  }

  .hero-q-body {
    display: block !important;
  }

  .hero-q-body strong {
    display: block;
    color: var(--advisor-ink);
    font-size: 15px !important;
    font-weight: 700 !important;
    line-height: 1.38 !important;
  }

  .hero-q-body span {
    display: block;
    margin-top: 3px;
    color: var(--advisor-muted) !important;
    font-size: 12px !important;
    line-height: 1.45 !important;
  }

  .hero-coverage-note,
  .hero-more-wrap {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin: 12px 2px 0 !important;
    padding: 10px 12px !important;
    border: 1px solid rgba(8, 127, 143, 0.12) !important;
    border-radius: 999px !important;
    background: rgba(231, 247, 247, 0.72) !important;
    color: var(--advisor-body) !important;
    font-size: 12px !important;
    line-height: 1.3;
    pointer-events: none;
  }

  .hero-coverage-note strong {
    color: var(--advisor-primary);
    font-size: 12px;
    white-space: nowrap;
  }

  .hero-question-tags {
    display: none !important;
  }

  body:not(.flow-started) .hero-cta-bar {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 90 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    padding: 10px 0 max(10px, env(safe-area-inset-bottom)) !important;
    border-top: 1px solid rgba(226, 235, 235, 0.95) !important;
    background: rgba(255, 255, 255, 0.98) !important;
    box-shadow: 0 -8px 22px rgba(14, 34, 38, 0.08) !important;
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
  }

  body:not(.flow-started) .hero-cta {
    position: static !important;
    width: 100% !important;
    height: 48px !important;
    min-height: 48px !important;
    margin: 0 !important;
    padding: 0 16px !important;
    border-radius: 0 !important;
    background: var(--advisor-primary-2) !important;
    color: #fff !important;
    box-shadow: none !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    line-height: 48px !important;
  }

  body.flow-started .hero,
  body.flow-started .hero-cta-bar {
    display: none !important;
  }

  body.flow-started #app,
  body.flow-started .main {
    background: var(--advisor-bg) !important;
  }

  .main {
    margin: 0 auto !important;
    padding: 0 var(--mini-gutter) calc(86px + env(safe-area-inset-bottom)) !important;
  }

  .form-card {
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .wizard-progress,
  body.flow-started .wizard-progress {
    position: sticky;
    top: 0;
    z-index: 50;
    display: grid !important;
    grid-template-columns: auto 1fr auto 1fr auto 1fr auto !important;
    align-items: center !important;
    gap: 0 !important;
    margin: 0 calc(-1 * var(--mini-gutter)) 0 !important;
    padding: 9px var(--mini-gutter) 8px !important;
    border: 0 !important;
    border-bottom: 1px solid var(--advisor-line-soft) !important;
    border-radius: 0 !important;
    background: rgba(244, 248, 247, 0.96) !important;
    box-shadow: none !important;
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
  }

  .wizard-progress .progress-line {
    display: block !important;
    width: 12px !important;
    height: 1px !important;
    background: rgba(113, 130, 138, 0.26) !important;
  }

  .wizard-progress .progress-step {
    padding: 0 !important;
    gap: 4px !important;
    background: transparent !important;
    opacity: 1 !important;
  }

  .wizard-progress .step-num {
    width: 18px !important;
    height: 18px !important;
    background: #dce7e7 !important;
    color: var(--advisor-muted) !important;
    font-size: 10px !important;
    box-shadow: none !important;
  }

  .wizard-progress .progress-step.done .step-num,
  .wizard-progress .progress-step.active .step-num {
    background: var(--advisor-primary-2) !important;
    color: #fff !important;
  }

  .wizard-progress .step-text strong {
    color: var(--advisor-muted) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0 !important;
  }

  .wizard-progress .progress-step.active .step-text strong {
    color: var(--advisor-ink) !important;
    font-weight: 700 !important;
  }

  .step-panel {
    padding: 14px 0 0;
  }

  .step-header {
    margin: 0 2px 12px !important;
    padding: 2px 0 0 !important;
  }

  .step-header h2,
  #answer-q-title {
    color: var(--advisor-ink) !important;
    font-size: 21px !important;
    font-weight: 800 !important;
    line-height: 1.28 !important;
    letter-spacing: 0 !important;
  }

  .step-intro {
    margin-top: 8px !important;
    padding: 10px 12px !important;
    border: 1px solid rgba(8, 127, 143, 0.12) !important;
    border-radius: var(--advisor-radius) !important;
    background: rgba(231, 247, 247, 0.68) !important;
    color: var(--advisor-body) !important;
    font-size: 13px !important;
    line-height: 1.55 !important;
  }

  .lookup-guide,
  .form-section-details,
  .form-section-core,
  .gap-section.form-section,
  #multi-career-fields.form-section,
  .sub-section {
    margin-top: 12px !important;
    margin-bottom: 12px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .lookup-guide {
    overflow: hidden !important;
    border: 1px solid var(--advisor-line) !important;
    border-radius: var(--advisor-radius) !important;
    background: var(--advisor-surface) !important;
  }

  .lookup-guide-summary,
  .form-section-details > summary {
    padding: 12px 14px !important;
    color: var(--advisor-primary) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
  }

  .lookup-guide-body {
    border-top: 1px solid var(--advisor-line-soft) !important;
    background: #fff !important;
  }

  .form-section-head {
    margin: 2px 2px 10px !important;
    padding: 0 !important;
  }

  .form-section-title,
  .sub-section h3 {
    color: var(--advisor-ink) !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    line-height: 1.35 !important;
  }

  .form-section-lead,
  .field-hint,
  .field-hint-compact {
    color: var(--advisor-muted) !important;
    font-size: 12px !important;
    line-height: 1.55 !important;
  }

  .field-hint::before,
  .field-hint-compact::before,
  .province-source-banner::before {
    background: var(--advisor-primary-2) !important;
  }

  .field-grid,
  .field-grid-tight,
  .field-grid-3,
  .field-grid-core,
  .gap-fields-grid,
  #workspace-inputs .sub-section .field-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    padding: 0 !important;
    margin: 0 0 12px !important;
    overflow: hidden !important;
    border: 1px solid var(--advisor-line) !important;
    border-radius: var(--advisor-radius-lg) !important;
    background: var(--advisor-surface) !important;
    box-shadow: none !important;
  }

  .field-grid > .field,
  .field-grid-tight > .field,
  .field-grid-core > .field,
  .gap-fields-grid > .field,
  #workspace-inputs .sub-section > .field,
  #workspace-inputs .sub-section .field-grid > .field {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    padding: 14px !important;
    min-height: 0 !important;
    border: 0 !important;
    border-bottom: 1px solid var(--advisor-line-soft) !important;
    border-radius: 0 !important;
    background: #fff !important;
    box-shadow: none !important;
  }

  .field-grid > .field:last-child,
  .field-grid-tight > .field:last-child,
  .field-grid-core > .field:last-child,
  .gap-fields-grid > .field:last-child,
  #workspace-inputs .sub-section .field-grid > .field:last-child {
    border-bottom: 0 !important;
  }

  .field.hidden,
  .field-grid .field.hidden,
  #gap-years-field.hidden,
  #gap-repaid-field.hidden {
    display: none !important;
  }

  .field label,
  .field-label,
  .field-label-row label {
    color: var(--advisor-ink) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 1.35 !important;
    white-space: normal !important;
  }

  .field input:not([type="radio"]):not([type="checkbox"]),
  .field > .mobile-select-button,
  .segment-row-grid input,
  .segment-row-grid .mobile-select-button,
  .compare-inline-grid input {
    width: 100% !important;
    min-height: 44px !important;
    padding: 10px 12px !important;
    border: 1px solid #dce7e8 !important;
    border-radius: 11px !important;
    background: var(--advisor-surface-2) !important;
    box-shadow: none !important;
    color: var(--advisor-ink) !important;
    text-align: left !important;
  }

  .field input::placeholder {
    color: #7b8c94 !important;
  }

  .mobile-select-button {
    justify-content: space-between !important;
  }

  .field input:focus,
  .field select:focus,
  .mobile-select-button:focus-visible {
    border-color: rgba(8, 127, 143, 0.48) !important;
    box-shadow: 0 0 0 3px rgba(8, 127, 143, 0.12) !important;
  }

  .province-source-banner,
  .contribution-eligibility-banner,
  .gap-guidance-banner,
  .policy-banner {
    border: 1px solid rgba(8, 127, 143, 0.12) !important;
    border-radius: var(--advisor-radius) !important;
    background: var(--advisor-primary-soft) !important;
    color: var(--advisor-body) !important;
    box-shadow: none !important;
  }

  #policy-bounds-banner {
    display: block !important;
    margin: 0 0 12px !important;
    padding: 12px 14px !important;
  }

  .question-category-tabs {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px !important;
    margin: 0 0 12px !important;
    padding: 4px !important;
    border: 1px solid var(--advisor-line) !important;
    border-radius: 999px !important;
    background: #fff !important;
  }

  .category-tab {
    min-height: 36px !important;
    border: 0 !important;
    border-radius: 999px !important;
    background: transparent !important;
    color: var(--advisor-muted) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
  }

  .category-tab.active {
    background: var(--advisor-primary-2) !important;
    color: #fff !important;
    box-shadow: none !important;
  }

  .question-choice-stage,
  .question-picker-root,
  .question-spotlight {
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .question-spotlight-label {
    margin: 0 2px 10px !important;
    color: var(--advisor-body) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    line-height: 1.45 !important;
  }

  .question-featured,
  .question-picker-compact {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
  }

  .question-card,
  .question-card-featured {
    display: block !important;
    width: 100% !important;
    min-height: 0 !important;
    padding: 15px 16px !important;
    border: 1px solid var(--advisor-line) !important;
    border-radius: var(--advisor-radius-lg) !important;
    background: #fff !important;
    box-shadow: none !important;
    color: var(--advisor-ink) !important;
    text-align: left !important;
  }

  .question-card.active,
  .question-card-featured.active {
    border-color: rgba(10, 167, 183, 0.5) !important;
    background: linear-gradient(180deg, #ffffff 0%, #eefafa 100%) !important;
    box-shadow: inset 0 0 0 1px rgba(10, 167, 183, 0.18) !important;
  }

  .question-card strong {
    display: block;
    color: var(--advisor-ink) !important;
    font-size: 15px !important;
    font-weight: 800 !important;
    line-height: 1.36 !important;
  }

  .question-hook,
  .question-card span {
    display: block;
    margin-top: 4px;
    color: var(--advisor-muted) !important;
    font-size: 12px !important;
    line-height: 1.48 !important;
  }

  .question-teaser {
    margin-top: 8px !important;
    padding: 7px 9px !important;
    border-radius: 10px !important;
    background: var(--advisor-gold-soft) !important;
    color: var(--advisor-gold) !important;
    font-weight: 700 !important;
  }

  .question-more-wrap {
    margin-top: 12px !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
  }

  .question-more-wrap summary {
    padding: 12px 2px !important;
    color: var(--advisor-primary) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
  }

  .question-workspace,
  .workspace-head,
  .question-plain-intro {
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .workspace-head {
    margin-bottom: 12px !important;
  }

  .workspace-label {
    color: var(--advisor-primary) !important;
    font-size: 12px !important;
    letter-spacing: 0 !important;
  }

  .workspace-head h3 {
    color: var(--advisor-ink) !important;
    font-size: 18px !important;
    font-weight: 800 !important;
    line-height: 1.35 !important;
  }

  .workspace-actions {
    display: none !important;
  }

  .answer-head {
    margin: 0 2px 12px !important;
  }

  .answer-eyebrow,
  .answer-result-eyebrow {
    margin: 0 0 7px !important;
    color: var(--advisor-gold) !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    letter-spacing: 0 !important;
  }

  .step-panel[data-step="4"] .inline-answer {
    margin: 0 !important;
  }

  .step-panel[data-step="4"] .answer-panel,
  .answer-panel,
  .answer-verdict,
  .matrix-drawer {
    margin: 0 0 12px !important;
    padding: 16px !important;
    border: 1px solid var(--advisor-line) !important;
    border-radius: var(--advisor-radius-lg) !important;
    background: #fff !important;
    box-shadow: none !important;
  }

  .answer-main,
  .answer-verdict-text {
    color: var(--advisor-ink) !important;
    font-size: 18px !important;
    font-weight: 500 !important;
    line-height: 1.72 !important;
    letter-spacing: 0 !important;
  }

  .answer-main strong,
  .answer-verdict-text strong,
  .answer-lead strong,
  .mini-card strong {
    color: var(--advisor-primary) !important;
    font-weight: 800 !important;
  }

  .answer-list {
    margin-top: 14px !important;
    padding-top: 12px !important;
    border-top: 1px solid var(--advisor-line-soft) !important;
  }

  .answer-list li {
    border-bottom-color: var(--advisor-line-soft) !important;
    color: var(--advisor-body) !important;
  }

  #inline-answer .answer-table-wrap,
  .table-wrap,
  .matrix-wrap {
    border-color: var(--advisor-line) !important;
    border-radius: var(--advisor-radius) !important;
    box-shadow: none !important;
  }

  #inline-answer .answer-table tr {
    border-color: var(--advisor-line) !important;
    box-shadow: none !important;
  }

  #inline-answer .answer-table tr.row-best {
    border-color: rgba(10, 167, 183, 0.42) !important;
    background: #effafa !important;
    box-shadow: inset 0 0 0 1px rgba(10, 167, 183, 0.18) !important;
  }

  #inline-answer .answer-table--ladder tr.row-best {
    background: linear-gradient(180deg, #effafa 0%, #ffffff 88%) !important;
  }

  .mobile-picker-sheet {
    border-radius: 20px 20px 0 0 !important;
    background: #fff !important;
  }

  .mobile-picker-head {
    border-bottom-color: var(--advisor-line-soft) !important;
  }

  .mobile-picker-option {
    min-height: 48px !important;
    border-bottom-color: var(--advisor-line-soft) !important;
  }

  .mobile-picker-option.active {
    background: var(--advisor-primary-soft) !important;
    color: var(--advisor-primary) !important;
  }

  .form-actions,
  .form-card[data-current-step="1"] > .form-actions,
  .form-card[data-current-step="2"] > .form-actions,
  .form-card[data-current-step="3"] > .form-actions,
  .form-card[data-current-step="4"] > .form-actions {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 80 !important;
    display: grid !important;
    align-items: stretch !important;
    gap: 10px !important;
    width: 100vw !important;
    margin: 0 !important;
    padding: 10px var(--mini-gutter) max(10px, env(safe-area-inset-bottom)) !important;
    border-top: 1px solid var(--advisor-line) !important;
    background: rgba(255, 255, 255, 0.98) !important;
    box-shadow: 0 -8px 22px rgba(14, 34, 38, 0.08) !important;
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
  }

  .form-card[data-current-step="1"] > .form-actions,
  .form-card[data-current-step="2"] > .form-actions,
  .form-card[data-current-step="3"] > .form-actions {
    grid-template-columns: minmax(84px, 28%) minmax(0, 1fr) !important;
  }

  .form-card[data-current-step="1"] > .form-actions {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .form-card[data-current-step="1"] > .form-actions #btn-prev {
    display: none !important;
  }

  .form-card[data-current-step="1"] > .form-actions .action-right {
    grid-column: 1 / -1 !important;
  }

  .form-card[data-current-step="4"] > .form-actions {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  }

  .form-actions .action-right {
    display: flex !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .step-indicator {
    display: none !important;
  }

  .form-actions .btn,
  .form-actions #btn-prev,
  .form-actions #btn-flow-back,
  .form-actions .action-right .btn-primary {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 48px !important;
    margin: 0 !important;
    padding: 0 12px !important;
    border-radius: 12px !important;
    box-shadow: none !important;
    font-size: 15px !important;
    font-weight: 700 !important;
  }

  .form-actions .btn-primary,
  .form-actions .action-right .btn-primary,
  .form-card[data-current-step="4"] > .form-actions #btn-prev {
    border: 0 !important;
    background: var(--advisor-primary-2) !important;
    color: #fff !important;
  }

  .form-actions #btn-prev,
  .form-actions #btn-flow-back {
    border: 1px solid var(--advisor-line) !important;
    background: #fff !important;
    color: var(--advisor-primary) !important;
  }

  .form-card[data-current-step="4"] > .form-actions .action-right {
    display: none !important;
  }
}


/* ============================================================
   v28 顶部步骤条降噪 — 与正文标题明确分层
   ============================================================ */
@media (max-width: 640px) {
  .wizard-progress,
  body.flow-started .wizard-progress {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 6px !important;
    margin: 0 calc(-1 * var(--mini-gutter)) 16px !important;
    padding: 10px var(--mini-gutter) 12px !important;
    background: rgba(255, 255, 255, 0.98) !important;
    border-bottom: 1px solid var(--advisor-line) !important;
    box-shadow: 0 6px 18px rgba(14, 34, 38, 0.045) !important;
  }

  .wizard-progress .progress-line {
    display: none !important;
  }

  .wizard-progress .progress-step {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
    min-height: 44px !important;
    padding: 6px 2px !important;
    border-radius: 12px !important;
  }

  .wizard-progress .progress-step.active {
    background: var(--advisor-primary-soft) !important;
  }

  .wizard-progress .step-num {
    width: 17px !important;
    height: 17px !important;
    font-size: 10px !important;
    line-height: 17px !important;
  }

  .wizard-progress .step-text {
    width: 100%;
    text-align: center !important;
    line-height: 1 !important;
  }

  .wizard-progress .step-text strong {
    display: block !important;
    width: 100%;
    color: var(--advisor-muted) !important;
    font-size: 10px !important;
    font-weight: 600 !important;
    line-height: 1.15 !important;
    letter-spacing: 0 !important;
    white-space: nowrap;
  }

  .wizard-progress .progress-step.active .step-text strong {
    color: var(--advisor-primary) !important;
    font-size: 10px !important;
    font-weight: 700 !important;
  }

  .wizard-progress .step-text small {
    display: none !important;
  }

  .step-panel {
    padding-top: 6px !important;
  }

  .step-header {
    margin: 0 2px 16px !important;
    padding-top: 2px !important;
  }

  .step-header h2,
  #answer-q-title {
    font-size: 22px !important;
    line-height: 1.3 !important;
  }
}


/* ============================================================
   v29 顶部步骤条修正 — 四列严格等宽，左右与内容区对齐
   ============================================================ */
@media (max-width: 640px) {
  .wizard-progress,
  body.flow-started .wizard-progress {
    position: sticky !important;
    top: 0 !important;
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    column-gap: 8px !important;
    row-gap: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 0 18px !important;
    padding: 8px !important;
    box-sizing: border-box !important;
    border: 1px solid var(--advisor-line) !important;
    border-radius: 16px !important;
    background: rgba(255, 255, 255, 0.98) !important;
    box-shadow: 0 4px 14px rgba(14, 34, 38, 0.045) !important;
  }

  .wizard-progress .progress-line {
    display: none !important;
  }

  .wizard-progress .progress-step,
  .wizard-progress .progress-step:first-of-type,
  .wizard-progress .progress-step:last-of-type,
  .wizard-progress .progress-step:not(:first-of-type):not(:last-of-type) {
    justify-self: stretch !important;
    align-self: stretch !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    height: 48px !important;
    min-height: 48px !important;
    margin: 0 !important;
    padding: 5px 2px !important;
    box-sizing: border-box !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
    border-radius: 12px !important;
    background: transparent !important;
  }

  .wizard-progress .progress-step.active {
    background: var(--advisor-primary-soft) !important;
  }

  .wizard-progress .step-num {
    flex: 0 0 auto !important;
    width: 18px !important;
    height: 18px !important;
    margin: 0 !important;
  }

  .wizard-progress .step-text {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    text-align: center !important;
  }

  .wizard-progress .step-text strong {
    display: block !important;
    width: 100% !important;
    overflow: hidden !important;
    text-align: center !important;
    text-overflow: clip !important;
    white-space: nowrap !important;
    font-size: 10px !important;
    line-height: 1.1 !important;
  }
}


/* ============================================================
   v30 表单输入稳定性 — 输入时不触发布局抖动
   ============================================================ */
@media (max-width: 640px) {
  html,
  body,
  #app,
  .planner-shell,
  .form-card,
  .step-panel,
  .question-data-fields,
  .field-grid,
  .field-grid-core,
  .gap-fields-grid,
  .segment-row-grid,
  .account-balance-estimate,
  .contribution-eligibility-banner,
  .gap-guidance-banner,
  .policy-banner {
    overflow-anchor: none;
  }

  .field input:not([type="radio"]):not([type="checkbox"]),
  .segment-row-grid input,
  .compare-inline-grid input,
  .field > .mobile-select-button,
  .segment-row-grid .mobile-select-button {
    height: 48px !important;
    min-height: 48px !important;
    padding: 0 12px !important;
    box-sizing: border-box !important;
    border-width: 1px !important;
    font-size: 16px !important;
    line-height: 24px !important;
    -webkit-appearance: none;
    appearance: none;
    transform: translateZ(0);
  }

  .field input:not([type="radio"]):not([type="checkbox"]):focus,
  .segment-row-grid input:focus,
  .compare-inline-grid input:focus,
  .field > .mobile-select-button:focus-visible,
  .segment-row-grid .mobile-select-button:focus-visible {
    border-width: 1px !important;
    outline: none !important;
    transform: translateZ(0) !important;
  }

  .account-balance-estimate {
    min-height: 42px !important;
  }

  #account-balance-estimate-hint {
    display: block;
    min-height: 20px;
  }

  #btn-reset-account-estimate {
    display: block !important;
    min-height: 22px !important;
    margin-top: 8px !important;
  }

  #btn-reset-account-estimate.hidden {
    display: block !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  .question-data-fields > .contribution-eligibility-banner,
  .contribution-eligibility-banner {
    min-height: 126px !important;
  }

  .gap-guidance-banner,
  .policy-banner {
    min-height: 64px !important;
  }

  .contribution-eligibility-banner.hidden,
  .gap-guidance-banner.hidden,
  .policy-banner.hidden {
    display: none !important;
    min-height: 0 !important;
  }
}


/* ============================================================
   v31 结果页小程序化 — 结论优先，明细列表化
   ============================================================ */
@media (max-width: 640px) {
  .step-panel[data-step="4"] {
    padding-top: 2px !important;
  }

  .step-panel[data-step="4"] .answer-head {
    margin: 0 0 12px !important;
    padding: 13px 14px !important;
    border: 1px solid var(--advisor-line) !important;
    border-radius: 16px !important;
    background: #fff !important;
    box-shadow: none !important;
  }

  .step-panel[data-step="4"] .answer-eyebrow {
    display: inline-flex !important;
    align-items: center !important;
    min-height: 22px !important;
    margin: 0 !important;
    padding: 0 9px !important;
    border-radius: 999px !important;
    background: var(--advisor-primary-soft) !important;
    color: var(--advisor-primary) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 0 !important;
    line-height: 22px !important;
  }

  .step-panel[data-step="4"] #answer-q-title {
    margin: 9px 0 0 !important;
    color: var(--advisor-ink) !important;
    font-size: 18px !important;
    font-weight: 800 !important;
    line-height: 1.38 !important;
    letter-spacing: 0 !important;
    text-wrap: pretty;
  }

  .step-panel[data-step="4"] .inline-answer:not(.hidden) {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    margin: 0 !important;
  }

  .step-panel[data-step="4"] .answer-panel,
  .step-panel[data-step="4"] .answer-summary-card,
  .step-panel[data-step="4"] .answer-detail-card {
    margin: 0 !important;
    border-radius: 16px !important;
    box-shadow: none !important;
  }

  .step-panel[data-step="4"] .answer-summary-card {
    padding: 16px !important;
    border: 1px solid rgba(10, 167, 183, 0.24) !important;
    background: #f3fbfc !important;
  }

  .answer-card-head,
  .answer-detail-head {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    min-width: 0 !important;
  }

  .step-panel[data-step="4"] .answer-result-eyebrow {
    display: inline-flex !important;
    align-items: center !important;
    margin: 0 !important;
    color: var(--advisor-primary) !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    letter-spacing: 0 !important;
    line-height: 1.2 !important;
  }

  .answer-card-note {
    flex: 0 0 auto !important;
    display: inline-flex !important;
    align-items: center !important;
    min-height: 22px !important;
    padding: 0 8px !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, 0.78) !important;
    color: var(--advisor-muted) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    line-height: 22px !important;
  }

  .step-panel[data-step="4"] .answer-summary-card .answer-main {
    margin: 11px 0 0 !important;
    color: var(--advisor-ink) !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    line-height: 1.72 !important;
  }

  .step-panel[data-step="4"] .answer-summary-card .answer-main strong {
    color: var(--advisor-primary) !important;
    font-size: 1.08em !important;
    font-weight: 850 !important;
  }

  .step-panel[data-step="4"] .answer-detail-card {
    padding: 14px !important;
    border: 1px solid var(--advisor-line) !important;
    background: #fff !important;
  }

  .answer-detail-head {
    margin-bottom: 12px !important;
  }

  .answer-detail-head strong {
    color: var(--advisor-ink) !important;
    font-size: 15px !important;
    font-weight: 800 !important;
    line-height: 1.3 !important;
  }

  .answer-detail-head span {
    color: var(--advisor-muted) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
    text-align: right !important;
  }

  .step-panel[data-step="4"] #inline-answer .answer-table-wrap {
    margin: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  .step-panel[data-step="4"] #inline-answer .answer-table--ladder tbody {
    gap: 9px !important;
  }

  .step-panel[data-step="4"] #inline-answer .answer-table--ladder tr {
    padding: 12px 13px !important;
    border: 1px solid var(--advisor-line) !important;
    border-radius: 14px !important;
    background: #fff !important;
    box-shadow: none !important;
  }

  .step-panel[data-step="4"] #inline-answer .answer-table--ladder tr.row-recommend {
    border-color: rgba(10, 167, 183, 0.56) !important;
    background: #effbfc !important;
    box-shadow: inset 0 0 0 1px rgba(10, 167, 183, 0.18) !important;
  }

  .step-panel[data-step="4"] #inline-answer .answer-table--ladder tr.row-policy-anchor:not(.row-recommend) {
    border-color: rgba(10, 167, 183, 0.22) !important;
    background: #f8fcfc !important;
  }

  .step-panel[data-step="4"] #inline-answer .answer-table--ladder td:first-child {
    font-size: 17px !important;
    font-weight: 850 !important;
    color: var(--advisor-ink) !important;
  }

  .step-panel[data-step="4"] #inline-answer .answer-table--ladder td:nth-child(3) {
    margin-top: 2px !important;
    color: var(--advisor-primary) !important;
    font-size: 17px !important;
    font-weight: 850 !important;
  }

  .step-panel[data-step="4"] #inline-answer .answer-table--ladder td:nth-child(4) {
    color: var(--advisor-body) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
  }

  .answer-tag-group {
    gap: 5px !important;
  }

  .answer-tag {
    min-height: 22px !important;
    padding: 0 8px !important;
    border: 1px solid transparent !important;
    border-radius: 999px !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    line-height: 20px !important;
  }

  .answer-tag-recommend {
    background: #eda64a !important;
    color: #fff !important;
  }

  .answer-tag-original,
  .answer-tag-statutory,
  .answer-tag-delay-max,
  .answer-tag-early,
  .answer-tag-policy {
    border-color: rgba(10, 167, 183, 0.34) !important;
    background: #e8f8fa !important;
    color: var(--advisor-primary) !important;
  }

  .answer-tag-muted {
    background: #eef4f5 !important;
    color: var(--advisor-muted) !important;
  }
}


/* ============================================================
   v32 结果页进阶矩阵 — 作为可选模块，和主结果拉开层级
   ============================================================ */
@media (max-width: 640px) {
  .step-panel[data-step="4"] .matrix-drawer,
  .step-panel[data-step="4"] .matrix-drawer[open] {
    margin: 14px 0 0 !important;
    padding: 0 !important;
    border: 1px solid var(--advisor-line) !important;
    border-radius: 16px !important;
    background: #fff !important;
    box-shadow: none !important;
    overflow: hidden !important;
  }

  .step-panel[data-step="4"] .matrix-drawer summary {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    min-height: 52px !important;
    padding: 0 14px !important;
    border: 0 !important;
    color: var(--advisor-ink) !important;
    font-size: 15px !important;
    font-weight: 800 !important;
    line-height: 1.35 !important;
    list-style: none !important;
  }

  .step-panel[data-step="4"] .matrix-drawer summary::-webkit-details-marker {
    display: none !important;
  }

  .step-panel[data-step="4"] .matrix-drawer summary::after {
    content: "展开";
    flex: 0 0 auto !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 44px !important;
    height: 26px !important;
    padding: 0 10px !important;
    border-radius: 999px !important;
    background: var(--advisor-primary-soft) !important;
    color: var(--advisor-primary) !important;
    font-size: 12px !important;
    font-weight: 800 !important;
  }

  .step-panel[data-step="4"] .matrix-drawer[open] summary {
    margin: 0 !important;
    border-bottom: 1px solid var(--advisor-line-soft) !important;
  }

  .step-panel[data-step="4"] .matrix-drawer[open] summary::after {
    content: "收起";
    background: #eef4f5 !important;
    color: var(--advisor-muted) !important;
  }

  .step-panel[data-step="4"] .matrix-tab-hint {
    margin: 0 !important;
    padding: 12px 14px 0 !important;
    color: var(--advisor-muted) !important;
    font-size: 12px !important;
    line-height: 1.58 !important;
  }

  .step-panel[data-step="4"] .summary-card,
  .step-panel[data-step="4"] .break-even-box {
    margin: 12px 14px 0 !important;
  }

  .step-panel[data-step="4"] .matrix-summary,
  .step-panel[data-step="4"] .matrix-breakeven {
    padding: 13px !important;
    border: 1px solid var(--advisor-line-soft) !important;
    border-radius: 14px !important;
    background: #f8fcfc !important;
    box-shadow: none !important;
  }

  .step-panel[data-step="4"] .matrix-summary-head {
    margin: 0 0 10px !important;
  }

  .step-panel[data-step="4"] .matrix-summary-eyebrow {
    color: var(--advisor-ink) !important;
    font-size: 14px !important;
    font-weight: 800 !important;
  }

  .step-panel[data-step="4"] .matrix-summary-tag {
    min-height: 24px !important;
    padding: 0 9px !important;
    border: 0 !important;
    background: #e8f8fa !important;
    color: var(--advisor-primary) !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    line-height: 24px !important;
  }

  .step-panel[data-step="4"] .matrix-summary-note {
    margin: 0 0 10px !important;
    padding: 9px 10px !important;
    border-radius: 10px !important;
    background: rgba(255, 255, 255, 0.74) !important;
    color: var(--advisor-body) !important;
    font-size: 12px !important;
  }

  .step-panel[data-step="4"] .matrix-summary-scenario {
    margin: 0 0 10px !important;
    gap: 7px !important;
  }

  .step-panel[data-step="4"] .matrix-scenario-chip {
    min-height: 30px !important;
    border-color: rgba(10, 167, 183, 0.28) !important;
    background: #e8f8fa !important;
    color: var(--advisor-primary) !important;
    font-size: 13px !important;
    font-weight: 800 !important;
  }

  .step-panel[data-step="4"] .matrix-summary-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  .step-panel[data-step="4"] .matrix-metric {
    padding: 10px !important;
    border: 1px solid var(--advisor-line-soft) !important;
    border-radius: 12px !important;
    background: rgba(255, 255, 255, 0.78) !important;
  }

  .step-panel[data-step="4"] .matrix-metric-primary {
    border-color: rgba(10, 167, 183, 0.28) !important;
    background: #effbfc !important;
  }

  .step-panel[data-step="4"] .matrix-metric-label {
    color: var(--advisor-muted) !important;
    font-size: 11px !important;
  }

  .step-panel[data-step="4"] .matrix-metric-num {
    color: var(--advisor-ink) !important;
    font-size: 16px !important;
    font-weight: 850 !important;
  }

  .step-panel[data-step="4"] .matrix-metric-primary .matrix-metric-num {
    color: var(--advisor-primary) !important;
    font-size: 18px !important;
  }

  .step-panel[data-step="4"] .matrix-breakeven-head {
    margin-bottom: 10px !important;
  }

  .step-panel[data-step="4"] .matrix-breakeven-title {
    margin: 0 0 4px !important;
    color: var(--advisor-ink) !important;
    font-size: 14px !important;
    font-weight: 800 !important;
  }

  .step-panel[data-step="4"] .matrix-breakeven-lead,
  .step-panel[data-step="4"] .matrix-breakeven-foot,
  .step-panel[data-step="4"] .matrix-legend,
  .step-panel[data-step="4"] .matrix-scroll-hint {
    color: var(--advisor-muted) !important;
    font-size: 12px !important;
    line-height: 1.5 !important;
  }

  .step-panel[data-step="4"] .matrix-breakeven-grid {
    border-color: var(--advisor-line-soft) !important;
    border-radius: 12px !important;
    background: #fff !important;
  }

  .step-panel[data-step="4"] .matrix-breakeven-row {
    min-height: 40px !important;
    padding: 8px 10px !important;
    background: #fff !important;
    border-bottom-color: var(--advisor-line-soft) !important;
  }

  .step-panel[data-step="4"] .matrix-breakeven-row:nth-child(even) {
    background: #f8fcfc !important;
  }

  .step-panel[data-step="4"] .matrix-breakeven-life {
    color: var(--advisor-ink) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
  }

  .step-panel[data-step="4"] .matrix-breakeven-answer {
    color: var(--advisor-primary) !important;
    font-size: 13px !important;
    font-weight: 800 !important;
  }

  .step-panel[data-step="4"] .matrix-breakeven-row.is-later-better .matrix-breakeven-answer {
    color: var(--advisor-muted) !important;
    font-weight: 700 !important;
  }

  .step-panel[data-step="4"] .matrix-legend,
  .step-panel[data-step="4"] .matrix-scroll-hint,
  .step-panel[data-step="4"] .matrix-wrap,
  .step-panel[data-step="4"] .cell-detail {
    margin-left: 14px !important;
    margin-right: 14px !important;
  }

  .step-panel[data-step="4"] .matrix-legend {
    margin-top: 12px !important;
  }

  .step-panel[data-step="4"] .matrix-scroll-hint {
    margin-top: 8px !important;
  }

  .step-panel[data-step="4"] .matrix-wrap {
    margin-top: 10px !important;
    margin-bottom: 14px !important;
    border-color: var(--advisor-line-soft) !important;
    border-radius: 14px !important;
    box-shadow: none !important;
  }
}


/* ============================================================
   v33 移动端矩阵降密 — 默认关键寿命列表，完整表二级展开
   ============================================================ */
@media (max-width: 640px) {
  .step-panel[data-step="4"] .matrix-mobile-list {
    margin: 12px 14px 0 !important;
    padding: 13px !important;
    border: 1px solid var(--advisor-line-soft) !important;
    border-radius: 14px !important;
    background: #fff !important;
  }

  .matrix-mobile-list-head {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    margin-bottom: 10px !important;
  }

  .matrix-mobile-list-head strong {
    color: var(--advisor-ink) !important;
    font-size: 14px !important;
    font-weight: 850 !important;
    line-height: 1.3 !important;
  }

  .matrix-mobile-list-head span {
    color: var(--advisor-muted) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
    text-align: right !important;
  }

  .matrix-life-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
  }

  .matrix-life-row {
    width: 100% !important;
    min-height: 58px !important;
    display: grid !important;
    grid-template-columns: minmax(72px, 0.88fr) minmax(88px, 1fr) minmax(92px, 1.08fr) !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 0 !important;
    padding: 10px 11px !important;
    border: 1px solid var(--advisor-line-soft) !important;
    border-radius: 12px !important;
    background: #f8fcfc !important;
    color: var(--advisor-ink) !important;
    text-align: left !important;
    box-shadow: none !important;
    -webkit-appearance: none;
    appearance: none;
  }

  .matrix-life-row.is-best {
    border-color: rgba(10, 167, 183, 0.42) !important;
    background: #effbfc !important;
  }

  .matrix-life-row.is-disabled {
    opacity: 0.72 !important;
  }

  .matrix-life-age {
    color: var(--advisor-ink) !important;
    font-size: 13px !important;
    font-weight: 750 !important;
    line-height: 1.25 !important;
  }

  .matrix-life-choice {
    color: var(--advisor-primary) !important;
    font-size: 14px !important;
    font-weight: 850 !important;
    line-height: 1.25 !important;
  }

  .matrix-life-money {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    min-width: 0 !important;
    line-height: 1.18 !important;
    text-align: right !important;
  }

  .matrix-life-money strong {
    color: var(--advisor-ink) !important;
    font-size: 15px !important;
    font-weight: 850 !important;
    line-height: 1.15 !important;
    font-variant-numeric: tabular-nums;
  }

  .matrix-life-money small {
    color: var(--advisor-muted) !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
  }

  .matrix-life-money em {
    margin-top: 3px !important;
    color: var(--advisor-muted) !important;
    font-size: 11px !important;
    font-style: normal !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
  }

  .step-panel[data-step="4"] .matrix-full-table {
    margin: 12px 14px 14px !important;
    border: 1px solid var(--advisor-line-soft) !important;
    border-radius: 14px !important;
    background: #fff !important;
    overflow: hidden !important;
  }

  .step-panel[data-step="4"] .matrix-full-table > summary {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    min-height: 46px !important;
    padding: 0 13px !important;
    color: var(--advisor-primary) !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    list-style: none !important;
  }

  .step-panel[data-step="4"] .matrix-full-table > summary::-webkit-details-marker {
    display: none !important;
  }

  .step-panel[data-step="4"] .matrix-full-table > summary::after {
    content: "展开" !important;
    color: var(--advisor-muted) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
  }

  .step-panel[data-step="4"] .matrix-full-table[open] > summary {
    border-bottom: 1px solid var(--advisor-line-soft) !important;
  }

  .step-panel[data-step="4"] .matrix-full-table[open] > summary::after {
    content: "收起" !important;
  }

  .step-panel[data-step="4"] .matrix-full-table .matrix-legend,
  .step-panel[data-step="4"] .matrix-full-table .matrix-scroll-hint,
  .step-panel[data-step="4"] .matrix-full-table .matrix-wrap,
  .step-panel[data-step="4"] .matrix-full-table .cell-detail {
    margin-left: 12px !important;
    margin-right: 12px !important;
  }

  .step-panel[data-step="4"] .matrix-full-table .matrix-wrap {
    margin-bottom: 12px !important;
  }
}


/* ============================================================
   v34 关键寿命建议金额 — 数字和单位同行
   ============================================================ */
@media (max-width: 640px) {
  .matrix-life-money {
    display: grid !important;
    grid-template-columns: auto auto !important;
    justify-content: end !important;
    align-items: baseline !important;
    column-gap: 3px !important;
    row-gap: 3px !important;
    text-align: right !important;
  }

  .matrix-life-money strong {
    grid-column: 1 !important;
    line-height: 1 !important;
  }

  .matrix-life-money small {
    grid-column: 2 !important;
    align-self: end !important;
    padding-bottom: 1px !important;
    line-height: 1 !important;
  }

  .matrix-life-money em {
    grid-column: 1 / -1 !important;
    justify-self: end !important;
    margin-top: 0 !important;
  }
}

/* ============================================================
   v36 首屏问题卡 — 全量展示 + 示例标签右上角
   ============================================================ */
@media (max-width: 640px) {
  body:not(.flow-started) .hero-questions-panel {
    margin-top: 22px !important;
  }

  body:not(.flow-started) .hero-title {
    max-width: 11em !important;
  }

  body:not(.flow-started) .hero-coverage-note.hidden,
  body:not(.flow-started) .hero-more-wrap.hidden {
    display: none !important;
  }

  body:not(.flow-started) .hero-q-card,
  body:not(.flow-started) .hero-q-card:hover,
  body:not(.flow-started) .hero-q-card:active,
  body:not(.flow-started) .hero-q-card:focus-visible {
    padding: 13px 14px 13px 34px !important;
  }

  body:not(.flow-started) .hero-q-title-row {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 10px !important;
    min-width: 0 !important;
  }

  body:not(.flow-started) .hero-q-title-row strong {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    margin: 0 !important;
  }

  body:not(.flow-started) .hero-q-kicker {
    flex: 0 0 auto !important;
    margin: 1px 0 0 !important;
    padding: 3px 7px !important;
    border-radius: 999px !important;
    background: var(--advisor-gold-soft) !important;
    color: var(--advisor-gold) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
  }
}

/* ============================================================
   v38 账户余额提示 — 图标和文字保持间距
   ============================================================ */
@media (max-width: 640px) {
  #account-balance-estimate-hint {
    display: flex !important;
    align-items: flex-start !important;
    gap: 8px !important;
    min-height: 20px;
  }

  #account-balance-estimate-hint::before {
    flex: 0 0 16px !important;
    width: 16px !important;
    height: 16px !important;
    margin-top: 2px !important;
  }
}

/* ============================================================
   v39 开发预览 — 计算类答案页全集
   ============================================================ */
body.answer-preview-mode {
  min-height: 100vh;
  background: var(--advisor-bg, #f4f8f7);
}

body.answer-preview-mode #app {
  min-height: 100vh;
}

.answer-preview-page {
  width: 100%;
  max-width: 640px;
  margin: 0 auto;
  padding: 18px var(--mini-gutter, 12px) 36px;
}

.answer-preview-hero {
  padding: 4px 2px 14px;
}

.answer-preview-hero p {
  width: fit-content;
  margin: 0 0 10px;
  padding: 4px 9px;
  border: 1px solid rgba(8, 127, 143, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.86);
  color: var(--advisor-primary, #087f8f);
  font-size: 12px;
  font-weight: 700;
}

.answer-preview-hero h1 {
  margin: 0;
  color: var(--advisor-ink, #17262d);
  font-size: 24px;
  line-height: 1.22;
  letter-spacing: 0;
}

.answer-preview-hero span,
.answer-preview-skip {
  display: block;
  margin-top: 8px;
  color: var(--advisor-muted, #71828a);
  font-size: 13px;
  line-height: 1.55;
}

.answer-preview-index {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  margin: 8px 0 14px;
}

.answer-preview-index a {
  display: block;
  padding: 10px 12px;
  border: 1px solid var(--advisor-line, #e2ebeb);
  border-radius: 12px;
  background: #fff;
  color: var(--advisor-primary, #087f8f);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
  text-decoration: none;
}

.answer-preview-skip {
  margin: 12px 0 16px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.72);
}

.answer-preview-item {
  scroll-margin-top: 12px;
  margin: 0 0 18px;
}

.answer-preview-item-head {
  margin-bottom: 10px;
  padding: 14px;
  border: 1px solid var(--advisor-line, #e2ebeb);
  border-radius: var(--advisor-radius, 14px);
  background: #fff;
}

.answer-preview-item-head span {
  display: block;
  margin-bottom: 6px;
  color: var(--advisor-primary, #087f8f);
  font-size: 12px;
  font-weight: 800;
}

.answer-preview-item-head h2 {
  margin: 0;
  color: var(--advisor-ink, #17262d);
  font-size: 18px;
  line-height: 1.35;
  letter-spacing: 0;
}

.answer-preview-item-head p {
  margin: 6px 0 0;
  color: var(--advisor-muted, #71828a);
  font-size: 13px;
  line-height: 1.45;
}

.answer-preview-item .answer-panel {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.answer-preview-error > p {
  margin: 0;
  padding: 12px;
  border: 1px solid rgba(190, 72, 72, 0.24);
  border-radius: 12px;
  background: rgba(255, 244, 244, 0.9);
  color: #8b2d2d;
  font-size: 13px;
  line-height: 1.5;
}

/* ============================================================
   v40 答案页整体改造 — 小程序端简约结果模板
   ============================================================ */
.answer-result-stack {
  display: grid;
  width: 100%;
  gap: 12px;
}

.answer-result-stack .answer-panel {
  width: 100% !important;
  margin: 0 !important;
  border-radius: 16px !important;
  box-shadow: 0 10px 30px rgba(22, 48, 54, 0.06) !important;
}

.answer-result-stack .answer-summary-card {
  position: relative;
  overflow: hidden;
  padding: 17px 16px 16px !important;
  border: 1px solid rgba(10, 167, 183, 0.2) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(240, 250, 250, 0.98) 100%) !important;
}

.answer-result-stack .answer-summary-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--advisor-primary-2, #0aa7b7), rgba(166, 109, 22, 0.72));
}

.answer-result-stack .answer-card-head,
.answer-result-stack .answer-detail-head {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 12px !important;
  min-width: 0 !important;
}

.answer-result-stack .answer-result-eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  margin: 0 !important;
  color: var(--advisor-primary, #087f8f) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  letter-spacing: 0 !important;
}

.answer-result-stack .answer-result-eyebrow::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 0 5px rgba(10, 167, 183, 0.11);
}

.answer-result-stack .answer-card-note {
  flex: 0 0 auto !important;
  min-height: 24px !important;
  padding: 0 9px !important;
  border: 1px solid rgba(10, 167, 183, 0.14) !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.82) !important;
  color: var(--advisor-muted, #71828a) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  line-height: 22px !important;
}

.answer-result-stack .answer-main {
  margin: 12px 0 0 !important;
  color: var(--advisor-ink, #17262d) !important;
  font-size: 17px !important;
  font-weight: 650 !important;
  line-height: 1.72 !important;
  letter-spacing: 0 !important;
}

.answer-result-stack .answer-main strong {
  color: var(--advisor-primary, #087f8f) !important;
  font-size: 1.08em !important;
  font-weight: 850 !important;
}

.answer-result-stack .answer-detail-card {
  padding: 15px 14px !important;
  border: 1px solid var(--advisor-line, #e2ebeb) !important;
  background: #ffffff !important;
}

.answer-result-stack .answer-detail-head {
  margin-bottom: 12px !important;
}

.answer-result-stack .answer-detail-head strong {
  color: var(--advisor-ink, #17262d) !important;
  font-size: 16px !important;
  font-weight: 850 !important;
  line-height: 1.25 !important;
}

.answer-result-stack .answer-detail-head span {
  flex: 0 0 auto;
  max-width: 45%;
  color: var(--advisor-muted, #71828a) !important;
  font-size: 12px !important;
  font-weight: 650 !important;
  line-height: 1.3 !important;
  text-align: right !important;
}

.answer-result-stack .answer-list {
  display: grid !important;
  gap: 4px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.answer-result-stack .answer-list li {
  position: relative !important;
  margin: 0 !important;
  padding: 7px 0 7px 20px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--advisor-body, #465a63) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  line-height: 1.58 !important;
}

.answer-result-stack .answer-list li::before {
  content: "";
  position: absolute;
  left: 2px;
  top: 17px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--advisor-primary-2, #0aa7b7);
  box-shadow: none;
}

.answer-result-stack .answer-list li strong {
  color: var(--advisor-primary, #087f8f) !important;
  font-size: 1em !important;
  font-weight: 780 !important;
}

.gov-dual-breakdown {
  display: grid;
  gap: 8px;
}

.gov-dual-breakdown-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 14px;
  min-height: 42px;
  padding: 9px 12px;
  border-radius: 12px;
  background: var(--advisor-surface-2, #f8fbfa);
}

.gov-dual-breakdown-row span {
  min-width: 0;
  color: var(--advisor-body, #465a63);
  font-size: 14px;
  font-weight: 650;
  line-height: 1.35;
}

.gov-dual-breakdown-row strong {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: baseline;
  color: var(--advisor-primary, #087f8f);
  font-size: 17px;
  font-weight: 850;
  line-height: 1.2;
}

.gov-dual-breakdown-row small {
  margin-left: 4px;
  color: var(--advisor-body, #465a63);
  font-size: 12px;
  font-weight: 650;
}

.gov-dual-note {
  margin: 10px 0 0;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(10, 167, 183, 0.07);
  color: var(--advisor-body, #465a63);
  font-size: 13px;
  font-weight: 500;
  line-height: 1.58;
}

.answer-result-stack .answer-details {
  margin: 0 !important;
  border: 1px solid var(--advisor-line, #e2ebeb) !important;
  border-radius: 14px !important;
  background: var(--advisor-surface-2, #f8fbfa) !important;
  overflow: hidden !important;
}

.answer-result-stack .answer-details summary {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  min-height: 46px !important;
  padding: 0 13px !important;
  color: var(--advisor-ink, #17262d) !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  list-style: none !important;
}

.answer-result-stack .answer-details summary::-webkit-details-marker {
  display: none;
}

.answer-result-stack .answer-details summary::after {
  content: "\5C55\5F00";
  padding: 4px 9px;
  border-radius: 999px;
  background: rgba(10, 167, 183, 0.1);
  color: var(--advisor-primary, #087f8f);
  font-size: 12px;
  font-weight: 750;
}

.answer-result-stack .answer-details[open] summary::after {
  content: "\6536\8D77";
}

.answer-result-stack .answer-details .answer-table-wrap {
  padding: 0 12px 12px !important;
}

.answer-result-stack .answer-subtable-title {
  margin: 13px 0 8px !important;
  color: var(--advisor-ink, #17262d) !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  line-height: 1.35 !important;
}

.answer-result-stack .answer-table-wrap {
  width: 100% !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.answer-result-stack .answer-table {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  color: var(--advisor-ink, #17262d) !important;
  font-size: 14px !important;
}

.answer-result-stack .answer-table th {
  padding: 10px 9px !important;
  border-bottom: 1px solid var(--advisor-line-soft, #edf3f3) !important;
  background: var(--advisor-surface-2, #f8fbfa) !important;
  color: var(--advisor-muted, #71828a) !important;
  font-size: 12px !important;
  font-weight: 750 !important;
}

.answer-result-stack .answer-table td {
  padding: 11px 9px !important;
  border-bottom: 1px solid var(--advisor-line-soft, #edf3f3) !important;
  color: var(--advisor-body, #465a63) !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}

.answer-result-stack .answer-table tr.row-best,
.answer-result-stack .answer-table tr.row-recommend {
  background: transparent !important;
}

.answer-result-stack .answer-tag-group {
  display: inline-flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
  gap: 5px !important;
}

.answer-result-stack .answer-tag {
  min-height: 22px !important;
  margin: 0 !important;
  padding: 0 8px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  line-height: 20px !important;
}

.answer-preview-page {
  max-width: 520px;
  padding: 16px var(--mini-gutter, 12px) 34px;
}

.answer-preview-hero {
  margin: 0 0 12px;
  padding: 16px;
  border: 1px solid rgba(10, 167, 183, 0.16);
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(232, 248, 248, 0.9));
  box-shadow: 0 10px 30px rgba(22, 48, 54, 0.06);
}

.answer-preview-hero p {
  margin-bottom: 9px;
  background: #fff;
}

.answer-preview-hero h1 {
  font-size: 22px;
}

.answer-preview-index {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 12px 0 12px;
}

.answer-preview-index a {
  min-height: 44px;
  padding: 9px 10px;
  border-radius: 13px;
  background: rgba(255, 255, 255, 0.86);
  color: var(--advisor-body, #465a63);
  font-size: 12px;
  font-weight: 750;
}

.answer-preview-skip {
  margin: 10px 0 16px;
  border: 1px solid var(--advisor-line-soft, #edf3f3);
  background: rgba(255, 255, 255, 0.78);
}

.answer-preview-item {
  margin: 0 0 18px;
}

.answer-preview-item-head {
  display: grid;
  gap: 6px;
  margin: 0 0 10px;
  padding: 14px 14px 13px;
  border-radius: 16px;
  background: #ffffff;
  box-shadow: 0 8px 24px rgba(22, 48, 54, 0.05);
}

.answer-preview-item-head span {
  margin: 0;
  color: var(--advisor-primary, #087f8f);
}

.answer-preview-item-head h2 {
  font-size: 17px;
  line-height: 1.38;
}

@media (max-width: 720px) {
  .answer-result-stack .answer-table,
  .answer-result-stack .answer-table thead,
  .answer-result-stack .answer-table tbody,
  .answer-result-stack .answer-table tr,
  .answer-result-stack .answer-table td {
    display: block !important;
    width: 100% !important;
  }

  .answer-result-stack .answer-table thead {
    display: none !important;
  }

  .answer-result-stack .answer-table tbody {
    display: grid !important;
    gap: 10px !important;
  }

  .answer-result-stack .answer-table tr {
    padding: 13px 13px 12px !important;
    border: 1px solid var(--advisor-line, #e2ebeb) !important;
    border-radius: 15px !important;
    background: #ffffff !important;
    box-shadow: none !important;
  }

  .answer-result-stack .answer-table tr.row-best,
  .answer-result-stack .answer-table tr.row-recommend {
    border-color: rgba(10, 167, 183, 0.48) !important;
    background: #effbfc !important;
    box-shadow: inset 0 0 0 1px rgba(10, 167, 183, 0.13) !important;
  }

  .answer-result-stack .answer-table tr.row-policy-anchor:not(.row-recommend) {
    border-color: rgba(10, 167, 183, 0.22) !important;
    background: #f9fcfc !important;
  }

  .answer-result-stack .answer-table td {
    display: flex !important;
    align-items: baseline !important;
    justify-content: space-between !important;
    gap: 12px !important;
    min-height: 28px !important;
    padding: 5px 0 !important;
    border: 0 !important;
    color: var(--advisor-ink, #17262d) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    text-align: right !important;
  }

  .answer-result-stack .answer-table td:empty {
    display: none !important;
  }

  .answer-result-stack .answer-table td::before {
    content: attr(data-label);
    flex: 0 0 auto;
    max-width: 50%;
    color: var(--advisor-muted, #71828a);
    font-size: 12px;
    font-weight: 650;
    line-height: 1.35;
    text-align: left;
  }

  .answer-result-stack .answer-table td:first-child {
    display: block !important;
    min-height: 0 !important;
    padding: 0 0 8px !important;
    border-bottom: 1px solid var(--advisor-line-soft, #edf3f3) !important;
    color: var(--advisor-ink, #17262d) !important;
    font-size: 19px !important;
    font-weight: 850 !important;
    line-height: 1.2 !important;
    text-align: left !important;
  }

  .answer-result-stack .answer-table td:first-child::before {
    display: none !important;
  }

  .answer-result-stack .answer-table--ladder td:nth-child(2) {
    justify-content: flex-end !important;
    padding-top: 0 !important;
  }

  .answer-result-stack .answer-table--ladder td:nth-child(2)::before {
    display: none !important;
  }

  .answer-result-stack .answer-table--ladder td:nth-child(3) {
    margin-top: 2px !important;
    color: var(--advisor-primary, #087f8f) !important;
    font-size: 18px !important;
    font-weight: 850 !important;
  }

  .answer-result-stack .answer-table--ladder td:nth-child(4) {
    color: var(--advisor-body, #465a63) !important;
    font-size: 14px !important;
  }

  .answer-result-stack .answer-table td:last-child {
    padding-bottom: 0 !important;
  }
}

/* ============================================================
   v41 恢复「预估寿命定了，几岁领最划算？」专属答案样式
   ============================================================ */
.answer-result-stack[data-answer-id="matrix"] {
  gap: 12px;
}

.answer-result-stack[data-answer-id="matrix"] .answer-panel {
  border-radius: 16px !important;
  box-shadow: none !important;
}

.answer-result-stack[data-answer-id="matrix"] .answer-summary-card {
  padding: 16px !important;
  border: 1px solid rgba(10, 167, 183, 0.24) !important;
  background: #f3fbfc !important;
}

.answer-result-stack[data-answer-id="matrix"] .answer-summary-card::before {
  display: none !important;
}

.answer-result-stack[data-answer-id="matrix"] .answer-result-eyebrow {
  gap: 0 !important;
  font-size: 13px !important;
  font-weight: 800 !important;
}

.answer-result-stack[data-answer-id="matrix"] .answer-result-eyebrow::before {
  display: none !important;
}

.answer-result-stack[data-answer-id="matrix"] .answer-main {
  margin-top: 11px !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  line-height: 1.72 !important;
}

.answer-result-stack[data-answer-id="matrix"] .answer-detail-card {
  padding: 14px !important;
  border: 1px solid var(--advisor-line, #e2ebeb) !important;
  background: #fff !important;
}

@media (max-width: 720px) {
  .answer-result-stack[data-answer-id="matrix"] .answer-table-wrap {
    overflow: visible !important;
    margin: 0 !important;
  }

  .answer-result-stack[data-answer-id="matrix"] .answer-table {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    font-size: 13px !important;
  }

  .answer-result-stack[data-answer-id="matrix"] .answer-table thead {
    display: none !important;
  }

  .answer-result-stack[data-answer-id="matrix"] .answer-table tbody {
    display: flex !important;
    flex-direction: column !important;
    gap: 9px !important;
  }

  .answer-result-stack[data-answer-id="matrix"] .answer-table--ladder tr {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    grid-template-rows: auto auto !important;
    grid-template-areas:
      "age note"
      "monthly net" !important;
    gap: 4px 12px !important;
    min-height: 0 !important;
    height: auto !important;
    padding: 12px 13px !important;
    border: 1px solid var(--advisor-line, #e2ebeb) !important;
    border-radius: 14px !important;
    background: #fff !important;
    overflow: visible !important;
    box-shadow: none !important;
  }

  .answer-result-stack[data-answer-id="matrix"] .answer-table--ladder tr.row-recommend,
  .answer-result-stack[data-answer-id="matrix"] .answer-table--ladder tr.row-best {
    border-color: rgba(10, 167, 183, 0.56) !important;
    background: #effbfc !important;
    box-shadow: inset 0 0 0 1px rgba(10, 167, 183, 0.18) !important;
  }

  .answer-result-stack[data-answer-id="matrix"] .answer-table--ladder tr.row-policy-anchor:not(.row-recommend) {
    border-color: rgba(10, 167, 183, 0.22) !important;
    background: #f8fcfc !important;
  }

  .answer-result-stack[data-answer-id="matrix"] .answer-table--ladder td {
    display: block !important;
    min-height: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    text-align: left !important;
  }

  .answer-result-stack[data-answer-id="matrix"] .answer-table--ladder td::before {
    display: none !important;
  }

  .answer-result-stack[data-answer-id="matrix"] .answer-table--ladder td:first-child {
    grid-area: age !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    color: var(--advisor-ink, #17262d) !important;
    font-size: 17px !important;
    font-weight: 850 !important;
    line-height: 1.2 !important;
  }

  .answer-result-stack[data-answer-id="matrix"] .answer-table--ladder td:nth-child(2) {
    grid-area: note !important;
    justify-self: end !important;
    align-self: start !important;
    display: flex !important;
    justify-content: flex-end !important;
    flex-wrap: nowrap !important;
    gap: 4px !important;
    width: auto !important;
    max-width: none !important;
    padding: 0 !important;
    text-align: right !important;
  }

  .answer-result-stack[data-answer-id="matrix"] .answer-table--ladder td:nth-child(2) .answer-tag-group {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    flex-wrap: nowrap !important;
    gap: 5px !important;
    white-space: nowrap !important;
  }

  .answer-result-stack[data-answer-id="matrix"] .answer-table--ladder td:nth-child(3) {
    grid-area: monthly !important;
    margin: 2px 0 0 !important;
    color: var(--advisor-primary, #087f8f) !important;
    font-size: 17px !important;
    font-weight: 850 !important;
    line-height: 1.25 !important;
    font-variant-numeric: tabular-nums;
  }

  .answer-result-stack[data-answer-id="matrix"] .answer-table--ladder td:nth-child(4) {
    grid-area: net !important;
    justify-self: end !important;
    align-self: end !important;
    color: var(--advisor-body, #465a63) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    line-height: 1.25 !important;
    text-align: right !important;
    font-variant-numeric: tabular-nums;
  }

  .answer-result-stack[data-answer-id="matrix"] .answer-table--ladder td:nth-child(4)::before {
    display: inline !important;
    content: "\51C0\62FF ";
    color: var(--advisor-muted, #71828a);
    font-size: 11px;
    font-weight: 650;
  }
}

/* ============================================================
   v42 答案页细节 — 分水岭布局与方案卡色彩
   ============================================================ */
.gap-repay-card-list {
  display: grid;
  gap: 10px;
}

.gap-repay-card {
  display: grid;
  gap: 8px;
  padding: 13px;
  border: 1px solid rgba(10, 167, 183, 0.2);
  border-radius: 15px;
  background: #fff;
}

.gap-repay-card > strong {
  display: block;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--advisor-line-soft, #edf3f3);
  color: var(--advisor-ink, #17262d);
  font-size: 18px;
  font-weight: 850;
  line-height: 1.25;
}

.gap-repay-card > div {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  color: var(--advisor-ink, #17262d);
  font-size: 14px;
  font-weight: 800;
  line-height: 1.35;
}

.gap-repay-card > div span {
  color: var(--advisor-muted, #71828a);
  font-size: 12px;
  font-weight: 700;
}

.gap-repay-card-single {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: baseline;
  gap: 12px;
}

.gap-repay-card-single > strong {
  padding-bottom: 0;
  border-bottom: 0;
}

.gap-repay-card-single > em {
  color: var(--advisor-ink, #17262d);
  font-size: 18px;
  font-style: normal;
  font-weight: 850;
  line-height: 1.25;
  white-space: nowrap;
}

.gap-repay-card-group {
  gap: 0;
}

.gap-repay-card-group > div {
  min-height: 40px;
  padding: 10px 0;
  border-bottom: 1px solid var(--advisor-line-soft, #edf3f3);
}

.gap-repay-card-group > div:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.gap-repay-card-group > div strong {
  color: var(--advisor-ink, #17262d);
  font-size: 16px;
  font-weight: 850;
  white-space: nowrap;
}

.break-even-card-list {
  display: grid;
  gap: 10px;
}

.break-even-card {
  padding: 13px;
  border: 1px solid rgba(10, 167, 183, 0.18);
  border-radius: 15px;
  background: linear-gradient(180deg, #ffffff 0%, #f5fbfb 100%);
}

.break-even-card-head {
  display: block;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--advisor-line-soft, #edf3f3);
}

.break-even-card-head strong {
  display: block;
  color: var(--advisor-ink, #17262d);
  font-size: 15px;
  font-weight: 850;
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.break-even-paths {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  padding-top: 10px;
}

.break-even-path {
  display: grid;
  grid-template-columns: minmax(92px, auto) minmax(0, 1fr) auto;
  align-items: center;
  gap: 6px;
  min-height: 42px;
  padding: 10px;
  border-radius: 12px;
  background: rgba(10, 167, 183, 0.07);
}

.break-even-path.is-later {
  background: rgba(166, 109, 22, 0.08);
}

.break-even-path-label {
  color: var(--advisor-muted, #71828a);
  font-size: 11px;
  font-weight: 750;
  line-height: 1.35;
  white-space: nowrap;
}

.break-even-path strong {
  color: var(--advisor-ink, #17262d);
  font-size: 12px;
  font-weight: 850;
  line-height: 1.25;
  min-width: 0;
  text-align: right;
  white-space: nowrap;
}

.break-even-path small {
  justify-self: end;
  color: var(--advisor-primary, #087f8f);
  font-size: 11px;
  font-weight: 750;
  line-height: 1.25;
  text-align: right;
  white-space: nowrap;
}

.break-even-card-plain p {
  margin: 0;
  color: var(--advisor-body, #465a63);
  font-size: 14px;
  line-height: 1.65;
}

@media (max-width: 720px) {
  .answer-result-stack:not([data-answer-id="matrix"]) .answer-table tr {
    border-color: rgba(10, 167, 183, 0.18) !important;
    background: linear-gradient(180deg, #ffffff 0%, #f8fcfc 100%) !important;
  }

  .answer-result-stack:not([data-answer-id="matrix"]) .answer-table tr:nth-child(even) {
    background: linear-gradient(180deg, #ffffff 0%, #f7fbf8 100%) !important;
  }

  .answer-result-stack:not([data-answer-id="matrix"]) .answer-table tr.row-best,
  .answer-result-stack:not([data-answer-id="matrix"]) .answer-table tr.row-recommend {
    border-color: rgba(10, 167, 183, 0.58) !important;
    background: linear-gradient(180deg, #e6f8fa 0%, #f3fcfc 100%) !important;
    box-shadow: inset 0 0 0 1px rgba(10, 167, 183, 0.18) !important;
  }

  .answer-result-stack:not([data-answer-id="matrix"]) .answer-table tr.row-best td:first-child,
  .answer-result-stack:not([data-answer-id="matrix"]) .answer-table tr.row-recommend td:first-child {
    color: var(--advisor-primary, #087f8f) !important;
  }

  .answer-result-stack:not([data-answer-id="matrix"]) .answer-table td:first-child {
    color: var(--advisor-ink, #17262d) !important;
  }
}

/* ============================================================
   v43 领取资格答案 — 两个硬条件 + 可选提前
   ============================================================ */
.readiness-answer {
  display: grid;
  gap: 11px;
}

.readiness-answer-lead {
  margin: 0;
  padding: 12px 13px;
  border: 1px solid rgba(10, 167, 183, 0.18);
  border-radius: 13px;
  background: rgba(10, 167, 183, 0.07);
  color: var(--advisor-body, #465a63);
  font-size: 14px;
  font-weight: 650;
  line-height: 1.6;
}

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

.readiness-condition {
  display: grid;
  gap: 12px;
  padding: 13px;
  border: 1px solid var(--advisor-line, #e2ebeb);
  border-radius: 15px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fcfc 100%);
}

.readiness-condition.is-warn {
  border-color: rgba(166, 109, 22, 0.28);
  background: linear-gradient(180deg, #ffffff 0%, rgba(255, 245, 223, 0.72) 100%);
}

.readiness-condition.is-ok {
  border-color: rgba(10, 167, 183, 0.32);
  background: linear-gradient(180deg, #ffffff 0%, #effbfc 100%);
}

.readiness-condition.is-wait {
  border-color: rgba(10, 167, 183, 0.22);
}

.readiness-condition-head {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.readiness-condition-head > span {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--advisor-primary-2, #0aa7b7);
  color: #fff;
  font-size: 13px;
  font-weight: 850;
  line-height: 1;
}

.readiness-condition-head div {
  min-width: 0;
}

.readiness-condition-head strong {
  display: block;
  color: var(--advisor-ink, #17262d);
  font-size: 16px;
  font-weight: 850;
  line-height: 1.3;
}

.readiness-condition-head small {
  display: block;
  margin-top: 2px;
  color: var(--advisor-muted, #71828a);
  font-size: 12px;
  font-weight: 650;
  line-height: 1.35;
}

.readiness-condition-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.readiness-condition-grid div {
  min-width: 0;
  padding: 10px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.72);
}

.readiness-condition-grid span {
  display: block;
  margin-bottom: 4px;
  color: var(--advisor-muted, #71828a);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.25;
}

.readiness-condition-grid strong {
  display: block;
  color: var(--advisor-ink, #17262d);
  font-size: 15px;
  font-weight: 850;
  line-height: 1.35;
}

.readiness-condition-grid .readiness-metric {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 3px;
  min-width: 0;
}

.readiness-condition-grid .readiness-metric > span {
  max-width: 100%;
  white-space: nowrap;
}

.readiness-condition-grid .readiness-metric small {
  display: block;
  max-width: 100%;
  color: var(--advisor-muted, #71828a);
  font-size: 12px;
  font-weight: 750;
  line-height: 1.25;
  white-space: nowrap;
}

.readiness-condition-result {
  margin: 0;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(10, 167, 183, 0.1);
  color: var(--advisor-primary, #087f8f);
  font-size: 15px;
  font-weight: 850;
  line-height: 1.35;
}

.readiness-condition.is-warn .readiness-condition-result {
  background: rgba(166, 109, 22, 0.12);
  color: var(--advisor-gold, #a66d16);
}

.readiness-gap {
  padding: 12px 13px;
  border: 1px solid rgba(166, 109, 22, 0.22);
  border-radius: 14px;
  background: rgba(255, 245, 223, 0.64);
}

.readiness-gap strong {
  display: block;
  color: var(--advisor-gold, #a66d16);
  font-size: 14px;
  font-weight: 850;
  line-height: 1.3;
}

.readiness-gap p {
  margin: 5px 0 0;
  color: var(--advisor-body, #465a63);
  font-size: 13px;
  line-height: 1.55;
}

.readiness-optional {
  border: 1px solid var(--advisor-line, #e2ebeb);
  border-radius: 14px;
  background: #fff;
  overflow: hidden;
}

.readiness-optional summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 46px;
  padding: 0 13px;
  color: var(--advisor-primary, #087f8f);
  font-size: 14px;
  font-weight: 850;
  list-style: none;
}

.readiness-optional summary::-webkit-details-marker {
  display: none;
}

.readiness-optional summary::after {
  content: "\5C55\5F00";
  color: var(--advisor-muted, #71828a);
  font-size: 12px;
  font-weight: 700;
}

.readiness-optional[open] summary::after {
  content: "\6536\8D77";
}

.readiness-optional .readiness-condition {
  margin: 0 12px 12px;
  box-shadow: none;
}
