:root {
  color-scheme: light;

  /* Typography tokens: change these once to restyle the app. */
  --font-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-display: Georgia, "Times New Roman", ui-serif, serif;
  --font-mono: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
  --type-hero: clamp(2.3rem, 5.4vw, 4.5rem);
  --type-question: clamp(2rem, 4.7vw, 3.8rem);
  --type-section: clamp(1.45rem, 2.8vw, 2.1rem);
  --type-card-title: clamp(1.15rem, 2.2vw, 1.48rem);
  --type-metric: clamp(1rem, 1.7vw, 1.24rem);
  --type-body: 1rem;
  --type-caption: 0.86rem;
  --type-label: 0.74rem;

  /* Layout tokens: components consume these, themes do not redefine structure. */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-7: 32px;
  --space-8: 40px;
  --radius-xs: 4px;
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 8px;
  --radius-xl: 8px;
  --ring-size: 3px;
  --max-shell: 1180px;
  --max-readable: 66ch;

  /* Fallback theme is the Health Fund Compare forest palette. */
  --color-forest: #263f2e;
  --color-sage: #70835f;
  --color-leaf: #97a77a;
  --color-gold: #c58f35;
  --color-soft-gold: #e0bd70;
  --color-earth: #3d2b1c;
  --color-clay: #b5653e;
  --color-warm-white: #fffaf0;
  --color-brand-navy: var(--color-forest);
  --color-brand-teal: var(--color-sage);
  --color-action-blue: var(--color-forest);
  --color-positive: #507857;
  --color-caution: var(--color-gold);
  --color-negative: #ad5a50;
  --color-neutral: #746c5e;
  --color-unknown: #8b877e;
  --color-page: #f3ead7;
  --color-page-strong: #dfd3b7;
  --color-surface: var(--color-warm-white);
  --color-surface-raised: #fffdfa;
  --color-surface-inset: #f1eadc;
  --color-surface-evidence: #e8eddc;
  --color-surface-watch: #fff1d6;
  --color-surface-compare: #fffdfa;
  --color-surface-selected: #e1ecd4;
  --color-text: #1f2b22;
  --color-text-muted: #625f54;
  --color-line: #d8c9a7;
  --color-line-strong: #a99871;
  --color-on-brand: #fffdfa;
  --color-focus: rgba(201, 153, 69, 0.34);
  --color-shadow: rgba(61, 43, 28, 0.13);
  --shadow-soft: 0 14px 34px var(--color-shadow);
  --shadow-lift: 0 24px 64px rgba(62, 46, 30, 0.18);
  --workflow-render-bg-image: url("../assets/workflow-forest-render-bg.png");
  --workflow-bg-image: url("../assets/workflow-bg-forest-family.png");
  --workflow-bg-position: left bottom;
  --workflow-bg-overlay:
    linear-gradient(180deg, rgba(255, 253, 250, 0.9) 0%, rgba(255, 250, 240, 0.78) 46%, rgba(243, 234, 215, 0.9) 100%),
    radial-gradient(circle at 12% 12%, rgba(197, 143, 53, 0.16), transparent 28%),
    radial-gradient(circle at 88% 18%, rgba(112, 131, 95, 0.14), transparent 30%);
}

html {
  scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}

html[data-theme="forest"] {
  --color-forest: #263f2e;
  --color-sage: #70835f;
  --color-leaf: #97a77a;
  --color-gold: #c58f35;
  --color-soft-gold: #e0bd70;
  --color-earth: #3d2b1c;
  --color-clay: #b5653e;
  --color-warm-white: #fffaf0;
  --color-brand-navy: var(--color-forest);
  --color-brand-teal: var(--color-sage);
  --color-action-blue: var(--color-forest);
  --color-positive: #507857;
  --color-caution: var(--color-gold);
  --color-negative: #ad5a50;
  --color-neutral: #746c5e;
  --color-unknown: #8b877e;
  --color-page: #f3ead7;
  --color-page-strong: #dfd3b7;
  --color-surface: var(--color-warm-white);
  --color-surface-raised: #fffdfa;
  --color-surface-inset: #f1eadc;
  --color-surface-evidence: #e8eddc;
  --color-surface-watch: #fff1d6;
  --color-surface-compare: #fffdfa;
  --color-surface-selected: #e1ecd4;
  --color-text: #1f2b22;
  --color-text-muted: #625f54;
  --color-line: #d8c9a7;
  --color-line-strong: #a99871;
  --color-on-brand: #fffdfa;
  --color-focus: rgba(201, 153, 69, 0.34);
  --shadow-soft: 0 14px 34px rgba(61, 43, 28, 0.13);
  --shadow-lift: 0 24px 64px rgba(61, 43, 28, 0.18);
}

* {
  box-sizing: border-box;
}

html,
body {
  min-height: 100%;
}

body {
  margin: 0;
  background:
    linear-gradient(135deg, rgba(255, 250, 240, 0.95), rgba(243, 234, 215, 0.86) 44%, rgba(223, 211, 183, 0.9)),
    var(--color-page);
  color: var(--color-text);
  font-family: var(--font-sans);
  letter-spacing: 0;
}

button,
input,
textarea {
  font: inherit;
}

button {
  cursor: pointer;
}

button:disabled {
  cursor: not-allowed;
  opacity: 0.48;
}

button:focus-visible,
input:focus-visible,
textarea:focus-visible,
summary:focus-visible {
  outline: none;
  box-shadow: 0 0 0 var(--ring-size) var(--color-focus);
}

noscript {
  display: block;
  padding: var(--space-6);
}

.public-offers-shell {
  position: relative;
  z-index: 0;
  isolation: isolate;
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto;
  padding: var(--space-6) 0 var(--space-8);
}

.public-offers-shell::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    var(--workflow-bg-overlay),
    var(--workflow-bg-image) var(--workflow-bg-position) / cover no-repeat,
    var(--color-page);
  opacity: 0.96;
}

.public-offers-shell::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(255, 253, 250, 0.82), rgba(255, 253, 250, 0.6) 46%, rgba(255, 253, 250, 0.86)),
    linear-gradient(180deg, rgba(255, 253, 250, 0.18), rgba(255, 250, 240, 0.68));
}

.public-offers-hero {
  min-height: 42vh;
  display: grid;
  align-content: space-between;
  gap: var(--space-8);
  padding: var(--space-6) 0 var(--space-8);
}

.public-offers-nav,
.public-offer-card-top,
.public-offer-footer,
.public-offers-tools,
.public-offers-tabs {
  display: flex;
  align-items: center;
}

.public-offers-nav {
  justify-content: space-between;
  gap: var(--space-4);
}

.public-offers-home,
.public-offer-footer a {
  color: var(--color-forest);
  font-weight: 850;
  text-decoration: none;
}

.public-offers-home {
  letter-spacing: 0;
}

.public-offers-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.85fr);
  gap: var(--space-7);
  align-items: end;
}

.public-offers-hero h1 {
  max-width: 12ch;
  margin: 0;
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--type-hero);
  font-weight: 700;
  line-height: 0.98;
}

.public-offers-hero p {
  max-width: 62ch;
  margin: var(--space-5) 0 0;
  color: var(--color-text-muted);
  font-size: 1.08rem;
  line-height: 1.68;
}

.public-offers-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
}

.public-offers-metrics div {
  min-height: 124px;
  display: grid;
  align-content: space-between;
  padding: var(--space-4);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  background: rgba(255, 253, 250, 0.82);
  box-shadow: 0 12px 32px rgba(47, 75, 55, 0.08);
}

.public-offers-metrics strong {
  color: var(--color-forest);
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1;
}

.public-offers-metrics span,
.public-offer-facts dt,
.public-offer-status,
.public-offer-footer span,
.public-offers-search span,
.public-offers-count {
  color: var(--color-text-muted);
  font-size: var(--type-label);
  font-weight: 850;
  letter-spacing: 0;
  text-transform: uppercase;
}

.public-offers-tools {
  position: sticky;
  top: 0;
  z-index: 3;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  background: color-mix(in srgb, var(--color-surface) 82%, transparent);
  box-shadow: 0 16px 34px rgba(47, 75, 55, 0.1);
  backdrop-filter: blur(14px);
}

.public-offers-tabs {
  flex-wrap: wrap;
  gap: var(--space-2);
}

.public-offers-tabs button {
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0 var(--space-3);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  background: var(--color-surface-raised);
  color: var(--color-text);
  font-size: 0.9rem;
  font-weight: 800;
}

.public-offers-tabs button.selected {
  border-color: var(--color-forest);
  background: var(--color-forest);
  color: var(--color-on-brand);
}

.public-offers-tabs button span {
  opacity: 0.74;
}

.public-offers-search {
  min-width: min(320px, 100%);
  display: grid;
  gap: var(--space-2);
}

.public-offers-search input {
  width: 100%;
  min-height: 42px;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  padding: 0 var(--space-3);
  background: var(--color-surface-raised);
  color: var(--color-text);
  font-size: 0.95rem;
}

.public-offers-count {
  margin: 0;
  white-space: nowrap;
}

.public-offers-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-4);
  padding-top: var(--space-5);
}

.public-offer-card {
  min-height: 360px;
  display: grid;
  grid-template-rows: auto auto auto 1fr auto;
  gap: var(--space-4);
  padding: var(--space-5);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  background: var(--color-surface-raised);
  box-shadow: 0 14px 32px rgba(47, 75, 55, 0.08);
}

.public-offer-card-top {
  justify-content: space-between;
  gap: var(--space-3);
  align-items: start;
}

.public-offer-provider {
  margin: 0 0 var(--space-2);
  color: var(--color-forest);
  font-size: 0.86rem;
  font-weight: 900;
}

.public-offer-card h2 {
  margin: 0;
  font-size: var(--type-card-title);
  line-height: 1.16;
}

.public-offer-status {
  flex: 0 0 auto;
  padding: 6px 8px;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-sm);
  background: var(--color-surface-evidence);
  color: var(--color-forest);
}

.public-offer-summary {
  margin: 0;
  color: var(--color-text-muted);
  line-height: 1.55;
}

.public-offer-reward {
  display: grid;
  gap: 4px;
  padding: 10px 11px;
  border-left: 4px solid var(--color-gold);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-soft-gold) 16%, var(--color-surface-raised));
}

.public-offer-reward span {
  color: var(--color-forest);
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
}

.public-offer-reward strong {
  color: var(--color-text);
  font-size: 0.98rem;
  line-height: 1.3;
}

.public-offer-facts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
  margin: 0;
}

.public-offer-facts div {
  display: grid;
  gap: 3px;
}

.public-offer-facts dd {
  margin: 0;
  color: var(--color-text);
  font-weight: 750;
  line-height: 1.35;
}

.public-offer-validity dd {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 8px;
}

.public-offer-validity dd span:nth-child(2) {
  color: var(--color-text-muted);
  font-weight: 700;
}

.public-offer-footer {
  justify-content: space-between;
  gap: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-line);
}

.app-shell {
  position: relative;
  min-height: min(100vh, 930px);
  display: grid;
  grid-template-columns: minmax(420px, 0.78fr) minmax(560px, 1.22fr);
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(255, 250, 240, 0.34) 0%, rgba(255, 250, 240, 0.44) 35%, rgba(255, 253, 250, 0.68) 58%, rgba(255, 253, 250, 0.88) 100%),
    linear-gradient(180deg, rgba(255, 250, 240, 0.28), rgba(231, 221, 196, 0.18)),
    var(--color-page);
}

.app-shell-landing {
  min-height: min(100vh, 960px);
  background:
    var(--workflow-bg-image) center top / 100% auto no-repeat,
    var(--color-page);
  background-attachment: fixed;
}

.app-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: var(--workflow-bg-image) left bottom / cover no-repeat;
  opacity: 0.82;
  -webkit-mask-image:
    linear-gradient(90deg, black 0%, rgba(0, 0, 0, 0.86) 34%, rgba(0, 0, 0, 0.54) 58%, rgba(0, 0, 0, 0.2) 84%, transparent 100%),
    linear-gradient(180deg, rgba(0, 0, 0, 0.44) 0%, black 22%, black 80%, rgba(0, 0, 0, 0.76) 92%, transparent 100%);
  mask-image:
    linear-gradient(90deg, black 0%, rgba(0, 0, 0, 0.86) 34%, rgba(0, 0, 0, 0.54) 58%, rgba(0, 0, 0, 0.2) 84%, transparent 100%),
    linear-gradient(180deg, rgba(0, 0, 0, 0.44) 0%, black 22%, black 80%, rgba(0, 0, 0, 0.76) 92%, transparent 100%);
  -webkit-mask-composite: source-in;
  mask-composite: intersect;
}

.app-shell-landing::before {
  background: var(--workflow-bg-image) center top / 100% auto no-repeat;
  background-attachment: fixed;
  opacity: 1;
  filter: none;
  -webkit-mask-image:
    linear-gradient(180deg, black 0%, black 84%, rgba(0, 0, 0, 0.74) 94%, transparent 100%);
  mask-image:
    linear-gradient(180deg, black 0%, black 84%, rgba(0, 0, 0, 0.74) 94%, transparent 100%);
}

.app-shell::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  z-index: 0;
  height: 28%;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255, 250, 240, 0), rgba(255, 250, 240, 0.58) 58%, rgba(255, 250, 240, 0.9) 100%);
}

.app-shell-landing::after {
  inset: 0;
  height: auto;
  background:
    radial-gradient(52vw 42vh at 64% 48%, rgba(255, 253, 250, 0.54), rgba(255, 253, 250, 0.18) 58%, transparent 78%),
    linear-gradient(90deg, rgba(255, 253, 250, 0.06), rgba(255, 253, 250, 0.24) 58%, rgba(255, 253, 250, 0.62));
}

.app-shell > * {
  position: relative;
  z-index: 1;
}

.app-shell-warmup-focus {
  grid-template-columns: 1fr;
  place-items: stretch;
  min-height: 100dvh;
  background: #fffdfa;
}

.app-shell-warmup-focus::before {
  background: var(--workflow-render-bg-image) center center / cover no-repeat;
  opacity: 1;
  filter: none;
  -webkit-mask-image: none;
  mask-image: none;
}

.app-shell-warmup-focus::after {
  inset: 0;
  z-index: 1;
  height: auto;
  background:
    linear-gradient(180deg, rgba(255, 253, 250, 0.98) 0 112px, rgba(255, 253, 250, 0.24) 176px, transparent 300px),
    linear-gradient(180deg, transparent 70%, rgba(38, 63, 46, 0.18) 100%);
}

.app-shell-warmup-focus .visual-panel {
  grid-column: 1;
  grid-row: 1;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.app-shell-warmup-focus .question-panel {
  grid-column: 1;
  grid-row: 1;
  z-index: 2;
  position: relative;
  isolation: isolate;
  width: 100%;
  display: grid;
  grid-template-rows: 1fr;
  place-items: center;
  padding: clamp(24px, 4vw, 56px);
  background: transparent;
}

.app-shell-warmup-focus .question-card {
  position: relative;
  z-index: 1;
  max-width: min(1040px, calc(100vw - 48px));
}

.app-shell-warmup-focus .question-card {
  align-self: center;
  gap: 14px;
  margin: 0 auto;
  padding: clamp(24px, 3vw, 34px);
  border-color: color-mix(in srgb, var(--color-gold) 40%, var(--color-line));
  background:
    linear-gradient(180deg, rgba(255, 253, 250, 0.98), rgba(255, 250, 240, 0.96)),
    var(--color-surface-raised);
  box-shadow: 0 28px 70px rgba(38, 63, 46, 0.2), 0 10px 30px rgba(61, 43, 28, 0.1);
  transform: none;
  transition: transform 220ms ease, box-shadow 220ms ease, background 220ms ease;
}

.focus-card-header {
  display: grid;
  grid-template-columns: minmax(220px, 0.72fr) auto;
  align-items: start;
  gap: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid color-mix(in srgb, var(--color-line) 66%, transparent);
}

.focus-card-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
}

.question-meta {
  justify-content: space-between;
  gap: var(--space-3);
}

.focus-card-header .question-progress {
  width: min(360px, 100%);
}

.focus-card-header .why-button,
.focus-card-header .home-button {
  background: rgba(255, 253, 250, 0.86);
}

.app-shell-warmup-focus .question-card h2 {
  font-size: clamp(1.62rem, 2.55vw, 2.15rem);
}

.app-shell-warmup-focus .option-grid {
  gap: 12px;
  margin-top: var(--space-4);
}

.app-shell-warmup-focus .choice {
  min-height: 86px;
  font-size: 1.02rem;
}

.app-shell-warmup-focus .question-panel > .accuracy-hint,
.app-shell-warmup-focus .question-panel > .reset-row {
  display: none;
}

.visual-panel {
  position: relative;
  min-height: min(100vh, 930px);
  height: min(100vh, 930px);
  overflow: visible;
  display: grid;
  grid-template-rows: 1fr auto;
  gap: var(--space-5);
  align-items: stretch;
  padding: 44px 46px 28px;
  background: transparent;
  color: var(--color-text);
  isolation: isolate;
}

.visual-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(61, 43, 28, 0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(61, 43, 28, 0.045) 1px, transparent 1px);
  background-size: 52px 52px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.3), transparent 88%);
}

.visual-system {
  position: relative;
  z-index: 1;
  min-height: 0;
  height: 100%;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: var(--space-4);
  pointer-events: none;
}

.brand-lockup {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: fit-content;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

.brand-mark {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border: 1px solid color-mix(in srgb, var(--color-gold) 56%, var(--color-line));
  border-radius: var(--radius-lg);
  background: linear-gradient(145deg, var(--color-forest), color-mix(in srgb, var(--color-forest) 74%, var(--color-clay)));
  color: var(--color-on-brand);
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 900;
  box-shadow: 0 14px 26px rgba(38, 63, 46, 0.18);
}

.brand-lockup span:last-child {
  display: grid;
  gap: 1px;
}

.brand-lockup strong {
  color: var(--color-forest);
  font-family: var(--font-display);
  font-size: 1.42rem;
  font-weight: 700;
  line-height: 1;
}

.brand-lockup small {
  color: color-mix(in srgb, var(--color-gold) 78%, var(--color-earth));
  font-size: 0.95rem;
  font-weight: 780;
}

.brand-art-shell {
  position: absolute;
  z-index: 0;
  top: 116px;
  right: clamp(-310px, -15vw, -150px);
  bottom: -30px;
  left: clamp(-96px, -5vw, -38px);
  display: none;
  place-items: stretch;
  width: auto;
  min-height: 0;
  margin: 0;
  pointer-events: none;
}

.brand-tree-art {
  display: block;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: none;
  object-fit: cover;
  object-position: left bottom;
  filter: saturate(1.04) contrast(1.01);
  -webkit-mask-image:
    linear-gradient(90deg, transparent 0%, rgba(0, 0, 0, 0.42) 5%, black 16%, black 56%, rgba(0, 0, 0, 0.58) 78%, transparent 100%),
    linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.24) 7%, rgba(0, 0, 0, 0.72) 15%, black 28%, black 82%, rgba(0, 0, 0, 0.72) 91%, transparent 100%);
  mask-image:
    linear-gradient(90deg, transparent 0%, rgba(0, 0, 0, 0.42) 5%, black 16%, black 56%, rgba(0, 0, 0, 0.58) 78%, transparent 100%),
    linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.24) 7%, rgba(0, 0, 0, 0.72) 15%, black 28%, black 82%, rgba(0, 0, 0, 0.72) 91%, transparent 100%);
  -webkit-mask-composite: source-in;
  mask-composite: intersect;
}

.australia-proof {
  z-index: 2;
  position: absolute;
  left: clamp(84px, 10vw, 126px);
  bottom: clamp(-18px, -2vh, -10px);
  display: block;
  max-width: 380px;
  margin: 0;
  padding: 0;
  text-shadow: 0 1px 10px rgba(255, 250, 240, 0.86);
}

.australia-proof > span {
  display: none;
}

.australia-proof p {
  margin: 0;
  color: var(--color-text);
  font-size: 0.95rem;
  line-height: 1.5;
}

.australia-proof strong {
  display: block;
  color: var(--color-text);
}

.visual-content {
  position: relative;
  z-index: 1;
  width: min(560px, 100%);
  display: grid;
  gap: var(--space-3);
}

.visual-panel .visual-content h1 {
  max-width: 13ch;
  font-size: clamp(2.2rem, 4.2vw, 3.8rem);
}

.visual-trail {
  position: relative;
  z-index: 1;
  display: none;
}

.badge {
  width: fit-content;
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 5px 9px;
  border: 1px solid color-mix(in srgb, var(--color-gold) 52%, transparent);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-soft-gold) 18%, transparent);
  color: var(--color-forest);
  font-size: var(--type-caption);
  font-weight: 800;
}

.visual-content h1,
.results-summary h1 {
  margin: 0;
  max-width: 12ch;
  color: var(--color-forest);
  font-family: var(--font-display);
  font-size: var(--type-hero);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: 0;
}

.visual-content p,
.landing-intro p,
.results-summary p,
.unlock-panel p {
  margin: 0;
  max-width: var(--max-readable);
  color: var(--color-text-muted);
  font-size: var(--type-body);
  line-height: 1.58;
}

.landing-intro p {
  font-size: 0.98rem;
}

.hero-trust-line {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-forest);
  font-size: 1rem;
  font-weight: 800;
}

.hero-trust-line svg {
  flex: 0 0 auto;
  width: 24px;
  height: 24px;
  color: var(--color-gold);
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.trail {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  min-height: 34px;
  margin-top: var(--space-1);
}

.flow-context {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-height: 42px;
  padding: 8px 10px;
  border: 1px solid color-mix(in srgb, var(--color-line) 74%, white);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-surface-inset) 48%, rgba(255, 253, 250, 0.82));
}

.flow-context-label {
  flex: 0 0 auto;
  color: var(--color-forest);
  font-size: var(--type-caption);
  font-weight: 840;
}

.flow-context .trail {
  min-height: 0;
  margin-top: 0;
  gap: 6px;
}

.trail span,
.trail-empty {
  margin: 0;
  min-height: 30px;
  padding: 6px 9px;
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in srgb, var(--color-sage) 28%, var(--color-line));
  background: color-mix(in srgb, var(--color-warm-white) 82%, white);
  color: var(--color-forest);
  font-size: var(--type-caption);
  font-weight: 760;
}

.question-panel {
  position: relative;
  z-index: 2;
  min-height: min(100vh, 930px);
  height: min(100vh, 930px);
  overflow: hidden;
  display: grid;
  grid-template-rows: auto auto auto 1fr;
  gap: 14px;
  padding: 34px 56px 18px;
  background:
    linear-gradient(90deg, rgba(255, 250, 240, 0.02) 0%, rgba(255, 250, 240, 0.2) 20%, rgba(255, 253, 249, 0.62) 44%, rgba(255, 253, 249, 0.9) 70%, rgba(255, 253, 250, 0.98) 100%);
  border-left: 0;
}

.landing-nav {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-7);
  min-height: 44px;
}

.flow-nav {
  width: min(720px, 100%);
  margin: 0 auto;
}

.landing-nav a {
  color: var(--color-text);
  font-size: 0.95rem;
  font-weight: 680;
  text-decoration: none;
}

.sign-in-button,
.account-nav-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  min-height: 42px;
  padding: 0 14px;
  border: 1px solid var(--color-forest);
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--color-forest);
  font-weight: 760;
}

.sign-in-button:hover,
.sign-in-button:focus-visible,
.account-nav-pill button:hover,
.account-nav-pill button:focus-visible {
  background: color-mix(in srgb, var(--color-surface-selected) 48%, white);
  border-color: color-mix(in srgb, var(--color-forest) 80%, var(--color-gold));
}

.account-nav-pill {
  max-width: min(320px, 42vw);
  background: color-mix(in srgb, var(--color-surface-selected) 58%, white);
  border-color: color-mix(in srgb, var(--color-forest) 34%, var(--color-line));
  color: var(--color-text);
}

.account-nav-pill span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 760;
}

.account-nav-pill button {
  flex: 0 0 auto;
  min-height: 30px;
  padding: 0 8px;
  border: 1px solid color-mix(in srgb, var(--color-gold) 58%, var(--color-line));
  border-radius: var(--radius-sm);
  background: var(--color-surface-raised);
  color: var(--color-forest);
  font-weight: 820;
}

.home-button {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  min-height: 40px;
  padding: 0 13px;
  border: 1px solid color-mix(in srgb, var(--color-forest) 36%, var(--color-line));
  border-radius: var(--radius-md);
  background: rgba(255, 253, 250, 0.78);
  color: var(--color-forest);
  font-weight: 790;
  box-shadow: 0 10px 24px rgba(61, 43, 28, 0.08);
  backdrop-filter: blur(10px);
}

.home-button:hover,
.home-button:focus-visible {
  border-color: var(--color-forest);
  background: var(--color-surface-raised);
}

.sign-in-button svg {
  width: 17px;
  height: 17px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.home-button svg {
  width: 17px;
  height: 17px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.top-row,
.action-row,
.question-meta,
.result-meta,
.tag-row {
  display: flex;
  align-items: center;
}

.top-row,
.action-row {
  justify-content: space-between;
  gap: var(--space-3);
}

.top-row-compact {
  position: static;
  width: min(720px, 100%);
  margin: 0 auto;
  justify-content: space-between;
}

.landing-intro {
  width: min(720px, 100%);
  margin: 0 auto;
  display: grid;
  gap: var(--space-3);
  padding: 18px 0 2px;
}

.landing-intro h1 {
  margin: 0;
  max-width: 17ch;
  color: var(--color-forest);
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 3.85vw, 3.7rem);
  font-weight: 700;
  line-height: 0.98;
}

.question-card {
  align-self: start;
  display: grid;
  gap: 12px;
  max-width: 720px;
  width: 100%;
  margin: 0 auto;
  padding: 22px 24px 20px;
  border: 1px solid color-mix(in srgb, var(--color-line) 82%, white);
  border-radius: var(--radius-lg);
  background: rgba(255, 253, 250, 0.9);
  box-shadow: 0 18px 42px rgba(61, 43, 28, 0.11);
  backdrop-filter: blur(14px);
}

.question-card::before {
  content: none;
}

.question-meta {
  justify-content: space-between;
  gap: var(--space-3);
  color: var(--color-text-muted);
  font-size: var(--type-caption);
}

.question-card h2 {
  margin: 0;
  max-width: none;
  color: var(--color-text);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(1.34rem, 2vw, 1.62rem);
  line-height: 1.12;
  letter-spacing: 0;
}

.question-note,
.accuracy-hint,
.soft-message,
.privacy-note,
.collection-notice,
.form-note,
.fine-print {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.98rem;
  line-height: 1.5;
}

.collection-notice {
  display: grid;
  gap: 4px;
  padding: var(--space-3);
  border: 1px solid color-mix(in srgb, var(--color-sage) 28%, var(--color-line));
  border-radius: var(--radius-md);
  background: rgba(237, 243, 234, 0.64);
}

.collection-notice strong {
  color: var(--color-forest);
}

.refinement-value-panel,
.refinement-choice-panel {
  display: grid;
  gap: 8px;
  margin-top: var(--space-3);
}

.refinement-value-panel div,
.refinement-choice-panel div {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border: 1px solid color-mix(in srgb, var(--color-gold) 34%, var(--color-line));
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--color-gold) 10%, var(--color-surface));
}

.refinement-choice-panel {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.refinement-choice-panel div:first-child {
  border-color: color-mix(in srgb, var(--color-forest) 48%, var(--color-line));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--color-surface-selected) 56%, white), color-mix(in srgb, var(--color-surface-selected) 28%, var(--color-surface-raised)));
}

.refinement-value-panel strong,
.refinement-choice-panel strong {
  color: var(--color-text);
  font-size: 0.96rem;
  line-height: 1.35;
}

.refinement-value-panel span,
.refinement-choice-panel span {
  color: var(--color-text-muted);
  font-size: 0.82rem;
  font-weight: 840;
  letter-spacing: 0;
  text-transform: uppercase;
}

.inline-link,
.collection-notice a,
.static-shell a {
  color: var(--color-forest);
  font-weight: 760;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.auxiliary-select small {
  color: var(--color-text-muted);
  font-size: 0.86rem;
  line-height: 1.35;
}

.auxiliary-select select {
  width: 100%;
  min-height: 148px;
  padding: 8px;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-text);
  font: inherit;
}

.auxiliary-select option {
  padding: 7px 8px;
  border-radius: 4px;
}

.consent-check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  color: var(--color-text-muted);
  font-size: 0.95rem;
  line-height: 1.4;
}

.consent-check input {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  accent-color: var(--color-forest);
  flex: 0 0 auto;
}

.option-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: var(--space-2);
}

.option-grid-compact {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.choice {
  min-height: 74px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  background:
    linear-gradient(180deg, rgba(255, 250, 240, 0.98), rgba(247, 241, 228, 0.94)),
    var(--color-surface-raised);
  color: var(--color-text);
  box-shadow: 0 8px 18px rgba(62, 46, 30, 0.055);
  text-align: center;
  transition: border-color 160ms ease, transform 160ms ease, background 160ms ease, box-shadow 160ms ease;
}

.choice-icon {
  flex: 0 0 auto;
  width: 24px;
  height: 24px;
  color: var(--color-sage);
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.choice-icon-logo {
  width: 34px;
  height: 34px;
  object-fit: contain;
  opacity: 1;
  mix-blend-mode: multiply;
}

.choice:hover,
.choice:focus-visible {
  border-color: color-mix(in srgb, var(--color-gold) 72%, var(--color-clay));
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(62, 46, 30, 0.09);
}

.choice.selected {
  border-color: var(--color-forest);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--color-surface-selected) 82%, white), var(--color-surface-selected));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-forest) 66%, transparent), 0 12px 26px rgba(47, 75, 55, 0.1);
}

.choice span {
  display: block;
  overflow-wrap: anywhere;
  font-weight: 780;
  line-height: 1.25;
}

.primary-button,
.secondary-button,
.ghost-button,
.why-button,
.reset-button,
.nav-button,
.provider-filter-button,
.theme-pill {
  min-height: 42px;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  padding: 9px 13px;
  font-weight: 780;
}

.primary-button {
  background: var(--color-action-blue);
  color: var(--color-on-brand);
}

.primary-button:hover,
.primary-button:focus-visible {
  background: color-mix(in srgb, var(--color-action-blue) 84%, black);
}

.secondary-button {
  background: var(--color-surface-raised);
  border-color: var(--color-line);
  color: var(--color-brand-navy);
}

.secondary-button:hover,
.secondary-button:focus-visible {
  border-color: var(--color-line-strong);
  background: var(--color-surface-inset);
}

.action-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  width: min(540px, 100%);
  margin: var(--space-2) auto 0;
}

.action-row-refinement {
  grid-template-columns: 0.78fr 1.2fr 0.98fr;
  width: min(640px, 100%);
}

.question-panel > .action-row {
  position: static;
  width: min(540px, 100%);
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

.question-panel > .accuracy-hint,
.question-panel > .reset-row {
  display: none;
}

.nav-button {
  width: 100%;
  min-width: 0;
  padding: 10px 12px;
  text-align: center;
  box-shadow: 0 8px 18px rgba(62, 46, 30, 0.045);
  transition: border-color 160ms ease, transform 160ms ease, background 160ms ease, box-shadow 160ms ease, color 160ms ease;
}

.nav-button:hover,
.nav-button:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(62, 46, 30, 0.09);
}

.nav-button-back {
  background: var(--color-surface-inset);
  border-color: var(--color-line);
  color: var(--color-text-muted);
}

.nav-button-back:hover,
.nav-button-back:focus-visible {
  border-color: color-mix(in srgb, var(--color-gold) 64%, var(--color-line));
  background: var(--color-surface-raised);
  color: var(--color-text);
}

.nav-button-skip {
  background: transparent;
  border-color: var(--color-forest);
  color: var(--color-forest);
}

.nav-button-skip:hover,
.nav-button-skip:focus-visible {
  border-color: color-mix(in srgb, var(--color-forest) 82%, var(--color-gold));
  background: color-mix(in srgb, var(--color-surface-selected) 44%, white);
}

.nav-button-results {
  background: color-mix(in srgb, var(--color-action-blue) 12%, white);
  border-color: color-mix(in srgb, var(--color-action-blue) 34%, var(--color-line));
  color: var(--color-action-blue);
}

.nav-button-results:hover,
.nav-button-results:focus-visible {
  background: color-mix(in srgb, var(--color-action-blue) 18%, white);
  border-color: color-mix(in srgb, var(--color-action-blue) 48%, var(--color-line));
}

.nav-button-continue {
  background: linear-gradient(135deg, var(--color-forest), color-mix(in srgb, var(--color-forest) 74%, var(--color-clay)));
  border-color: var(--color-forest);
  color: var(--color-on-brand);
}

.nav-button-continue:hover,
.nav-button-continue:focus-visible {
  background: linear-gradient(135deg, color-mix(in srgb, var(--color-forest) 86%, black), color-mix(in srgb, var(--color-forest) 68%, var(--color-clay)));
  border-color: color-mix(in srgb, var(--color-forest) 78%, black);
}

.action-row-refinement .nav-button-results {
  background: linear-gradient(135deg, var(--color-forest), color-mix(in srgb, var(--color-forest) 76%, var(--color-clay)));
  border-color: var(--color-forest);
  color: var(--color-on-brand);
}

.action-row-refinement .nav-button-results:hover,
.action-row-refinement .nav-button-results:focus-visible {
  background: linear-gradient(135deg, color-mix(in srgb, var(--color-forest) 86%, black), color-mix(in srgb, var(--color-forest) 68%, var(--color-clay)));
  border-color: color-mix(in srgb, var(--color-forest) 78%, black);
}

.action-row-refinement .nav-button-continue {
  background: var(--color-surface-raised);
  border-color: color-mix(in srgb, var(--color-forest) 52%, var(--color-line));
  color: var(--color-forest);
}

.action-row-landing {
  grid-template-columns: 1fr;
  gap: var(--space-2);
  width: 100%;
}

.action-row-landing .nav-button {
  min-height: 46px;
  font-size: 1rem;
}

.action-row-landing .nav-button-continue {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.action-row-landing .nav-button-continue span {
  position: absolute;
  right: 18px;
  font-size: 1.45rem;
  line-height: 1;
}

.question-progress {
  display: grid;
  gap: var(--space-3);
  width: min(310px, 100%);
}

.question-progress > div:first-child {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  color: var(--color-text);
  font-size: 0.9rem;
}

.question-progress strong {
  font-weight: 680;
  white-space: nowrap;
}

.progress-bars {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 6px;
}

.progress-bars span {
  height: 6px;
  border-radius: 99px;
  background: color-mix(in srgb, var(--color-line) 56%, white);
}

.progress-bars .active {
  background: var(--color-forest);
}

.why-button-top {
  flex: 0 0 auto;
  color: var(--color-text);
}

.landing-proof-row {
  width: min(720px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-7);
  align-self: start;
  padding-bottom: 0;
}

.landing-continuation {
  position: relative;
  isolation: isolate;
  min-height: 62vh;
  border-top: 0;
  background:
    var(--workflow-bg-image) center top / 100% auto no-repeat,
    var(--color-surface-raised);
  background-attachment: fixed;
}

.landing-continuation::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(54vw 34vh at 50% 10%, rgba(255, 253, 250, 0.62), rgba(255, 253, 250, 0.24) 58%, transparent 78%),
    linear-gradient(180deg, rgba(255, 250, 240, 0.58), rgba(248, 252, 246, 0.68) 58%, rgba(255, 253, 250, 0.82)),
    linear-gradient(90deg, rgba(255, 253, 250, 0.58), rgba(255, 253, 250, 0.36) 48%, rgba(255, 253, 250, 0.58));
}

.scroll-cue {
  display: grid;
  place-items: center;
  height: 92px;
  color: color-mix(in srgb, var(--color-sage) 58%, white);
}

.scroll-cue svg {
  width: 30px;
  height: 30px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.7;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.landing-section-inner,
.landing-info-band {
  width: min(1120px, calc(100% - 40px));
  margin: 0 auto;
}

.landing-section-inner {
  display: grid;
  gap: var(--space-6);
  padding: 0 0 clamp(88px, 8vw, 116px);
}

.landing-section-inner h2,
.landing-info-band h2 {
  margin: 0;
  color: var(--color-forest);
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3.35rem);
  line-height: 1.05;
}

.landing-section-copy {
  display: grid;
  justify-items: center;
  gap: var(--space-3);
  max-width: 780px;
  margin: 0 auto;
  text-align: center;
}

.landing-section-copy p,
.landing-info-copy p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 1.05rem;
  line-height: 1.58;
}

.how-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
  gap: var(--space-5);
  align-items: stretch;
  text-align: left;
}

.how-steps,
.how-proof-panel,
.landing-info-band {
  border: 1px solid color-mix(in srgb, var(--color-line) 88%, white);
  border-radius: var(--radius-lg);
  background: rgba(255, 253, 248, 0.88);
  box-shadow: 0 18px 42px rgba(61, 43, 28, 0.08);
}

.how-steps {
  display: grid;
  gap: 0;
  padding: var(--space-3);
}

.how-step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-4);
  align-items: start;
  padding: var(--space-5);
}

.how-step + .how-step {
  border-top: 1px solid color-mix(in srgb, var(--color-line) 74%, transparent);
}

.how-step > span {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 1px solid color-mix(in srgb, var(--color-sage) 72%, white);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--color-sage) 16%, white);
  color: var(--color-forest);
  font-weight: 900;
}

.how-step h3,
.how-proof-panel h3 {
  margin: 0;
  color: var(--color-text);
  font-size: 1.12rem;
}

.how-step p,
.how-proof-panel span,
.landing-info-list span {
  margin: 0;
  color: var(--color-text-muted);
  line-height: 1.58;
}

.how-step div {
  display: grid;
  gap: var(--space-2);
}

.how-proof-panel {
  display: grid;
  align-content: start;
  gap: var(--space-4);
  padding: var(--space-5);
  background:
    linear-gradient(135deg, rgba(238, 247, 236, 0.88), rgba(255, 250, 240, 0.9)),
    var(--color-surface-raised);
}

.how-proof-panel ul,
.landing-info-list {
  display: grid;
  gap: var(--space-3);
  margin: 0;
  padding: 0;
  list-style: none;
}

.how-proof-panel li,
.landing-info-list > div {
  display: grid;
  gap: 4px;
  padding: var(--space-3);
  border: 1px solid color-mix(in srgb, var(--color-line) 78%, transparent);
  border-radius: var(--radius-sm);
  background: rgba(255, 253, 248, 0.78);
}

.how-proof-panel strong,
.landing-info-list strong {
  color: var(--color-forest);
}

.landing-info-band {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(340px, 1fr);
  gap: var(--space-6);
  align-items: center;
  margin-top: clamp(48px, 5vw, 72px);
  margin-bottom: clamp(88px, 8vw, 116px);
  padding: var(--space-6);
  border-color: color-mix(in srgb, var(--color-line) 82%, white);
  background:
    linear-gradient(135deg, rgba(255, 253, 250, 0.97), rgba(255, 253, 250, 0.92)),
    var(--color-surface-raised);
  box-shadow: 0 22px 58px rgba(61, 43, 28, 0.12);
  backdrop-filter: blur(18px);
}

.landing-info-copy {
  display: grid;
  gap: var(--space-3);
}

.landing-info-list .inline-link {
  justify-self: start;
  margin-top: var(--space-1);
}

@media (max-height: 820px) and (min-width: 861px) {
  .question-panel {
    gap: 10px;
    padding-top: 24px;
    padding-bottom: 14px;
  }

  .landing-nav {
    min-height: 38px;
  }

  .landing-intro {
    gap: 8px;
    padding-top: 4px;
  }

  .landing-intro h1 {
    font-size: clamp(2.25rem, 3.45vw, 3.25rem);
  }

  .landing-intro p,
  .hero-trust-line {
    font-size: 0.92rem;
  }

  .question-card {
    padding: 16px 20px 14px;
  }

  .option-grid {
    gap: 8px;
    margin-top: 10px;
  }

  .choice {
    min-height: 58px;
    padding: 8px 10px;
  }

  .action-row {
    margin-top: 8px;
  }

  .action-row-landing .nav-button {
    min-height: 42px;
  }

  .landing-proof-row {
    gap: var(--space-4);
    align-items: center;
  }

  .landing-proof-row svg {
    width: 30px;
    height: 30px;
  }

  .landing-proof-row p {
    gap: 0;
    font-size: 0.84rem;
    line-height: 1.25;
  }

  .landing-proof-row p span {
    display: none;
  }

  .brand-art-shell {
    top: 96px;
    right: clamp(-250px, -12vw, -130px);
    bottom: -22px;
    left: clamp(-82px, -5vw, -36px);
  }

  .australia-proof {
    bottom: -18px;
    max-width: 360px;
  }

  .australia-proof p {
    font-size: 0.88rem;
    line-height: 1.38;
  }
}

.landing-proof-row > div {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-3);
}

.landing-proof-row svg {
  width: 34px;
  height: 34px;
  color: var(--color-forest);
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.landing-proof-row p {
  display: grid;
  gap: 4px;
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.9rem;
  line-height: 1.4;
}

.landing-proof-row strong {
  color: var(--color-text);
  font-size: 0.92rem;
}

.ghost-button,
.why-button,
.reset-button,
.theme-pill {
  background: transparent;
  color: var(--color-text-muted);
}

.why-button {
  display: inline-flex;
  gap: var(--space-2);
  align-items: center;
  min-height: auto;
  border: 0;
  padding: 2px 0;
  background: transparent;
  font-size: 0.92rem;
  line-height: 1.2;
}

.why-button span {
  display: inline-grid;
  place-items: center;
  width: 18px;
  height: 18px;
  border: 1px solid var(--color-line);
  border-radius: 50%;
  font-size: 0.72rem;
  font-weight: 850;
}

.why-panel {
  border-left: 3px solid var(--color-brand-teal);
  padding: 10px 12px;
  background: var(--color-surface-evidence);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}

.why-panel p {
  margin: 0;
  color: var(--color-text);
  line-height: 1.45;
}

.field-label {
  position: relative;
  display: grid;
  gap: var(--space-2);
}

.auxiliary-field {
  margin-top: -4px;
  color: var(--color-text-muted);
  font-weight: 730;
}

.premium-followup .money-prefix {
  top: auto;
  bottom: 14px;
  transform: none;
}

.postcode-followup {
  max-width: 360px;
  margin-top: var(--space-3);
}

.postcode-followup small {
  color: var(--color-text-muted);
  font-weight: 500;
  line-height: 1.35;
}

.current-tier-followup {
  margin-top: var(--space-3);
}

.tier-option-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-2);
}

.tier-choice {
  min-height: 46px;
  justify-content: center;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--color-surface-raised) 90%, white), var(--color-surface));
  color: var(--color-text);
  font-size: 0.92rem;
  font-weight: 850;
  line-height: 1.15;
  box-shadow: none;
}

.tier-choice:hover,
.tier-choice:focus-visible {
  border-color: color-mix(in srgb, var(--color-brand-teal) 58%, var(--color-line));
  background: color-mix(in srgb, var(--color-surface-selected) 42%, var(--color-surface-raised));
}

.tier-choice.selected {
  border-color: var(--color-brand-teal);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--color-surface-selected) 84%, white), var(--color-surface-selected));
  color: var(--color-brand-navy);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-brand-teal) 38%, transparent);
}

.field-label input,
.field-label textarea,
.email-form input {
  width: 100%;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  background: var(--color-surface-raised);
  color: var(--color-text);
  padding: 14px 15px;
  font-size: 1rem;
  line-height: 1.4;
}

.field-label input:focus,
.field-label textarea:focus,
.email-form input:focus {
  border-color: var(--color-action-blue);
}

.money-prefix {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-text-muted);
  font-weight: 850;
}

.money-prefix + input {
  padding-left: 34px;
}

.reset-row {
  display: flex;
  justify-content: center;
}

.reset-row-results {
  width: min(var(--max-shell), 100%);
  margin: 0 auto;
}

.reset-button {
  min-height: 36px;
  padding: 6px 10px;
  color: var(--color-text-muted);
  font-size: 0.9rem;
}

.reset-button:hover,
.reset-button:focus-visible {
  color: var(--color-brand-navy);
  text-decoration: underline;
}

.confidence {
  display: grid;
  gap: var(--space-2);
  min-width: min(290px, 100%);
}

.confidence-compact {
  width: min(280px, 48vw);
  min-width: 190px;
}

.confidence-copy {
  display: grid;
  gap: 2px;
  color: var(--color-text-muted);
  font-size: 0.78rem;
  line-height: 1.2;
}

.confidence-copy strong {
  color: var(--color-text);
  font-size: 0.96rem;
}

.eyebrow {
  color: var(--color-brand-teal);
  font-weight: 850;
  text-transform: uppercase;
  font-size: var(--type-label);
}

.confidence-track {
  overflow: hidden;
  height: 7px;
  border-radius: 99px;
  background: color-mix(in srgb, var(--color-line) 72%, white);
}

.confidence-track span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--color-caution), var(--color-action-blue), var(--color-positive));
  transition: width 220ms ease;
}

.results-shell {
  min-height: 100vh;
  padding: var(--space-7);
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--color-page) 42%, var(--color-surface-raised)),
      var(--color-page) 38%,
      var(--color-page-strong)
    ),
    var(--color-page);
  display: grid;
  gap: var(--space-5);
  align-content: start;
}

.results-summary,
.unlock-panel,
.clarification-panel {
  display: grid;
  gap: var(--space-3);
  width: min(var(--max-shell), 100%);
  margin: 0 auto;
  padding: var(--space-5);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-soft);
}

.results-summary {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--color-forest) 92%, black), color-mix(in srgb, var(--color-sage) 46%, var(--color-forest))),
    var(--color-forest);
  color: var(--color-on-brand);
}

.results-summary::before {
  content: "";
  position: absolute;
  right: -80px;
  bottom: -170px;
  width: min(44vw, 430px);
  aspect-ratio: 650 / 742;
  background: url("../assets/brand-tree.png") center / contain no-repeat;
  opacity: 0.18;
  pointer-events: none;
}

.results-summary::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(247, 246, 242, 0.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(247, 246, 242, 0.055) 1px, transparent 1px);
  background-size: 42px 42px;
  pointer-events: none;
  mask-image: linear-gradient(90deg, transparent, rgba(0, 0, 0, 0.58));
}

.results-summary > * {
  position: relative;
  z-index: 1;
}

.results-summary-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
}

.results-summary .ghost-button,
.results-summary .theme-pill {
  width: fit-content;
  color: rgba(255, 255, 255, 0.86);
}

.theme-pill {
  min-height: 34px;
  border-color: rgba(247, 246, 242, 0.26);
  padding: 5px 9px;
  text-transform: capitalize;
}

.results-count-pill {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 5px 10px;
  border: 1px solid rgba(247, 246, 242, 0.26);
  border-radius: var(--radius-md);
  background: rgba(247, 246, 242, 0.12);
  color: rgba(255, 253, 250, 0.9);
  font-size: var(--type-caption);
  font-weight: 850;
}

.results-title-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, 330px);
  align-items: end;
  gap: var(--space-4);
}

.results-title-copy {
  display: grid;
  gap: var(--space-2);
}

.results-summary h1 {
  max-width: 14ch;
  color: var(--color-on-brand);
  font-size: clamp(1.9rem, 4.1vw, 3.5rem);
}

.results-summary p {
  max-width: 62ch;
  color: rgba(255, 253, 250, 0.78);
}

.results-summary .confidence {
  width: 100%;
  padding: 9px;
  border: 1px solid rgba(247, 246, 242, 0.22);
  border-radius: var(--radius-md);
  background: rgba(247, 246, 242, 0.1);
}

.results-summary .confidence-copy,
.results-summary .confidence-copy strong,
.results-summary .eyebrow {
  color: white;
}

.results-summary .fine-print {
  color: rgba(255, 253, 250, 0.74);
  font-size: 0.92rem;
}

.summary-tools {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}

.loading-summary {
  justify-items: start;
}

.loading-orb {
  width: 42px;
  height: 42px;
  border: 4px solid rgba(247, 246, 242, 0.28);
  border-top-color: var(--color-soft-gold);
  border-radius: 50%;
  animation: spin 900ms linear infinite;
}

.loading-bar {
  position: relative;
  overflow: hidden;
  width: min(420px, 100%);
  height: 8px;
  border-radius: 999px;
  background: rgba(247, 246, 242, 0.18);
}

.loading-bar span {
  position: absolute;
  inset-block: 0;
  left: -35%;
  width: 35%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(226, 196, 122, 0.1), var(--color-soft-gold), rgba(226, 196, 122, 0.1));
  animation: loadingSweep 1.25s ease-in-out infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes loadingSweep {
  to {
    left: 100%;
  }
}

.results-workspace {
  width: min(var(--max-shell), 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.42fr);
  gap: var(--space-4);
  align-items: start;
}

.shortlist-panel,
.promotion-panel {
  width: min(var(--max-shell), 100%);
  margin: 0 auto;
  border: 1px solid color-mix(in srgb, var(--color-sage) 22%, var(--color-line));
  border-radius: var(--radius-lg);
  background:
    linear-gradient(180deg, rgba(255, 253, 250, 0.96), rgba(247, 246, 242, 0.9)),
    var(--color-surface-raised);
  box-shadow: var(--shadow-soft);
}

.shortlist-panel {
  display: grid;
  gap: var(--space-4);
  padding: var(--space-4);
}

.shortlist-header,
.promotion-panel-header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--space-4);
}

.shortlist-header h2,
.promotion-panel h2 {
  margin: 0;
  color: var(--color-text);
  font-size: 1.18rem;
  line-height: 1.18;
}

.shortlist-header p,
.promotion-panel p {
  max-width: 66ch;
  margin: 5px 0 0;
  color: var(--color-text-muted);
  font-size: 0.94rem;
  line-height: 1.45;
}

.shortlist-header > span {
  flex: 0 0 auto;
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  padding: 5px 9px;
  border: 1px solid color-mix(in srgb, var(--color-gold) 38%, var(--color-line));
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--color-soft-gold) 16%, white);
  color: var(--color-forest);
  font-size: var(--type-caption);
  font-weight: 850;
}

.results-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

.promotion-panel {
  display: grid;
  gap: var(--space-4);
  padding: var(--space-4);
}

.results-side-window {
  width: min(var(--max-shell), 100%);
  margin: 0 auto;
}

.results-side-window:empty {
  display: none;
}

.results-side-window .promotion-panel {
  margin: 0;
}

.promotion-panel-header a {
  flex: 0 0 auto;
  min-height: 38px;
  display: inline-grid;
  place-items: center;
  padding: 0 var(--space-3);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  background: var(--color-surface-raised);
  color: var(--color-forest);
  font-weight: 850;
  text-decoration: none;
}

.promotion-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-3);
}

.promotion-card {
  display: grid;
  gap: 7px;
  min-height: 166px;
  padding: var(--space-3);
  border: 1px solid color-mix(in srgb, var(--color-line) 84%, transparent);
  border-left: 4px solid var(--color-gold);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-soft-gold) 9%, var(--color-surface-raised));
}

.promotion-card span,
.promotion-card small {
  color: var(--color-text-muted);
  font-size: 0.72rem;
  font-weight: 850;
  line-height: 1.2;
  text-transform: uppercase;
}

.promotion-card h3 {
  margin: 0;
  color: var(--color-text);
  font-size: 0.98rem;
  line-height: 1.2;
}

.promotion-card strong {
  align-self: end;
  color: var(--color-forest);
  font-size: 0.9rem;
  line-height: 1.28;
}

.clarification-panel {
  grid-template-columns: 1fr auto auto;
  align-items: center;
  border: 1px solid color-mix(in srgb, var(--color-sage) 24%, var(--color-line));
  background:
    linear-gradient(180deg, rgba(255, 253, 250, 0.98), rgba(237, 243, 234, 0.96)),
    var(--color-surface-raised);
  color: var(--color-text);
}

.clarification-panel-compact {
  gap: var(--space-2);
  padding: 10px 12px;
  box-shadow: 0 8px 18px color-mix(in srgb, var(--color-shadow) 40%, transparent);
}

.clarification-panel h2,
.empty-card h2 {
  margin: 0;
  color: var(--color-text);
  font-size: var(--type-card-title);
}

.clarification-panel p,
.empty-card p {
  margin: 5px 0 0;
  color: var(--color-text-muted);
  line-height: 1.45;
}

.clarification-panel ul {
  margin: 0;
  padding-left: 18px;
  color: var(--color-text-muted);
  line-height: 1.45;
}

.result-card,
.empty-card {
  position: relative;
  display: grid;
  gap: var(--space-4);
  padding: var(--space-5);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(180deg, rgba(255, 253, 250, 0.98), rgba(247, 246, 242, 0.94)),
    var(--color-surface-raised);
  box-shadow: var(--shadow-soft);
}

.result-card::before,
.empty-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 5px;
  border-radius: var(--radius-lg) 0 0 var(--radius-lg);
  background: linear-gradient(180deg, var(--color-forest), var(--color-gold));
  opacity: 0.86;
}

.result-card {
  grid-template-columns: auto 1fr;
}

.result-card-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(180px, 260px);
  gap: var(--space-3);
  align-items: start;
}

.empty-card {
  justify-items: start;
}

.result-rank {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: var(--radius-md);
  background: var(--color-forest);
  color: var(--color-on-brand);
  font-weight: 900;
  box-shadow: 0 8px 18px rgba(47, 75, 55, 0.22);
}

.fund-name {
  margin: 0 0 4px;
  color: var(--color-sage);
  font-weight: 850;
}

.result-card h2,
.unlock-panel h2,
.compare-header h2 {
  margin: 0;
  color: var(--color-text);
  font-size: var(--type-card-title);
  line-height: 1.16;
}

.result-subline {
  margin: 6px 0 0;
  color: var(--color-text-muted);
  font-size: var(--type-caption);
  font-weight: 760;
  line-height: 1.35;
}

.result-meta {
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: 10px;
}

.result-meta span,
.tag-row span {
  min-height: 28px;
  padding: 5px 8px;
  border-radius: var(--radius-sm);
  border: 1px solid color-mix(in srgb, var(--color-line) 82%, transparent);
  background: color-mix(in srgb, var(--color-surface-inset) 82%, white);
  color: var(--color-forest);
  font-size: var(--type-caption);
  font-weight: 780;
}

.ranking-badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: 8px;
}

.ranking-badges span {
  min-height: 26px;
  padding: 5px 8px;
  border-radius: var(--radius-sm);
  border: 1px solid color-mix(in srgb, var(--color-teal) 26%, var(--color-line));
  background: color-mix(in srgb, var(--color-teal) 8%, white);
  color: var(--color-forest);
  font-size: var(--type-caption);
  font-weight: 820;
}

.offer-disclosure {
  margin: 8px 0 0;
  color: var(--color-text-muted);
  font-size: var(--type-caption);
  font-weight: 650;
  line-height: 1.45;
}

.account-price {
  display: grid;
  justify-items: start;
  gap: 3px;
  width: min(100%, 248px);
  margin-top: 10px;
  padding: 9px 11px;
  border: 1px solid color-mix(in srgb, var(--color-gold) 46%, var(--color-line));
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-soft-gold) 16%, var(--color-surface-raised));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.78);
}

.account-price-main {
  display: grid;
  min-width: 0;
  align-content: start;
  gap: 4px;
}

.account-price span {
  color: var(--color-forest);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.account-price strong {
  color: var(--color-text);
  font-size: 1.48rem;
  line-height: 1;
  overflow-wrap: anywhere;
}

.account-price small {
  color: var(--color-text-muted);
  font-size: 0.72rem;
  font-weight: 720;
  line-height: 1.28;
}

.account-price-public {
  width: fit-content;
  max-width: 100%;
  grid-template-columns: max-content minmax(220px, 306px);
  align-items: stretch;
  gap: 10px;
  padding: 12px;
}

.account-price-public .account-price-main {
  align-content: start;
  min-width: 190px;
  padding-right: 10px;
  border-right: 1px solid color-mix(in srgb, var(--color-gold) 36%, transparent);
}

.account-price-public .rebate-edit-button {
  min-height: 28px;
  margin-top: 3px;
  padding: 3px 0;
  border-color: transparent;
  background: transparent;
  color: var(--color-text-muted);
  font-size: 0.84rem;
  font-weight: 760;
  justify-self: start;
  text-align: left;
  white-space: nowrap;
}

.account-price-public .rebate-edit-button:hover,
.account-price-public .rebate-edit-button:focus-visible {
  background: transparent;
  color: var(--color-forest);
  text-decoration: underline;
  text-underline-offset: 3px;
}

@media (max-width: 720px) {
  .tier-option-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.account-price-missing strong {
  font-size: 0.98rem;
  line-height: 1.15;
}

.result-promotion {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  max-width: 142px;
  min-height: 26px;
  padding: 5px 9px;
  border: 1px solid color-mix(in srgb, var(--color-gold) 42%, var(--color-line));
  border-radius: 7px;
  background: color-mix(in srgb, var(--color-soft-gold) 26%, var(--color-surface-raised));
  color: #8a641d;
  font-size: 0.68rem;
  font-weight: 920;
  line-height: 1.1;
  letter-spacing: 0;
  text-align: center;
  text-transform: uppercase;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
  cursor: pointer;
  appearance: none;
  font-family: var(--font-sans);
}

.result-promotion:hover,
.result-promotion:focus-visible {
  border-color: color-mix(in srgb, var(--color-gold) 62%, var(--color-line));
  background: color-mix(in srgb, var(--color-soft-gold) 36%, var(--color-surface-raised));
  color: #755112;
}

.result-promotion-detail {
  display: grid;
  gap: 4px;
  width: min(188px, 100%);
  padding: 8px 9px;
  border: 1px solid color-mix(in srgb, var(--color-gold) 38%, var(--color-line));
  border-radius: 8px;
  background: color-mix(in srgb, var(--color-soft-gold) 14%, var(--color-surface-raised));
  text-align: left;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.74);
}

.result-promotion-detail strong {
  color: var(--color-forest);
  font-size: 0.74rem;
  line-height: 1.22;
}

.result-promotion-detail small {
  color: var(--color-text-muted);
  font-size: 0.67rem;
  font-weight: 760;
  line-height: 1.18;
  text-transform: uppercase;
}

.result-promotion-detail a {
  color: #7f5917;
  font-size: 0.7rem;
  font-weight: 850;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.result-card ul {
  margin: 14px 0 0;
  padding-left: 18px;
  color: var(--color-text-muted);
  line-height: 1.45;
}

.result-glance {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-2);
  margin: 12px 0 0;
}

.result-glance div {
  min-width: 0;
  padding: 8px 9px;
  border: 1px solid color-mix(in srgb, var(--color-sage) 18%, var(--color-line));
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--color-surface-inset) 82%, white);
}

.result-glance dt {
  margin: 0 0 3px;
  color: var(--color-text-muted);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1.1;
  text-transform: uppercase;
}

.result-glance dd {
  margin: 0;
  color: var(--color-forest);
  font-size: 0.86rem;
  font-weight: 860;
  line-height: 1.18;
  overflow-wrap: anywhere;
}

.public-savings-signal {
  display: grid;
  align-content: center;
  gap: 3px;
  min-width: 0;
  width: min(306px, 100%);
  margin: 0;
  padding: 10px 12px;
  border: 1px solid color-mix(in srgb, var(--color-sage) 28%, var(--color-line));
  border-radius: var(--radius-md);
  background:
    linear-gradient(135deg, rgba(237, 243, 234, 0.96), rgba(255, 253, 250, 0.94)),
    var(--color-surface-evidence);
}

.public-savings-signal span {
  color: var(--color-forest);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.public-savings-signal strong {
  color: var(--color-brand-navy);
  font-size: 1.3rem;
  line-height: 1.12;
  overflow-wrap: anywhere;
}

.public-savings-signal small {
  color: var(--color-text-muted);
  font-size: 0.84rem;
  line-height: 1.32;
}

.public-savings-positive {
  border-color: color-mix(in srgb, var(--color-positive) 34%, var(--color-line));
  background:
    linear-gradient(135deg, rgba(232, 244, 235, 0.98), rgba(255, 253, 250, 0.95)),
    var(--color-surface-evidence);
}

.public-savings-watch {
  border-color: color-mix(in srgb, var(--color-gold) 48%, var(--color-line));
  background:
    linear-gradient(135deg, rgba(255, 241, 214, 0.92), rgba(255, 253, 250, 0.96)),
    var(--color-surface-watch);
}

.result-signal-strip {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: stretch;
  gap: var(--space-2);
  margin-top: 12px;
}

.result-signal-main,
.result-signal-watch {
  display: grid;
  gap: 3px;
  padding: 9px 10px;
  border: 1px solid color-mix(in srgb, var(--color-sage) 24%, var(--color-line));
  border-radius: var(--radius-md);
  background: var(--color-surface-evidence);
}

.result-signal-main span,
.result-signal-watch span {
  color: var(--color-forest);
  font-size: 0.7rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.result-signal-main strong {
  color: var(--color-text);
  font-size: 0.94rem;
  line-height: 1.22;
}

.result-signal-main small,
.result-signal-watch small {
  color: var(--color-text-muted);
  font-size: 0.78rem;
  line-height: 1.25;
}

.result-signal-watch {
  min-width: 104px;
  align-content: center;
  border-color: color-mix(in srgb, var(--color-caution) 36%, var(--color-line));
  background: var(--color-surface-watch);
}

.result-signal-watch span {
  color: color-mix(in srgb, var(--color-caution) 72%, var(--color-earth));
}

.tag-row {
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 14px;
}

.result-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: 14px;
}

.result-actions .secondary-button {
  min-height: 38px;
}

.compare-selected,
.result-card-compared {
  border-color: color-mix(in srgb, var(--color-gold) 70%, var(--color-line));
  background: var(--color-surface-selected);
}

.result-card-open {
  border-color: color-mix(in srgb, var(--color-forest) 50%, var(--color-line));
}

.provider-filter,
.fund-selector,
.data-scope-note {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  width: min(680px, 100%);
  padding: 10px 12px;
  border: 1px solid rgba(247, 246, 242, 0.24);
  border-radius: var(--radius-md);
  background: rgba(247, 246, 242, 0.12);
}

.data-scope-note {
  display: grid;
  justify-content: stretch;
  gap: 4px;
}

.data-scope-note strong,
.data-scope-note span,
.fund-selector strong,
.fund-selector span,
.provider-filter strong,
.provider-filter span {
  color: var(--color-on-brand);
}

.data-scope-note span,
.fund-selector span,
.provider-filter span {
  color: rgba(255, 253, 250, 0.78);
  font-size: 0.88rem;
  line-height: 1.35;
}

.fund-selector {
  flex-wrap: wrap;
}

.provider-filter div {
  display: grid;
  gap: 2px;
}

.fund-selector-copy {
  display: grid;
  gap: 2px;
  min-width: 210px;
}

.fund-selector-menu {
  flex: 1 1 220px;
  position: relative;
}

.fund-selector-menu summary {
  width: 100%;
  min-height: 38px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: 8px 10px 8px 12px;
  border: 1px solid rgba(247, 246, 242, 0.42);
  border-radius: var(--radius-md);
  background: var(--color-on-brand);
  color: var(--color-forest);
  font: inherit;
  font-weight: 800;
  cursor: pointer;
  list-style: none;
}

.fund-selector-menu summary::-webkit-details-marker {
  display: none;
}

.fund-selector-menu summary svg {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: transform 150ms ease;
}

.fund-selector-menu[open] summary svg {
  transform: rotate(180deg);
}

.fund-selector-menu summary:hover,
.fund-selector-menu summary:focus-visible {
  border-color: color-mix(in srgb, var(--color-gold) 72%, var(--color-line));
  box-shadow: 0 0 0 var(--ring-size) var(--color-focus);
  outline: 0;
}

.fund-selector-popover {
  position: absolute;
  z-index: 20;
  top: calc(100% + 6px);
  right: 0;
  left: 0;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--color-gold) 54%, var(--color-line));
  border-radius: var(--radius-md);
  background: var(--color-surface-raised);
  box-shadow: var(--shadow-lift);
}

.fund-selector-popover ul {
  max-height: min(330px, 48vh);
  margin: 0;
  padding: 4px;
  overflow-y: auto;
  overscroll-behavior: contain;
  list-style: none;
  scrollbar-color: color-mix(in srgb, var(--color-sage) 72%, var(--color-line)) color-mix(in srgb, var(--color-surface-inset) 70%, white);
  scrollbar-width: thin;
}

.fund-selector-popover ul::-webkit-scrollbar {
  width: 12px;
}

.fund-selector-popover ul::-webkit-scrollbar-track {
  background: color-mix(in srgb, var(--color-surface-inset) 70%, white);
  border-left: 1px solid color-mix(in srgb, var(--color-line) 70%, transparent);
}

.fund-selector-popover ul::-webkit-scrollbar-thumb {
  min-height: 44px;
  border: 3px solid color-mix(in srgb, var(--color-surface-inset) 70%, white);
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-sage) 72%, var(--color-line));
}

.fund-selector-popover ul::-webkit-scrollbar-thumb:hover {
  background: var(--color-forest);
}

.fund-selector-popover li {
  margin: 0;
}

.fund-selector-option {
  width: 100%;
  min-height: 38px;
  display: flex;
  align-items: center;
  padding: 8px 10px;
  border: 0;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--color-text);
  font: inherit;
  font-weight: 700;
  line-height: 1.25;
  text-align: left;
  cursor: pointer;
}

.fund-selector-popover > .fund-selector-option {
  border-bottom: 1px solid color-mix(in srgb, var(--color-line) 72%, transparent);
  border-radius: 0;
  background: color-mix(in srgb, var(--color-surface-evidence) 52%, white);
  color: var(--color-forest);
}

.fund-selector-option:hover,
.fund-selector-option:focus-visible {
  background: color-mix(in srgb, var(--color-surface-evidence) 68%, white);
  outline: 0;
}

.fund-selector-option.selected {
  background: var(--color-forest);
  color: var(--color-on-brand);
}

.fund-selector-option span {
  color: inherit;
  font-size: 0.94rem;
  line-height: 1.25;
}

.fund-selector p {
  flex: 1 0 100%;
  margin: 0;
  color: rgba(255, 253, 250, 0.84);
  font-size: 0.86rem;
  line-height: 1.35;
}

.provider-filter-button {
  min-height: 38px;
  flex: 0 0 auto;
  border-color: rgba(247, 246, 242, 0.36);
  background: var(--color-on-brand);
  color: var(--color-forest);
}

.provider-filter-button.selected {
  background: var(--color-soft-gold);
  color: var(--color-brand-navy);
}

.compare-panel {
  position: sticky;
  top: var(--space-4);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: var(--space-3);
  max-height: calc(100vh - (var(--space-4) * 2));
  padding: var(--space-3);
  border: 1px solid color-mix(in srgb, var(--color-sage) 28%, var(--color-line));
  border-radius: var(--radius-md);
  background:
    linear-gradient(180deg, rgba(255, 253, 250, 0.98), rgba(247, 246, 242, 0.94)),
    var(--color-surface-compare);
  box-shadow: var(--shadow-soft);
  overflow: hidden;
}

.compare-header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: var(--space-3);
}

.compare-header p,
.compare-panel p {
  margin: 4px 0 0;
  color: var(--color-text-muted);
  font-size: var(--type-caption);
  line-height: 1.4;
}

.compare-scroll {
  display: grid;
  min-height: 0;
  gap: var(--space-3);
  overflow: auto;
  overscroll-behavior: contain;
  padding-right: 4px;
  scrollbar-color: color-mix(in srgb, var(--color-sage) 62%, var(--color-gold)) color-mix(in srgb, var(--color-soft-gold) 54%, white);
  scrollbar-width: thin;
}

.compare-scroll:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--color-sage) 58%, var(--color-gold));
  outline-offset: 2px;
}

.compare-items {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.compare-item {
  display: inline-flex;
  max-width: 100%;
  gap: 6px;
  align-items: center;
  min-height: 34px;
  padding: 6px 7px;
  border-radius: var(--radius-sm);
  border: 1px solid color-mix(in srgb, var(--color-sage) 18%, var(--color-line));
  background: var(--color-surface-evidence);
}

.compare-item span {
  overflow: hidden;
  max-width: 210px;
  color: var(--color-text);
  font-size: 0.82rem;
  font-weight: 780;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.compare-item .ghost-button {
  min-height: 30px;
  padding: 4px 7px;
  font-size: 0.82rem;
}

.compare-item small {
  color: var(--color-forest);
  font-size: 0.72rem;
  font-weight: 840;
}

.compare-context {
  display: grid;
  gap: var(--space-3);
}

.compare-context-header {
  display: grid;
  gap: 2px;
}

.compare-context-header > span {
  color: var(--color-forest);
  font-size: 0.86rem;
  font-weight: 880;
}

.compare-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--space-2);
}

.compare-card {
  display: grid;
  align-content: start;
  gap: var(--space-2);
  min-width: 0;
  padding: 10px;
  border: 1px solid color-mix(in srgb, var(--color-line) 84%, transparent);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-surface-raised) 88%, var(--color-warm-white));
  transition: transform 180ms ease, border-color 180ms ease, background-color 180ms ease;
}

.compare-card-viewed {
  border-color: color-mix(in srgb, var(--color-gold) 45%, var(--color-line));
  background: var(--color-surface-selected);
}

.compare-card-heading {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.compare-card-heading span {
  color: var(--color-forest);
  font-size: 0.72rem;
  font-weight: 860;
  text-transform: uppercase;
}

.compare-card-heading strong,
.compare-card-heading small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.compare-card-heading strong {
  color: var(--color-text);
  font-size: 0.92rem;
  line-height: 1.18;
}

.compare-card-heading small {
  color: var(--color-text-muted);
  font-size: 0.76rem;
}

.compare-card-metrics {
  display: grid;
  gap: 6px;
}

.compare-metric {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 3px;
  padding-top: 6px;
  border-top: 1px solid color-mix(in srgb, var(--color-line) 74%, transparent);
}

.compare-metric-head {
  display: flex;
  min-width: 0;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}

.compare-metric-head > span {
  min-width: 0;
  color: var(--color-text-muted);
  font-size: 0.72rem;
  font-weight: 760;
  overflow-wrap: anywhere;
}

.compare-metric strong {
  color: var(--color-text);
  font-size: 0.88rem;
  line-height: 1.2;
  overflow-wrap: break-word;
  word-break: normal;
}

.compare-metric small {
  color: var(--color-text-muted);
  font-size: 0.72rem;
  line-height: 1.25;
  overflow-wrap: break-word;
}

.compare-status {
  flex: 0 0 auto;
  padding: 4px 6px;
  border-radius: var(--radius-sm);
  background: var(--color-surface-inset);
  color: var(--color-text-muted);
  font-size: 0.68rem;
  font-weight: 860;
  text-transform: uppercase;
}

.compare-status-selected {
  background: var(--color-surface-selected);
  color: var(--color-brand-navy);
}

.compare-status-better {
  background: color-mix(in srgb, var(--color-positive) 14%, white);
  color: color-mix(in srgb, var(--color-positive) 76%, black);
}

.compare-status-worse,
.compare-status-watch {
  background: var(--color-surface-watch);
  color: color-mix(in srgb, var(--color-caution) 78%, black);
}

.compare-status-unknown {
  color: var(--color-unknown);
}

.detail-panel {
  margin-top: var(--space-4);
  border: 1px solid color-mix(in srgb, var(--color-sage) 24%, var(--color-line));
  border-radius: var(--radius-lg);
  background:
    linear-gradient(180deg, rgba(255, 253, 250, 0.98), rgba(247, 246, 242, 0.96)),
    var(--color-surface);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

.detail-content,
.plan-detail {
  display: grid;
  gap: var(--space-4);
  max-height: min(78vh, 900px);
  overflow: auto;
  padding: var(--space-4);
  overscroll-behavior: contain;
}

.detail-heading {
  z-index: 3;
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
  align-items: flex-start;
  margin: calc(-1 * var(--space-4)) calc(-1 * var(--space-4)) 0;
  padding: var(--space-4);
  border-bottom: 1px solid color-mix(in srgb, var(--color-sage) 18%, var(--color-line));
  background:
    linear-gradient(180deg, rgba(255, 253, 250, 0.99), rgba(247, 246, 242, 0.97)),
    var(--color-surface);
  backdrop-filter: blur(12px);
}

.detail-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin: calc(-1 * var(--space-4)) calc(-1 * var(--space-4)) 0;
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid color-mix(in srgb, var(--color-sage) 18%, var(--color-line));
  background:
    linear-gradient(180deg, rgba(255, 253, 250, 0.99), rgba(247, 246, 242, 0.97)),
    var(--color-surface);
}

.detail-toolbar-minimal {
  justify-content: space-between;
}

.detail-toolbar > div {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.detail-toolbar .badge {
  justify-self: start;
  border-color: color-mix(in srgb, var(--color-gold) 46%, var(--color-line));
  background: var(--color-surface-selected);
  color: var(--color-forest);
}

.detail-toolbar p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: var(--type-caption);
  line-height: 1.35;
}

.detail-heading > div {
  display: grid;
  gap: 7px;
}

.detail-heading-actions {
  display: grid;
  justify-items: end;
  gap: var(--space-2);
}

.account-price-detail {
  margin-top: 0;
  width: min(100%, 250px);
}

.account-price-detail strong {
  font-size: 1.34rem;
}

.detail-heading .badge {
  border-color: color-mix(in srgb, var(--color-gold) 46%, var(--color-line));
  background: var(--color-surface-selected);
  color: var(--color-forest);
}

.detail-heading h2 {
  margin: 0;
  max-width: 28ch;
  font-size: var(--type-card-title);
}

.detail-heading p,
.detail-unlock p {
  margin: 0;
  color: var(--color-text-muted);
  line-height: 1.45;
}

.detail-close {
  flex: 0 0 auto;
  min-height: 36px;
  padding: 6px 10px;
  box-shadow: 0 8px 18px rgba(47, 75, 55, 0.12);
}

.detail-summary-row,
.detail-section-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.detail-summary-row span,
.detail-section-tabs button {
  min-height: 26px;
  padding: 5px 8px;
  border-radius: var(--radius-sm);
  border: 1px solid color-mix(in srgb, var(--color-line) 80%, transparent);
  background: var(--color-surface-raised);
  color: var(--color-forest);
  font-size: 0.82rem;
  font-weight: 780;
}

.detail-section-tabs button {
  background: var(--color-surface-inset);
  color: var(--color-brand-navy);
}

.detail-section-tabs button.selected {
  border-color: color-mix(in srgb, var(--color-forest) 44%, var(--color-line));
  background: var(--color-surface-selected);
  color: var(--color-forest);
}

.detail-context {
  margin: 0;
  padding: 11px 12px;
  border: 1px solid color-mix(in srgb, var(--color-sage) 34%, var(--color-line));
  border-left: 4px solid var(--color-sage);
  border-radius: var(--radius-md);
  background: var(--color-surface-evidence);
  color: var(--color-text);
  font-size: 0.9rem;
  line-height: 1.42;
}

.detail-context strong {
  color: var(--color-forest);
}

.detail-section {
  display: grid;
  gap: var(--space-2);
}

.detail-section-accordion > details {
  display: grid;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--color-line) 80%, transparent);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-surface-raised) 88%, var(--color-warm-white));
  transition: border-color 180ms ease, background-color 180ms ease;
}

.detail-section-accordion > details[open] {
  border-color: color-mix(in srgb, var(--color-gold) 44%, var(--color-line));
  background: color-mix(in srgb, var(--color-warm-white) 90%, white);
}

.detail-section-accordion > details > summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-2);
  align-items: center;
  padding: 11px 12px;
  list-style: none;
  cursor: pointer;
}

.detail-section-accordion > details > summary::-webkit-details-marker {
  display: none;
}

.detail-section-accordion > details > summary span {
  min-height: 26px;
  padding: 5px 8px;
  border-radius: var(--radius-sm);
  background: var(--color-surface-selected);
  color: var(--color-brand-navy);
  font-size: 0.78rem;
  font-weight: 850;
}

.detail-section-body {
  display: grid;
  gap: var(--space-2);
  padding: 0 10px 10px;
  animation: detailReveal 160ms ease;
}

@keyframes detailReveal {
  from {
    opacity: 0;
    transform: translateY(-2px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.detail-section h3 {
  margin: 0;
  color: var(--color-text);
  font-size: 1rem;
}

.detail-list {
  display: grid;
  gap: var(--space-2);
  margin: 0;
  padding: 0;
  color: var(--color-text-muted);
  list-style: none;
}

.detail-list li {
  display: grid;
  gap: 3px;
  padding: 9px 10px;
  border: 1px solid color-mix(in srgb, var(--color-line) 82%, transparent);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-surface-raised) 86%, var(--color-warm-white));
}

.detail-section-watch .detail-list li {
  background: var(--color-surface-watch);
}

.detail-section-extras .detail-list li.detail-list-more-extras {
  border-color: color-mix(in srgb, var(--color-gold) 54%, var(--color-line));
  background: color-mix(in srgb, var(--color-soft-gold) 24%, var(--color-surface-raised));
}

.detail-section-extras .detail-list li.detail-row-match-exact,
.detail-scroll-list .detail-child-row.detail-row-match-exact {
  border-color: color-mix(in srgb, var(--color-sage) 52%, var(--color-line));
  background: color-mix(in srgb, var(--color-surface-evidence) 74%, var(--color-surface-raised));
}

.detail-section-extras .detail-list li.detail-row-match-exact,
.detail-scroll-list .detail-child-row.detail-row-match-exact {
  box-shadow: inset 3px 0 0 color-mix(in srgb, var(--color-brand-green) 74%, var(--color-sage));
}

.detail-list-expandable {
  padding: 0;
  overflow: hidden;
}

.detail-list details {
  display: grid;
}

.detail-list > li > details[open],
.detail-child-row-expandable > details[open] {
  border-color: color-mix(in srgb, var(--color-gold) 44%, var(--color-line));
  background: color-mix(in srgb, var(--color-warm-white) 84%, white);
}

.detail-list summary {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 8px 9px;
  list-style: none;
  cursor: pointer;
}

.detail-list summary::-webkit-details-marker {
  display: none;
}

.detail-list summary > span {
  display: grid;
  gap: 3px;
}

.detail-list summary em {
  justify-self: end;
  align-self: center;
  white-space: nowrap;
  border-radius: var(--radius-sm);
  background: var(--color-surface-selected);
  color: var(--color-brand-navy);
  padding: 5px 8px;
  font-size: 0.8rem;
  font-style: normal;
  font-weight: 850;
}

.detail-list > li > details[open] > summary em,
.detail-child-row-expandable > details[open] > summary em {
  background: var(--color-surface-watch);
  color: color-mix(in srgb, var(--color-caution) 72%, var(--color-earth));
}

.detail-list > li > details[open] > summary em::before,
.detail-child-row-expandable > details[open] > summary em::before {
  content: "Close list";
}

.detail-list > li > details[open] > summary em,
.detail-child-row-expandable > details[open] > summary em {
  font-size: 0;
}

.detail-list > li > details[open] > summary em::before,
.detail-child-row-expandable > details[open] > summary em::before {
  font-size: 0.8rem;
}

.detail-scroll-list {
  display: grid;
  gap: 5px;
  max-height: min(460px, 62vh);
  overflow: auto;
  overscroll-behavior: auto;
  touch-action: pan-y;
  margin: 0 8px 8px;
  padding: 7px;
  border: 1px solid color-mix(in srgb, var(--color-line) 74%, transparent);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--color-surface-inset) 58%, white);
}

.detail-scroll-close {
  position: sticky;
  bottom: 0;
  z-index: 1;
  min-height: 34px;
  border: 1px solid color-mix(in srgb, var(--color-caution) 32%, var(--color-line));
  border-radius: var(--radius-md);
  background: var(--color-surface-watch);
  color: color-mix(in srgb, var(--color-caution) 72%, var(--color-earth));
  font-size: 0.86rem;
  font-weight: 850;
}

.detail-scroll-list-compact {
  gap: 3px;
  max-height: min(420px, 58vh);
}

.detail-list-more-extras .detail-scroll-list-compact {
  max-height: min(590px, 70vh);
}

.detail-child-row {
  display: grid;
  gap: 2px;
  grid-template-columns: minmax(0, 1fr) auto;
  padding: 6px 7px;
  border-radius: var(--radius-sm);
  background: var(--color-surface-inset);
}

.detail-child-row > strong,
.detail-child-row > span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.detail-child-row > span {
  text-align: right;
}

.detail-child-row small {
  grid-column: 1 / -1;
}

.detail-child-row-expandable {
  display: block;
}

.detail-child-row-expandable details {
  width: 100%;
}

.detail-child-row-expandable summary {
  min-height: 36px;
}

.detail-scroll-list-nested {
  margin: 5px 0 0;
  max-height: min(300px, 42vh);
  border-color: color-mix(in srgb, var(--color-line-strong) 42%, var(--color-line));
  background: color-mix(in srgb, var(--color-surface-inset) 70%, var(--color-surface-raised));
  box-shadow: inset 3px 0 0 color-mix(in srgb, var(--color-line-strong) 52%, var(--color-line));
}

.detail-scroll-list-nested .detail-child-row {
  grid-template-columns: minmax(108px, 0.42fr) minmax(0, 1fr);
  border: 1px solid color-mix(in srgb, var(--color-line) 76%, var(--color-surface-inset));
  background: color-mix(in srgb, var(--color-surface-raised) 74%, var(--color-warm-white));
}

.detail-scroll-list-nested .detail-child-row:nth-child(even) {
  background: color-mix(in srgb, var(--color-warm-white) 58%, var(--color-surface-inset));
}

.detail-child-row-expandable > details[open] > summary {
  background: color-mix(in srgb, var(--color-page-strong) 44%, var(--color-surface-inset));
}

.detail-child-row-expandable > details[open] {
  border-color: color-mix(in srgb, var(--color-line-strong) 62%, var(--color-line));
  background: color-mix(in srgb, var(--color-page-strong) 36%, var(--color-surface-inset));
}

.detail-scroll-list-nested .detail-child-row.detail-row-match-exact {
  border-color: color-mix(in srgb, var(--color-sage) 52%, var(--color-line));
  background: color-mix(in srgb, var(--color-surface-evidence) 66%, var(--color-surface-raised));
}

.detail-scroll-list-nested .detail-child-row.detail-row-match-exact {
  box-shadow: inset 3px 0 0 color-mix(in srgb, var(--color-brand-green) 74%, var(--color-sage));
}

.detail-list strong {
  color: var(--color-text);
  font-size: 0.92rem;
}

.detail-scroll-list-compact .detail-child-row strong {
  font-size: 0.88rem;
}

.detail-list span,
.detail-list small,
.detail-child-row span,
.detail-child-row small,
.detail-empty {
  color: var(--color-text-muted);
  line-height: 1.4;
}

.detail-list small,
.detail-empty {
  font-size: 0.88rem;
}

.detail-empty {
  margin: 0;
}

.detail-loading {
  display: grid;
  justify-items: start;
  gap: 10px;
  padding: var(--space-4);
  color: var(--color-text-muted);
}

.detail-loading .loading-orb {
  width: 28px;
  height: 28px;
  border-width: 3px;
  border-color: color-mix(in srgb, var(--color-sage) 20%, transparent);
  border-top-color: var(--color-gold);
}

.detail-loading p {
  margin: 0;
}

.detail-loading-inline {
  margin-top: var(--space-3);
  padding: var(--space-3);
  border: 1px solid color-mix(in srgb, var(--color-sage) 18%, var(--color-line));
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-surface) 90%, var(--color-sage) 10%);
}

.detail-unlock {
  padding: var(--space-3);
  border: 1px solid color-mix(in srgb, var(--color-sage) 22%, var(--color-line));
  border-radius: var(--radius-md);
  background: var(--color-surface-evidence);
}

/* PHIS 2nd Gen flow styling: keep the post-landing journey in the same warm, editorial system. */
.results-shell {
  position: relative;
  isolation: isolate;
  background:
    var(--workflow-bg-image) center center / cover no-repeat,
    var(--color-page);
  background-attachment: fixed;
}

.results-shell::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(255, 253, 250, 0.5), rgba(255, 253, 250, 0.28) 46%, rgba(255, 253, 250, 0.5)),
    linear-gradient(180deg, rgba(255, 253, 250, 0.16), rgba(255, 250, 240, 0.38));
}

.results-summary {
  min-height: 330px;
  align-content: space-between;
  border: 1px solid color-mix(in srgb, var(--color-gold) 34%, var(--color-line));
  background:
    linear-gradient(90deg, rgba(255, 253, 250, 0.98) 0 62%, rgba(245, 238, 222, 0.9)),
    var(--color-surface-raised);
  color: var(--color-text);
}

.results-summary::before {
  content: none;
}

.results-summary::after {
  background-image:
    linear-gradient(rgba(38, 63, 46, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(38, 63, 46, 0.035) 1px, transparent 1px);
  mask-image: linear-gradient(90deg, transparent 44%, rgba(0, 0, 0, 0.52));
}

.results-brand-lockup {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.results-brand-lockup > span {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border: 1px solid rgba(255, 253, 250, 0.36);
  border-radius: var(--radius-md);
  background: linear-gradient(145deg, #2f513b, #1d3325);
  color: var(--color-on-brand);
  font-family: var(--font-display);
  font-size: 1.06rem;
  font-weight: 800;
  box-shadow: 0 12px 26px rgba(61, 43, 28, 0.12);
}

.results-brand-lockup div {
  display: grid;
  gap: 1px;
}

.results-brand-lockup strong {
  color: var(--color-forest);
  font-family: var(--font-display);
  font-size: 1.24rem;
  line-height: 1;
}

.results-brand-lockup small {
  color: var(--color-gold);
  font-size: 0.9rem;
  font-weight: 760;
}

.results-count-pill {
  border-color: color-mix(in srgb, var(--color-sage) 30%, var(--color-line));
  background: rgba(255, 253, 250, 0.78);
  color: var(--color-forest);
}

.results-summary .badge {
  width: fit-content;
  border-color: color-mix(in srgb, var(--color-gold) 42%, var(--color-line));
  background: color-mix(in srgb, var(--color-soft-gold) 15%, white);
  color: var(--color-forest);
}

.results-summary h1 {
  max-width: 13ch;
  color: var(--color-forest);
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 5vw, 4.2rem);
  font-weight: 700;
  line-height: 0.98;
}

.results-summary p {
  color: var(--color-text-muted);
  font-size: 1.02rem;
  line-height: 1.55;
}

.results-summary .ghost-button,
.results-summary .theme-pill {
  color: var(--color-forest);
}

.results-summary .confidence {
  border-color: color-mix(in srgb, var(--color-line) 78%, transparent);
  background: rgba(255, 253, 250, 0.84);
  box-shadow: 0 14px 34px rgba(61, 43, 28, 0.08);
}

.results-summary .confidence-copy,
.results-summary .confidence-copy strong,
.results-summary .eyebrow {
  color: var(--color-forest);
}

.results-summary .confidence-copy span:last-child {
  color: var(--color-text-muted);
}

.summary-tools {
  align-items: stretch;
}

.summary-tools > .ghost-button {
  min-height: 48px;
  border-color: color-mix(in srgb, var(--color-sage) 36%, var(--color-line));
  background: rgba(255, 253, 250, 0.8);
}

.provider-filter,
.fund-selector,
.data-scope-note {
  width: min(760px, 100%);
  border-color: color-mix(in srgb, var(--color-line) 86%, transparent);
  background: rgba(255, 253, 250, 0.78);
}

.data-scope-note strong,
.data-scope-note span,
.fund-selector strong,
.fund-selector span,
.provider-filter strong,
.provider-filter span {
  color: var(--color-text);
}

.data-scope-note span,
.fund-selector span,
.provider-filter span {
  color: var(--color-text-muted);
}

.fund-selector p {
  color: var(--color-text-muted);
}

.shortlist-panel,
.promotion-panel,
.unlock-panel,
.clarification-panel {
  border-color: color-mix(in srgb, var(--color-line) 88%, transparent);
  background:
    linear-gradient(180deg, rgba(255, 253, 250, 0.98), rgba(255, 250, 240, 0.93)),
    var(--color-surface-raised);
}

.shortlist-panel {
  padding: var(--space-5);
}

.shortlist-header {
  padding-bottom: var(--space-3);
  border-bottom: 1px solid color-mix(in srgb, var(--color-line) 76%, transparent);
}

.shortlist-header h2,
.promotion-panel h2,
.unlock-panel h2,
.clarification-panel h2 {
  color: var(--color-forest);
  font-family: var(--font-display);
  font-weight: 700;
}

.result-card {
  grid-template-columns: 44px minmax(0, 1fr);
  gap: var(--space-4);
  padding: var(--space-5);
  border-color: color-mix(in srgb, var(--color-line) 86%, transparent);
  background:
    linear-gradient(135deg, rgba(255, 253, 250, 0.99), rgba(255, 250, 240, 0.92)),
    var(--color-surface-raised);
  box-shadow: 0 18px 46px rgba(61, 43, 28, 0.09);
}

.result-card::before,
.empty-card::before {
  width: 3px;
  background: linear-gradient(180deg, var(--color-sage), var(--color-gold), var(--color-clay));
}

.result-card::after {
  content: "";
  position: absolute;
  right: 18px;
  top: 18px;
  width: 36px;
  height: 18px;
  border-radius: 100% 0 100% 0;
  background: linear-gradient(135deg, rgba(197, 143, 53, 0.28), rgba(112, 131, 95, 0.18));
  transform: rotate(-22deg);
  pointer-events: none;
}

.result-card-body {
  min-width: 0;
}

.result-rank {
  width: 38px;
  height: 38px;
  border: 1px solid color-mix(in srgb, var(--color-sage) 36%, transparent);
  background: color-mix(in srgb, var(--color-surface-selected) 82%, white);
  color: var(--color-forest);
  box-shadow: none;
}

.fund-name {
  color: var(--color-gold);
  font-size: 0.76rem;
  letter-spacing: 0;
  text-transform: uppercase;
}

.result-card h2 {
  max-width: 24ch;
  color: var(--color-forest);
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 2.3vw, 1.75rem);
}

.result-subline {
  color: var(--color-text-muted);
}

.result-meta span,
.tag-row span {
  background: rgba(241, 234, 220, 0.68);
}

.result-glance div {
  background: rgba(255, 253, 250, 0.72);
}

.result-card ul {
  color: var(--color-text);
}

.result-signal-strip {
  grid-template-columns: minmax(0, 1fr) max-content;
}

.result-signal-main,
.result-signal-watch {
  padding: 12px;
  background: rgba(232, 237, 220, 0.74);
}

.result-signal-watch {
  background: linear-gradient(180deg, rgba(255, 241, 214, 0.95), rgba(255, 253, 250, 0.82));
}

.result-actions {
  padding-top: var(--space-1);
}

.result-action-primary {
  border-color: color-mix(in srgb, var(--color-forest) 55%, var(--color-line));
  background: linear-gradient(135deg, #284a34, #203d2b);
  color: var(--color-on-brand);
}

.result-action-primary:hover,
.result-action-primary:focus-visible {
  background: linear-gradient(135deg, #315b40, #263f2e);
  color: var(--color-on-brand);
}

.result-card-compared {
  border-color: color-mix(in srgb, var(--color-gold) 66%, var(--color-line));
  background:
    linear-gradient(135deg, rgba(255, 253, 250, 0.99), rgba(225, 236, 212, 0.56)),
    var(--color-surface-selected);
}

.compare-selected {
  border-color: color-mix(in srgb, var(--color-gold) 68%, var(--color-line));
  background: color-mix(in srgb, var(--color-surface-selected) 76%, white);
  color: var(--color-forest);
}

.compare-panel {
  border-color: color-mix(in srgb, var(--color-gold) 30%, var(--color-line));
  background:
    linear-gradient(180deg, rgba(255, 253, 250, 0.98), rgba(243, 234, 215, 0.72)),
    var(--color-surface-compare);
  box-shadow: 0 18px 46px rgba(61, 43, 28, 0.1);
}

.compare-header h2 {
  color: var(--color-forest);
  font-family: var(--font-display);
}

.detail-panel {
  border-color: color-mix(in srgb, var(--color-gold) 30%, var(--color-line));
  background:
    linear-gradient(180deg, rgba(255, 253, 250, 0.99), rgba(255, 250, 240, 0.96)),
    var(--color-surface);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82), 0 18px 42px rgba(61, 43, 28, 0.08);
}

.detail-heading {
  background:
    linear-gradient(180deg, rgba(255, 253, 250, 0.98), rgba(255, 250, 240, 0.96)),
    var(--color-surface);
}

.detail-heading h2,
.detail-section h3 {
  color: var(--color-forest);
  font-family: var(--font-display);
}

.detail-section h3 {
  font-size: 1.08rem;
}

.detail-list li {
  background: rgba(255, 253, 250, 0.78);
}

.detail-section-watch .detail-list li {
  border-color: color-mix(in srgb, var(--color-gold) 35%, var(--color-line));
  background: linear-gradient(180deg, rgba(255, 241, 214, 0.96), rgba(255, 250, 240, 0.9));
}

.unlock-panel {
  position: relative;
  overflow: hidden;
}

.unlock-panel::after {
  content: "";
  position: absolute;
  right: -28px;
  bottom: -52px;
  width: 190px;
  aspect-ratio: 650 / 742;
  background: url("../assets/brand-tree.png") center / contain no-repeat;
  opacity: 0.1;
  pointer-events: none;
}

.unlock-panel {
  grid-template-columns: 1fr minmax(260px, 380px);
  align-items: center;
  border: 1px solid color-mix(in srgb, var(--color-sage) 24%, var(--color-line));
  background:
    linear-gradient(135deg, rgba(255, 253, 250, 0.98), rgba(237, 243, 234, 0.96)),
    var(--color-surface-raised);
  color: var(--color-text);
}

.unlock-panel .badge {
  border-color: color-mix(in srgb, var(--color-gold) 46%, var(--color-line));
  color: var(--color-forest);
  background: var(--color-surface-selected);
}

.unlock-panel p {
  color: var(--color-text-muted);
}

.email-form {
  display: grid;
  gap: 10px;
}

.account-signin-actions {
  display: grid;
  gap: 10px;
}

.contact-consent {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  padding: 10px 12px;
  border: 1px solid color-mix(in srgb, var(--color-gold) 42%, var(--color-line));
  border-radius: var(--radius-md);
  background: rgba(255, 253, 248, 0.78);
  color: var(--color-text);
  font-weight: 780;
  line-height: 1.3;
}

.contact-consent input {
  width: 18px;
  height: 18px;
  margin-top: 1px;
  accent-color: var(--color-forest);
}

.google-signin-button,
.apple-signin-button {
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border: 1px solid color-mix(in srgb, var(--color-gold) 62%, var(--color-line));
  border-radius: var(--radius-md);
  background:
    linear-gradient(180deg, rgba(255, 250, 240, 0.98), rgba(247, 241, 228, 0.94)),
    var(--color-surface-raised);
  color: var(--color-forest);
  font-weight: 850;
  box-shadow: 0 8px 18px rgba(62, 46, 30, 0.045);
  transition: border-color 160ms ease, transform 160ms ease, background 160ms ease, box-shadow 160ms ease;
}

.google-signin-button:hover,
.google-signin-button:focus-visible,
.apple-signin-button:hover,
.apple-signin-button:focus-visible {
  border-color: color-mix(in srgb, var(--color-gold) 72%, var(--color-clay));
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(62, 46, 30, 0.09);
}

.google-mark,
.apple-mark {
  width: 24px;
  height: 24px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: var(--color-surface-raised);
  border: 1px solid var(--color-line);
  color: var(--color-action-blue);
  font-weight: 900;
  font-family: Arial, sans-serif;
}

.apple-mark {
  color: var(--color-forest);
}

.email-form label {
  display: grid;
  gap: 6px;
  color: var(--color-text-muted);
  font-weight: 730;
}

.email-link-recovery {
  display: grid;
  gap: 8px;
}

.email-link-recovery details {
  border-top: 1px solid color-mix(in srgb, var(--color-gold) 40%, var(--color-line));
  padding-top: 8px;
}

.email-link-recovery summary {
  cursor: pointer;
  color: var(--color-text-muted);
  font-size: 0.9rem;
  font-weight: 780;
}

.email-link-recovery label {
  display: grid;
  gap: 6px;
  margin-top: 10px;
  color: var(--color-text-muted);
  font-weight: 730;
}

.email-link-recovery textarea {
  min-height: 84px;
  resize: vertical;
}

.email-link-recovery .ghost-button {
  justify-self: start;
  margin-top: 8px;
}

.saved-note {
  display: grid;
  gap: 6px;
  padding: var(--space-3);
  border-radius: var(--radius-md);
  background: var(--color-surface-selected);
  color: var(--color-brand-navy);
}

.saved-note .ghost-button {
  justify-self: start;
  min-height: 36px;
  padding: 7px 10px;
}

.account-menu-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.saved-link-box {
  display: grid;
  gap: 7px;
  padding: 10px;
  border: 1px solid color-mix(in srgb, var(--color-gold) 42%, var(--color-line));
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-surface-raised) 72%, var(--color-cream));
}

.saved-link-box input,
.account-action-card input,
.account-action-card textarea {
  width: 100%;
  min-height: 42px;
  border: 1px solid color-mix(in srgb, var(--color-gold) 50%, var(--color-line));
  border-radius: var(--radius-md);
  background: var(--color-surface-raised);
  color: var(--color-text);
  padding: 9px 11px;
  font: inherit;
}

.account-action-card {
  max-width: 680px;
  padding: 24px;
  border: 1px solid color-mix(in srgb, var(--color-gold) 46%, var(--color-line));
  border-radius: var(--radius-lg);
  background: var(--color-surface);
}

.account-action-card form {
  display: grid;
  gap: 12px;
}

.account-action-card label {
  display: grid;
  gap: 6px;
  font-weight: 760;
  color: var(--color-text-muted);
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.static-page {
  position: relative;
  isolation: isolate;
  min-height: 100vh;
  overflow-x: hidden;
  background:
    var(--workflow-bg-overlay),
    var(--workflow-bg-image) var(--workflow-bg-position) / cover no-repeat,
    var(--color-page);
  background-attachment: fixed;
  color: var(--color-text);
}

.static-page::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(255, 253, 250, 0.9), rgba(255, 253, 250, 0.7) 42%, rgba(255, 253, 250, 0.92)),
    linear-gradient(180deg, rgba(255, 253, 250, 0.16), rgba(255, 250, 240, 0.72));
}

.static-shell {
  position: relative;
  z-index: 1;
  width: min(920px, calc(100% - 32px));
  margin: 0 auto;
  padding: 32px 0 64px;
}

.home-link {
  display: inline-flex;
  margin-bottom: 24px;
}

.static-hero,
.static-section {
  display: grid;
  gap: 12px;
  margin-bottom: 18px;
  padding: 24px;
  border: 1px solid color-mix(in srgb, var(--color-line) 82%, transparent);
  border-radius: var(--radius-lg);
  background: rgba(255, 253, 250, 0.82);
  box-shadow: 0 14px 34px rgba(61, 43, 28, 0.08);
  backdrop-filter: blur(10px);
}

.static-hero h1,
.static-section h2 {
  margin: 0;
  color: var(--color-forest);
  font-family: var(--font-display);
  letter-spacing: 0;
}

.static-hero h1 {
  max-width: 14ch;
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  line-height: 1;
}

.static-section h2 {
  font-size: 1.4rem;
}

.static-hero p,
.static-section p {
  max-width: 72ch;
  margin: 0;
  color: var(--color-text-muted);
  line-height: 1.58;
}

.rebate-estimate {
  display: grid;
  gap: 2px;
  margin-top: 6px;
  padding-top: 6px;
  border-top: 1px solid color-mix(in srgb, var(--color-line) 68%, transparent);
}

.rebate-estimate span,
.rebate-estimate small {
  color: var(--color-text-muted);
}

.rebate-estimate strong {
  font-size: 0.98rem;
}

.rebate-edit-button {
  margin-top: 6px;
}

.rebate-intake-prompt,
.rebate-notice {
  display: grid;
  gap: 8px;
  margin-top: var(--space-3);
  padding: var(--space-3);
  border: 1px solid color-mix(in srgb, var(--color-action-blue) 24%, var(--color-line));
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-action-blue) 8%, var(--color-surface));
}

.rebate-intake-prompt p,
.rebate-notice p {
  margin: 0;
  color: var(--color-text-muted);
}

.rebate-sheet {
  max-width: 860px;
  margin-inline: auto;
}

.rebate-form {
  display: grid;
  gap: var(--space-4);
  margin-top: var(--space-4);
}

.rebate-fieldset {
  display: grid;
  gap: 10px;
  min-width: 0;
  padding: 0;
  border: 0;
}

.rebate-fieldset legend {
  font-weight: 850;
}

.rebate-option-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 8px;
}

.rebate-option-grid label {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 44px;
  padding: 9px 11px;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  font-weight: 750;
}

.rebate-option-grid label.selected {
  border-color: color-mix(in srgb, var(--color-action-blue) 52%, var(--color-line));
  background: color-mix(in srgb, var(--color-action-blue) 10%, var(--color-surface));
}

.premium-results-page {
  position: relative;
  padding: 0;
  gap: 0;
  overflow: hidden;
  background:
    var(--workflow-bg-image) center center / cover no-repeat,
    var(--color-page);
  background-attachment: fixed;
}

.premium-results-page::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(255, 253, 250, 0.5), rgba(255, 253, 250, 0.28) 46%, rgba(255, 253, 250, 0.5)),
    linear-gradient(180deg, rgba(255, 253, 250, 0.16), rgba(255, 250, 240, 0.38));
}

.premium-results-page > * {
  position: relative;
  z-index: 1;
}

.premium-results-header {
  position: sticky;
  top: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  min-height: 72px;
  padding: 10px clamp(16px, 3vw, 28px);
  border-bottom: 1px solid color-mix(in srgb, var(--color-line) 78%, white);
  background: rgba(255, 253, 250, 0.94);
  backdrop-filter: blur(16px);
  box-shadow: 0 10px 28px rgba(61, 43, 28, 0.06);
}

.premium-brand-lockup,
.premium-header-actions,
.premium-account-button,
.premium-header-pill,
.premium-save-button {
  display: flex;
  align-items: center;
}

.premium-brand-lockup {
  gap: 12px;
}

.premium-brand-mark,
.premium-account-button span:first-child {
  display: grid;
  place-items: center;
  color: var(--color-on-brand);
  background: linear-gradient(145deg, var(--color-forest), #173322);
  box-shadow: inset 0 0 0 1px rgba(255, 253, 250, 0.16);
}

.premium-brand-mark {
  width: 48px;
  height: 48px;
  border-radius: 8px;
  font-family: var(--font-display);
  font-size: 1.04rem;
  font-weight: 900;
}

.premium-brand-lockup strong {
  display: block;
  font-family: var(--font-display);
  color: var(--color-forest);
  font-size: 1.3rem;
  line-height: 1.05;
}

.premium-brand-lockup small {
  display: block;
  margin-top: 1px;
  color: var(--color-gold);
  font-weight: 850;
}

.premium-header-actions {
  justify-content: flex-end;
  gap: 14px;
}

.premium-header-pill,
.premium-save-button,
.premium-account-button {
  min-height: 40px;
  padding: 8px 14px;
  border: 1px solid color-mix(in srgb, var(--color-line) 82%, white);
  border-radius: 8px;
  background: rgba(255, 253, 250, 0.92);
  color: var(--color-text);
  font: inherit;
  font-weight: 850;
  box-shadow: 0 8px 18px rgba(61, 43, 28, 0.05);
}

.premium-header-pill {
  gap: 9px;
}

.premium-header-pill span {
  display: grid;
  place-items: center;
  width: 18px;
  height: 18px;
  border-radius: 99px;
  color: white;
  background: var(--color-forest);
  font-size: 0.72rem;
}

.premium-save-button,
.premium-account-button {
  cursor: pointer;
}

.premium-save-button {
  gap: 9px;
}

.premium-account-button {
  gap: 10px;
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}

.premium-account-button span:first-child {
  width: 36px;
  height: 36px;
  border-radius: 999px;
}

.premium-results-content {
  position: relative;
  width: min(1440px, calc(100% - 48px));
  margin: 0 auto;
  padding: 26px 0 64px;
}

.premium-results-content::after {
  content: none;
}

.premium-summary-panel,
.premium-results-layout,
.premium-results-content > .unlock-panel,
.premium-results-content > .clarification-panel,
.premium-results-content > .results-side-window,
.premium-results-content > .reset-row {
  position: relative;
  z-index: 1;
}

.premium-summary-panel {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(250px, 0.58fr) minmax(270px, 0.54fr);
  gap: 34px;
  align-items: center;
  min-height: 138px;
  padding: 28px 42px;
  border: 1px solid color-mix(in srgb, var(--color-line) 74%, white);
  border-radius: 10px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(255, 253, 248, 0.98));
  box-shadow: 0 18px 48px rgba(61, 43, 28, 0.08);
}

.premium-summary-copy,
.premium-summary-confidence,
.premium-summary-action {
  min-width: 0;
}

.premium-summary-copy h1 {
  max-width: none;
  color: var(--color-forest);
  font-size: clamp(2rem, 2.6vw, 2.8rem);
  line-height: 1.04;
}

.premium-summary-copy p {
  max-width: 68ch;
  margin-top: 10px;
  color: var(--color-text-muted);
  line-height: 1.55;
}

.premium-summary-confidence,
.premium-summary-action {
  display: grid;
  gap: 7px;
  padding-left: 30px;
  border-left: 1px solid color-mix(in srgb, var(--color-line) 70%, white);
}

.premium-summary-confidence > span,
.premium-summary-action > span {
  color: var(--color-text);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.premium-summary-confidence strong {
  color: var(--color-forest);
  font-family: var(--font-display);
  font-size: 1.7rem;
  line-height: 1.1;
}

.premium-summary-action strong {
  color: var(--color-text);
  font-size: 1rem;
}

.premium-confidence-track {
  overflow: hidden;
  height: 7px;
  border-radius: 99px;
  background: color-mix(in srgb, var(--color-soft-gold) 38%, var(--color-surface-inset));
}

.premium-confidence-track span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--color-forest), var(--color-positive));
}

.premium-summary-confidence small {
  color: var(--color-forest);
  font-weight: 650;
}

.premium-compare-selected {
  width: 100%;
  min-height: 44px;
  margin-top: 4px;
}

.premium-results-layout {
  display: grid;
  grid-template-columns: minmax(270px, 314px) minmax(0, 1fr);
  gap: 32px;
  align-items: start;
  margin-top: 26px;
}

.premium-sidebar-stack {
  position: sticky;
  top: 94px;
  display: grid;
  gap: 10px;
  align-self: start;
}

.premium-back-button {
  min-height: 48px;
  border: 1px solid var(--color-line);
  border-radius: 8px;
  background: var(--color-surface-raised);
  color: var(--color-forest);
  font: inherit;
  font-weight: 900;
  cursor: pointer;
}

.premium-filter-sidebar,
.premium-data-card,
.premium-sidebar-stack .fund-selector {
  border: 1px solid color-mix(in srgb, var(--color-line) 82%, white);
  border-radius: 10px;
  background: rgba(255, 254, 251, 0.96);
  box-shadow: 0 14px 32px rgba(61, 43, 28, 0.06);
}

.premium-filter-sidebar {
  display: grid;
  gap: 18px;
  padding: 18px;
}

.premium-filter-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.premium-filter-heading h2 {
  color: var(--color-forest);
  font-family: var(--font-display);
  font-size: 1.22rem;
}

.premium-filter-group {
  display: grid;
  gap: 12px;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--color-line) 76%, white);
  border-radius: 9px;
  background: color-mix(in srgb, var(--color-surface-inset) 62%, white);
}

.premium-filter-group h3 {
  margin: 0;
  color: var(--color-forest);
  font-family: var(--font-sans);
  font-size: 0.96rem;
  font-weight: 950;
}

.premium-filter-group p {
  margin: 3px 0 0;
  color: var(--color-text-muted);
  font-size: 0.78rem;
  line-height: 1.32;
}

.premium-filter-heading button,
.premium-filter-note button,
.premium-filter-note a,
.premium-summary-link {
  border: 0;
  background: transparent;
  color: var(--color-forest);
  font: inherit;
  font-weight: 800;
  text-decoration: underline;
  cursor: pointer;
}

.premium-filter-field {
  display: grid;
  gap: 8px;
  min-width: 0;
  margin: 0;
  padding: 0;
  border: 0;
}

.premium-filter-field > span,
.premium-filter-field legend {
  color: var(--color-text);
  font-size: 0.9rem;
  font-weight: 900;
}

.premium-filter-field select,
.premium-filter-field input[type="range"] {
  width: 100%;
}

.premium-filter-field select {
  min-height: 40px;
  padding: 8px 12px;
  border: 1px solid var(--color-line);
  border-radius: 6px;
  background: var(--color-surface-raised);
  color: var(--color-text);
  font: inherit;
}

.premium-provider-pool-field,
.premium-provider-fund-field,
.premium-sidebar-select-field {
  position: relative;
}

.premium-provider-pool-field .fund-selector-menu,
.premium-provider-fund-field .fund-selector-menu,
.premium-sidebar-select-field .fund-selector-menu {
  flex: none;
  width: 100%;
}

.premium-provider-pool-field .fund-selector-menu summary,
.premium-provider-fund-field .fund-selector-menu summary,
.premium-sidebar-select-field .fund-selector-menu summary {
  min-height: 40px;
  border-color: var(--color-line);
  border-radius: 6px;
  background: var(--color-surface-raised);
  font-weight: 400;
}

.premium-provider-pool-field .fund-selector-menu summary > span,
.premium-provider-fund-field .fund-selector-menu summary > span,
.premium-sidebar-select-field .fund-selector-menu summary > span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.premium-provider-pool-field .fund-selector-popover,
.premium-provider-fund-field .fund-selector-popover,
.premium-sidebar-select-field .fund-selector-popover {
  right: 0;
  left: 0;
}

.provider-pool-popover,
.sidebar-select-popover {
  display: grid;
  padding: 4px;
}

.premium-provider-fund-field > p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.76rem;
  line-height: 1.3;
}

.premium-filter-field input[type="range"] {
  accent-color: var(--color-gold);
}

.premium-filter-field strong {
  color: var(--color-text);
  font-size: 0.92rem;
}

.range-labels {
  display: flex;
  justify-content: space-between;
  color: var(--color-text-muted);
  font-weight: 700;
}

.premium-checkbox-field label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  min-height: 32px;
  padding: 6px 7px;
  border: 1px solid color-mix(in srgb, var(--color-line) 86%, white);
  border-radius: 999px;
  background: rgba(255, 253, 250, 0.92);
  color: var(--color-text);
  font-size: clamp(0.68rem, 0.72vw, 0.8rem);
  font-weight: 760;
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
  transition: background 150ms ease, border-color 150ms ease, color 150ms ease, box-shadow 150ms ease;
}

.premium-checkbox-field {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 7px;
  align-items: start;
}

.premium-checkbox-field input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.premium-checkbox-field label:has(input:checked) {
  border-color: color-mix(in srgb, var(--color-forest) 78%, var(--color-line));
  background: linear-gradient(145deg, var(--color-forest), #173322);
  color: white;
  box-shadow: 0 8px 18px rgba(22, 61, 43, 0.16);
}

.premium-checkbox-field label:has(input:focus-visible) {
  outline: 3px solid color-mix(in srgb, var(--color-gold) 34%, transparent);
  outline-offset: 2px;
}

.premium-filter-note {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 10px;
  align-items: start;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--color-sage) 28%, var(--color-line));
  border-radius: 8px;
  background: color-mix(in srgb, var(--color-sage) 8%, var(--color-surface-raised));
}

.premium-filter-note span {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border: 1px solid color-mix(in srgb, var(--color-forest) 42%, var(--color-line));
  border-radius: 999px;
  color: var(--color-forest);
}

.premium-filter-note p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.9rem;
}

.premium-sidebar-stack .fund-selector {
  grid-template-columns: 1fr;
  padding: 14px;
  gap: 10px;
}

.premium-sidebar-stack .fund-selector-menu {
  width: 100%;
}

.premium-data-card {
  padding: 14px;
}

.premium-data-card .data-scope-note {
  box-shadow: none;
  border: 0;
  background: transparent;
  padding: 0;
}

.premium-results-list {
  display: grid;
  gap: 14px;
  min-width: 0;
}

.premium-list-header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 18px;
  padding: 0 2px 4px;
}

.premium-list-header span {
  color: var(--color-gold);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.premium-list-header h2 {
  color: var(--color-forest);
  font-size: 1.45rem;
}

.premium-list-header p {
  color: var(--color-text-muted);
}

.premium-list-header strong {
  flex: 0 0 auto;
  padding: 7px 12px;
  border: 1px solid var(--color-line);
  border-radius: 8px;
  background: var(--color-surface-raised);
  color: var(--color-forest);
}

.premium-results-grid {
  display: grid;
  gap: 14px;
}

.premium-result-card {
  position: relative;
  display: block;
  grid-template-columns: none;
  gap: 0;
  overflow: hidden;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--color-line) 74%, white);
  border-radius: 12px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 253, 248, 0.99));
  box-shadow: 0 12px 30px rgba(61, 43, 28, 0.06);
  transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.premium-result-card:first-child {
  border-color: color-mix(in srgb, var(--color-gold) 42%, var(--color-line));
  box-shadow: 0 18px 40px rgba(61, 43, 28, 0.09);
}

.premium-result-card:hover {
  border-color: color-mix(in srgb, var(--color-gold) 40%, var(--color-line));
  box-shadow: 0 20px 42px rgba(61, 43, 28, 0.105);
  transform: translateY(-1px);
}

.premium-result-card::before,
.premium-result-card::after {
  content: none;
}

.best-match-ribbon {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  width: 128px;
  height: 26px;
  padding: 0 28px 0 14px;
  color: #fffaf0;
  background: #b88932;
  clip-path: path("M 0 0 H 128 C 119 3 116 18 101 26 H 0 Z");
  font-size: 0.72rem;
  font-weight: 880;
  letter-spacing: 0.055em;
  line-height: 1;
  text-transform: uppercase;
}

.premium-card-grid {
  display: grid;
  grid-template-columns:
    minmax(148px, 0.92fr)
    minmax(188px, 1.14fr)
    minmax(128px, 0.76fr)
    minmax(232px, 1.34fr)
    minmax(190px, 1.02fr)
    minmax(142px, 0.82fr);
  align-items: stretch;
  min-height: 148px;
}

.premium-card-grid > * {
  min-width: 0;
  padding: clamp(16px, 1.18vw, 20px);
  border-left: 1px solid color-mix(in srgb, var(--color-line) 44%, transparent);
}

.premium-card-grid > *:first-child {
  border-left: 0;
}

.premium-fund-block,
.premium-score-block,
.premium-card-actions {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 12px;
}

.premium-fund-mark {
  position: relative;
  display: grid;
  place-items: center;
  width: 140px;
  max-width: 100%;
  min-height: 68px;
  padding: 10px 12px;
  border-radius: 10px;
  color: var(--color-forest);
  background: color-mix(in srgb, var(--color-sage) 9%, white);
  font-family: var(--font-display);
  font-size: 1.72rem;
  font-weight: 950;
  text-align: center;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-line) 55%, transparent);
}

.premium-fund-mark-logo {
  background: rgba(255, 255, 255, 0.9);
}

.premium-fund-mark-logo img {
  display: block;
  width: 100%;
  max-width: 122px;
  max-height: 56px;
  object-fit: contain;
}

.premium-fund-mark-logo > span {
  display: none;
}

.premium-fund-mark-logo.logo-failed > span {
  display: block;
}

.premium-fund-block span {
  max-width: 150px;
  color: var(--color-text-muted);
  font-size: 0.82rem;
  font-weight: 850;
  text-align: center;
}

.premium-fund-block .result-promotion {
  max-width: 142px;
  color: #8a641d;
  font-size: 0.68rem;
  font-weight: 920;
}

.premium-plan-block {
  display: grid;
  align-content: center;
  gap: 7px;
}

.premium-plan-block h2 {
  color: var(--color-text);
  font-family: var(--font-sans);
  font-size: clamp(1rem, 0.98vw, 1.14rem);
  line-height: 1.28;
}

.cover-tier-badge {
  width: fit-content;
  padding: 5px 9px;
  border-radius: 7px;
  background: color-mix(in srgb, var(--color-soft-gold) 30%, var(--color-surface-raised));
  color: #8a641d;
  font-size: 0.78rem;
  font-weight: 850;
}

.premium-card-price {
  display: block;
  color: var(--color-text);
}

.premium-card-price strong {
  font-family: var(--font-display);
  font-size: 1.44rem;
}

.premium-card-price span:not(.sr-only) {
  margin-left: 3px;
  color: var(--color-text-muted);
  font-size: 0.78rem;
}

.premium-card-price small {
  display: block;
  margin-top: 4px;
  color: var(--color-text-muted);
}

.premium-rebate-link {
  margin-top: 5px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--color-forest);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 850;
  text-align: left;
  cursor: pointer;
}

.premium-feature-chips {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 4px;
  margin-top: 0;
}

.premium-feature-chip,
.premium-highlight-link {
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  cursor: pointer;
}

.premium-feature-chip {
  max-width: 100%;
  padding: 4px 8px;
  border: 1px solid color-mix(in srgb, var(--color-gold) 42%, var(--color-line));
  border-radius: 7px;
  background: color-mix(in srgb, var(--color-soft-gold) 16%, var(--color-surface-raised));
  color: var(--color-forest);
  font-size: 0.66rem;
  line-height: 1.1;
  font-weight: 850;
  text-align: center;
}

.premium-score-ring {
  position: relative;
  display: grid;
  place-items: center;
  width: 78px;
  height: 78px;
  border-radius: 999px;
  background:
    radial-gradient(circle at center, var(--color-surface-raised) 58%, transparent 60%),
    conic-gradient(var(--color-positive) calc(var(--score) * 1%), color-mix(in srgb, var(--color-line) 70%, white) 0);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-line) 42%, transparent);
}

.premium-score-ring strong {
  color: var(--color-forest);
  font-family: var(--font-display);
  font-size: 1.18rem;
}

.premium-score-block > span {
  color: var(--color-text-muted);
  font-size: 0.78rem;
  font-weight: 750;
}

.premium-why-block,
.premium-highlights-block {
  display: grid;
  align-content: center;
  gap: 9px;
}

.premium-why-block h3,
.premium-highlights-block h3 {
  color: var(--color-text);
  font-family: var(--font-sans);
  font-size: 0.92rem;
  line-height: 1.22;
}

.premium-why-block h3::before {
  content: "\2726";
  margin-right: 6px;
  color: var(--color-gold);
}

.premium-why-block p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.88rem;
  line-height: 1.45;
}

.premium-watch-count {
  width: fit-content;
  padding: 5px 9px;
  border-radius: 7px;
  background: color-mix(in srgb, var(--color-soft-gold) 28%, var(--color-surface-raised));
  color: #8a641d;
  font-size: 0.76rem;
  font-weight: 900;
  text-transform: uppercase;
}

.premium-why-block ul,
.premium-highlights-block ul {
  display: grid;
  gap: 7px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.premium-why-block li,
.premium-highlights-block li {
  position: relative;
  padding-left: 22px;
  color: var(--color-text);
  font-size: 0.85rem;
  line-height: 1.36;
}

.premium-why-block li::before,
.premium-highlights-block li::before {
  position: absolute;
  left: 0;
  top: 0.08rem;
  display: grid;
  place-items: center;
  width: 15px;
  height: 15px;
  border-radius: 999px;
  background: var(--color-forest);
  content: "\2713";
  color: white;
  font-size: 0.56rem;
  font-weight: 900;
}

.premium-highlights-block li::before {
  content: none;
}

.premium-highlights-block li {
  display: block;
  min-height: 28px;
  padding: 0 0 7px;
  border-bottom: 1px dashed color-mix(in srgb, var(--color-line) 68%, white);
}

.premium-summary-link {
  width: fit-content;
  padding: 0;
  font-size: 0.84rem;
}

.premium-why-link {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  padding: 4px 8px;
  border: 0;
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-soft-gold) 18%, var(--color-surface-raised));
  color: var(--color-text);
  text-align: left;
  font: 820 0.78rem/1.18 var(--font-sans);
  text-decoration: none;
}

.premium-why-link:hover,
.premium-why-link:focus-visible {
  background: color-mix(in srgb, var(--color-soft-gold) 28%, var(--color-surface-raised));
  color: var(--color-forest);
  text-decoration: none;
}

.premium-highlight-link {
  display: inline-grid;
  grid-template-columns: 24px minmax(0, 1fr);
  align-items: center;
  column-gap: 8px;
  width: fit-content;
  max-width: 100%;
  padding: 2px 6px 2px 0;
  border-radius: 8px;
  background: transparent;
  color: var(--color-text);
  text-align: left;
  font-size: 0.78rem;
  line-height: 1.2;
  font-weight: 820;
  text-decoration: none;
}

.premium-highlight-link span {
  display: grid;
  gap: 2px;
}

.premium-highlight-link strong {
  color: var(--color-text);
  font-size: 0.79rem;
  font-weight: 900;
}

.premium-highlight-link small {
  color: var(--color-text-muted);
  font-size: 0.62rem;
  font-weight: 650;
  line-height: 1.16;
}

.premium-highlight-icon-holder {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border: 1px solid color-mix(in srgb, var(--color-line) 70%, white);
  border-radius: 7px;
  background: color-mix(in srgb, var(--color-surface-inset) 62%, white);
  color: var(--color-forest);
}

.premium-highlight-icon {
  width: 14px;
  height: 14px;
  margin-top: 0;
  color: currentColor;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.premium-feature-chip:hover,
.premium-feature-chip:focus-visible,
.premium-highlight-link:hover,
.premium-highlight-link:focus-visible,
.premium-summary-link:hover,
.premium-summary-link:focus-visible,
.premium-rebate-link:hover,
.premium-rebate-link:focus-visible {
  color: var(--color-forest);
  text-decoration: underline;
}

.premium-card-actions {
  justify-items: stretch;
  align-content: center;
}

.premium-compare-check {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--color-text);
  font-size: 0.88rem;
  font-weight: 750;
}

.premium-compare-check input {
  width: 18px;
  height: 18px;
  accent-color: var(--color-forest);
}

.premium-detail-button,
.apply-now-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  width: 100%;
  padding: 9px 14px;
  border-radius: 8px;
  font: inherit;
  font-weight: 900;
  text-decoration: none;
  cursor: pointer;
}

.premium-detail-button {
  border: 1px solid transparent;
  color: var(--color-on-brand);
  background: linear-gradient(145deg, var(--color-forest), #173322);
  box-shadow: inset 0 0 0 1px rgba(255, 253, 250, 0.1);
}

.apply-now-button {
  border: 1px solid var(--color-gold);
  color: #8a641d;
  background: rgba(255, 253, 250, 0.9);
}

.premium-card-detail {
  position: relative;
  z-index: 4;
  padding: 0 18px 18px;
  background: rgba(255, 253, 250, 0.98);
  border-radius: 0 0 10px 10px;
}

.premium-card-detail:empty {
  display: none;
}

.premium-card-detail .detail-panel {
  position: relative;
  z-index: 5;
}

.premium-card-detail .detail-content,
.premium-card-detail .plan-detail {
  max-height: min(72vh, 760px);
  overflow: auto;
  border: 1px solid color-mix(in srgb, var(--color-gold) 42%, var(--color-line));
  border-radius: 8px;
  background: rgba(255, 253, 250, 0.99);
  box-shadow: 0 18px 34px rgba(61, 43, 28, 0.12);
}

.premium-card-detail .detail-unlock {
  margin-top: 0;
}

.premium-results-list .compare-panel {
  position: static;
  max-height: none;
  margin-top: 8px;
}

@media (max-width: 1240px) {
  .premium-results-content {
    width: min(100% - 32px, 1180px);
  }

  .premium-card-grid {
    grid-template-columns: minmax(118px, 0.8fr) minmax(180px, 1.2fr) minmax(104px, 0.62fr) minmax(210px, 1.3fr);
  }

  .premium-highlights-block,
  .premium-card-actions {
    border-top: 1px solid color-mix(in srgb, var(--color-line) 70%, white);
  }
}

@media (max-width: 1040px) {
  .premium-summary-panel,
  .premium-results-layout {
    grid-template-columns: 1fr;
  }

  .premium-summary-confidence,
  .premium-summary-action {
    padding-left: 0;
    border-left: 0;
    padding-top: 18px;
    border-top: 1px solid color-mix(in srgb, var(--color-line) 70%, white);
  }

  .premium-sidebar-stack {
    position: static;
  }

  .premium-filter-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .premium-filter-heading,
  .premium-filter-note {
    grid-column: 1 / -1;
  }
}

@media (max-width: 780px) {
  .premium-results-header,
  .premium-header-actions,
  .premium-list-header {
    align-items: stretch;
    flex-direction: column;
  }

  .premium-header-actions {
    width: 100%;
  }

  .premium-header-pill,
  .premium-save-button,
  .premium-account-button {
    justify-content: center;
    width: 100%;
  }

  .premium-results-content {
    width: min(100% - 20px, 680px);
    padding-top: 12px;
  }

  .premium-summary-panel {
    padding: 22px;
  }

  .premium-filter-sidebar,
  .premium-card-grid {
    grid-template-columns: 1fr;
  }

  .premium-card-grid > * {
    border-left: 0;
    border-top: 1px solid color-mix(in srgb, var(--color-line) 70%, white);
  }

  .premium-card-grid > *:first-child {
    border-top: 0;
  }

  .premium-fund-block {
    justify-items: start;
  }

  .premium-fund-block span {
    max-width: none;
    text-align: left;
  }
}

.rebate-child-field small {
  display: block;
  margin-top: 4px;
  color: var(--color-text-muted);
}

@media (max-width: 980px) {
  .results-workspace,
  .public-offers-hero-grid,
  .public-offers-grid,
  .promotion-strip {
    grid-template-columns: 1fr;
  }

  .compare-panel {
    position: static;
    max-height: min(760px, 78vh);
  }
}

@media (max-width: 860px) {
  .app-shell {
    grid-template-columns: 1fr;
  }

  .app-shell-warmup-focus {
    grid-template-columns: 1fr;
  }

  .app-shell-warmup-focus::before {
    opacity: 0.32;
  }

  .app-shell-warmup-focus::after {
    background:
      linear-gradient(180deg, rgba(255, 250, 240, 0.26), rgba(255, 253, 250, 0.72)),
      rgba(28, 42, 31, 0.08);
  }

  .visual-panel {
    min-height: auto;
    height: auto;
    display: grid;
    gap: var(--space-4);
    align-items: start;
    padding: var(--space-5);
    overflow: hidden;
  }

  .visual-system {
    position: relative;
    inset: auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 96px;
    grid-template-rows: auto auto;
    gap: var(--space-3);
  }

  .visual-content {
    grid-column: 1 / -1;
    order: 3;
  }

  .brand-proof-row {
    display: none;
  }

  .brand-art-shell {
    position: relative;
    inset: auto;
    display: grid;
    grid-column: 2;
    grid-row: 1;
    align-self: start;
    width: 96px;
    height: 96px;
    margin: 0;
  }

  .brand-tree-art {
    width: 96px;
    height: 96px;
    max-height: 96px;
    object-fit: cover;
    object-position: 9% 68%;
    -webkit-mask-image: none;
    mask-image: none;
    filter: drop-shadow(0 12px 16px rgba(62, 46, 30, 0.12));
  }

  .australia-proof {
    position: static;
    grid-column: 1 / -1;
    max-width: 100%;
    align-items: start;
    margin-top: var(--space-2);
    left: auto;
    bottom: auto;
    padding-left: 0;
  }

  .visual-content {
    display: grid;
    width: 100%;
    gap: var(--space-3);
  }

  .visual-content h1 {
    max-width: 18ch;
    font-size: clamp(2rem, 10vw, 3.05rem);
  }

  .visual-trail {
    display: block;
    margin-top: 0;
  }

  .question-panel {
    min-height: 66vh;
    height: auto;
    overflow: visible;
    padding: var(--space-5);
  }

  .app-shell-warmup-focus .visual-panel {
    max-height: 124px;
    overflow: hidden;
    opacity: 0.3;
  }

  .app-shell-warmup-focus .visual-trail {
    display: none;
  }

  .app-shell-warmup-focus .question-panel {
    min-height: calc(100vh - 124px);
    place-items: start center;
    padding: var(--space-4);
    background: rgba(255, 253, 250, 0.72);
  }

  .app-shell-warmup-focus .question-card {
    width: 100%;
    max-width: 430px;
    padding: var(--space-5);
    transform: none;
  }

  .focus-card-header {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }

  .flow-context {
    display: grid;
    gap: var(--space-2);
  }

  .flow-context .trail {
    overflow: hidden;
  }

  .refinement-choice-panel,
  .action-row-refinement {
    grid-template-columns: 1fr;
  }

  .focus-card-actions {
    justify-content: space-between;
    gap: var(--space-2);
  }

  .focus-card-actions .why-button,
  .focus-card-actions .home-button {
    min-height: 40px;
    padding-inline: 10px;
  }

  .focus-card-actions .why-button {
    flex: 1 1 auto;
  }

  .focus-card-actions .home-button {
    flex: 0 0 auto;
  }

  .app-shell-warmup-focus .choice {
    min-height: 68px;
  }

  .landing-intro {
    display: none;
  }

  .top-row {
    display: flex;
    justify-content: flex-end;
  }

  .top-row-compact {
    position: static;
    width: 100%;
    align-items: flex-start;
    gap: var(--space-2);
  }

  .top-row-compact .question-progress {
    min-width: 0;
    width: 100%;
  }

  .top-row-compact .question-progress > div:first-child {
    gap: var(--space-2);
    line-height: 1.25;
  }

  .action-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .action-row-landing {
    grid-template-columns: 1fr;
  }

  .question-panel > .action-row {
    position: static;
    width: min(540px, 100%);
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
  }

  .question-panel > .accuracy-hint,
  .question-panel > .reset-row {
    display: flex;
  }

  .question-panel > .accuracy-hint {
    display: block;
  }

  .option-grid,
  .option-grid-compact,
  .how-layout,
  .landing-info-band,
  .unlock-panel,
  .clarification-panel,
  .results-title-row,
  .result-signal-strip,
  .result-glance,
  .result-card-header {
    grid-template-columns: 1fr;
  }

  .shortlist-header,
  .promotion-panel-header {
    display: grid;
    align-items: start;
  }

  .result-signal-watch {
    min-width: 0;
  }

  .provider-filter,
  .fund-selector {
    align-items: stretch;
    flex-direction: column;
  }

  .provider-filter-button {
    width: 100%;
  }

  .choice {
    min-height: 58px;
  }

  .landing-section-inner,
  .landing-info-band {
    width: min(100% - 28px, 1120px);
  }

  .landing-section-inner {
    padding-bottom: var(--space-7);
  }

  .landing-info-band {
    padding: var(--space-4);
    margin-bottom: var(--space-7);
  }

  .how-step {
    padding: var(--space-4);
  }

  .question-card h2,
  .results-summary h1 {
    max-width: 16ch;
  }

  .results-summary {
    min-height: 0;
    padding: var(--space-4);
  }

  .results-brand-lockup strong {
    font-size: 1.05rem;
  }

  .results-brand-lockup small {
    font-size: 0.78rem;
  }

  .summary-tools {
    display: grid;
  }

  .result-card {
    grid-template-columns: 34px minmax(0, 1fr);
    padding: var(--space-3);
  }

  .result-card::after {
    width: 28px;
    height: 14px;
  }

  .result-rank {
    width: 30px;
    height: 30px;
  }

  .confidence-compact {
    width: 100%;
    min-width: 0;
  }

  .detail-panel {
    position: fixed;
    left: 10px;
    right: 10px;
    bottom: 0;
    z-index: 20;
    max-height: 84vh;
    overflow: auto;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    box-shadow: 0 -18px 44px rgba(22, 35, 38, 0.22);
  }

  .detail-panel .detail-content,
  .detail-panel .plan-detail {
    max-height: none;
    overflow: visible;
    overscroll-behavior: auto;
    gap: var(--space-3);
    padding: var(--space-3);
  }

  .detail-panel .detail-heading,
  .detail-panel .detail-toolbar {
    position: static;
    margin: calc(-1 * var(--space-3)) calc(-1 * var(--space-3)) 0;
    padding: var(--space-3);
  }

  .detail-toolbar {
    align-items: stretch;
  }

  .detail-close {
    justify-self: start;
  }

  .account-price-public {
    grid-template-columns: 1fr;
  }

  .account-price-public .account-price-main {
    padding-right: 0;
    padding-bottom: 8px;
    border-right: 0;
    border-bottom: 1px solid color-mix(in srgb, var(--color-gold) 34%, transparent);
  }

  .account-price-public .rebate-edit-button {
    margin-top: 2px;
    justify-self: start;
  }

  .detail-scroll-list {
    max-height: min(460px, 62vh);
  }

  .detail-scroll-list-compact {
    max-height: min(420px, 58vh);
  }

  .detail-list-more-extras .detail-scroll-list-compact {
    max-height: min(590px, 70vh);
  }

  .detail-heading {
    align-items: stretch;
  }

  .detail-heading-actions {
    justify-items: stretch;
  }

  .account-price,
  .account-price-detail {
    width: 100%;
  }

  .compare-item span {
    white-space: normal;
  }

  .public-offers-shell {
    width: min(100% - 24px, 720px);
    padding-top: var(--space-4);
  }

  .public-offers-hero {
    min-height: 0;
    padding-bottom: var(--space-5);
  }

  .public-offers-hero h1 {
    max-width: 11ch;
  }

  .public-offers-metrics {
    grid-template-columns: 1fr;
  }

  .public-offers-metrics div {
    min-height: 92px;
  }

  .public-offers-tools {
    position: static;
    display: grid;
  }

  .public-offers-search {
    min-width: 0;
  }

  .public-offer-facts {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 420px) {
  .brand-lockup {
    padding-right: 8px;
  }

  .brand-mark {
    width: 42px;
    height: 42px;
    font-size: 0.74rem;
  }

  .brand-lockup strong {
    font-size: 0.98rem;
  }

  .brand-lockup small {
    font-size: 0.7rem;
  }

  .brand-art-shell,
  .brand-tree-art {
    width: 86px;
    height: 86px;
  }

  .question-panel,
  .results-shell {
    padding: var(--space-4);
  }

  .action-row {
    gap: 6px;
  }

  .nav-button {
    min-height: 38px;
    padding: 7px 6px;
    font-size: 0.9rem;
  }

  .question-meta,
  .detail-heading,
  .compare-header,
  .results-summary-top {
    display: grid;
    justify-items: start;
  }

  .result-card {
    grid-template-columns: 1fr;
  }

  .detail-content {
    padding: var(--space-4);
  }

  .detail-close,
  .compare-header .secondary-button {
    width: 100%;
  }

  .account-price strong {
    font-size: 1.35rem;
  }

  .public-offers-nav,
  .public-offer-card-top {
    display: grid;
    justify-items: start;
  }

  .public-offer-card {
    min-height: 0;
    padding: var(--space-4);
  }
}

/* Workflow polish: fixed-dimension question surface and cleaner results workspace. */
.app-shell-warmup-focus .question-card.workflow-card {
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr) minmax(24px, auto) auto;
  width: min(1020px, calc(100vw - 48px));
  height: min(780px, calc(100dvh - 48px));
  min-height: 0;
  max-height: none;
  overflow: hidden;
  gap: 12px;
}

.workflow-header {
  grid-template-columns: minmax(180px, 0.62fr) minmax(340px, 1fr);
  align-items: stretch;
}

.workflow-step-copy,
.workflow-readiness {
  display: grid;
  align-content: center;
  gap: 5px;
}

.workflow-step-copy span,
.workflow-readiness span,
.workflow-trail-label,
.refinement-choice span,
.rail-section-heading span,
.result-row-ribbon,
.result-fit-cell small,
.result-why-cell h3,
.result-coverage-cell h3,
.result-check-cell h3 {
  color: var(--color-text-muted);
  font-size: var(--type-label);
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.workflow-step-copy strong,
.workflow-readiness strong {
  color: var(--color-forest);
  font-size: 1rem;
  line-height: 1.1;
}

.workflow-step-meter,
.workflow-readiness div {
  overflow: hidden;
  height: 6px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-line) 58%, white);
}

.workflow-step-meter span,
.workflow-readiness div span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--color-gold), var(--color-sage), var(--color-forest));
}

.workflow-header-side {
  display: flex;
  align-items: stretch;
  justify-content: flex-end;
  gap: var(--space-3);
}

.workflow-readiness {
  min-width: 170px;
  padding: 9px 11px;
  border: 1px solid color-mix(in srgb, var(--color-line) 76%, transparent);
  border-radius: var(--radius-md);
  background: rgba(255, 253, 250, 0.72);
}

.workflow-trail {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  min-height: 34px;
  padding-bottom: var(--space-1);
  border-bottom: 1px solid color-mix(in srgb, var(--color-line) 62%, transparent);
}

.workflow-trail .trail {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-width: 0;
}

.workflow-trail .trail span,
.workflow-trail .trail-empty {
  margin: 0;
  min-height: 26px;
  display: inline-flex;
  align-items: center;
  padding: 4px 8px;
  border: 1px solid color-mix(in srgb, var(--color-sage) 24%, var(--color-line));
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--color-surface-evidence) 50%, white);
  color: var(--color-forest);
  font-size: 0.82rem;
  font-weight: 760;
}

.workflow-content {
  display: grid;
  align-content: start;
  gap: var(--space-3);
  min-height: 0;
  overflow: auto;
  padding-right: 4px;
  scrollbar-gutter: stable;
}

.question-content {
  display: grid;
  align-content: start;
  gap: var(--space-3);
}

.workflow-content .option-grid {
  margin-top: 0;
}

.workflow-content .field-label textarea {
  min-height: 124px;
}

.workflow-message-slot {
  min-height: 24px;
  display: grid;
  align-items: center;
}

.workflow-actions {
  align-self: end;
  margin-top: 0;
}

.workflow-card-refinement .workflow-content {
  gap: var(--space-4);
}

.refinement-choice-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}

.refinement-choice {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: var(--space-3);
  min-height: 186px;
  padding: var(--space-4);
  border: 1px solid color-mix(in srgb, var(--color-line) 82%, transparent);
  border-radius: var(--radius-md);
  background: rgba(255, 253, 250, 0.74);
}

.refinement-choice-primary {
  border-color: color-mix(in srgb, var(--color-gold) 46%, var(--color-line));
  background: linear-gradient(180deg, rgba(255, 253, 250, 0.94), rgba(255, 241, 214, 0.72));
}

.refinement-choice strong {
  display: block;
  margin-top: 5px;
  color: var(--color-forest);
  font-family: var(--font-display);
  font-size: 1.18rem;
  line-height: 1.1;
}

.refinement-choice p {
  margin: 6px 0 0;
  color: var(--color-text-muted);
  font-size: 0.92rem;
  line-height: 1.38;
}

.workflow-card-refinement .workflow-actions {
  grid-template-columns: minmax(140px, 200px);
  justify-content: start;
}

.results-summary-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}

.results-layout {
  width: min(1360px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 276px minmax(0, 1fr);
  gap: var(--space-4);
  align-items: start;
}

.results-main-column {
  min-width: 0;
  display: grid;
  gap: var(--space-4);
}

.results-refinement-rail {
  position: sticky;
  top: var(--space-4);
  display: grid;
  gap: var(--space-4);
  padding: var(--space-4);
  border: 1px solid color-mix(in srgb, var(--color-line) 86%, transparent);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(180deg, rgba(255, 253, 250, 0.98), rgba(255, 250, 240, 0.92)),
    var(--color-surface-raised);
  box-shadow: 0 16px 38px rgba(61, 43, 28, 0.09);
}

.rail-back-button,
.rail-action-button {
  width: 100%;
}

.rail-section {
  display: grid;
  gap: var(--space-3);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid color-mix(in srgb, var(--color-line) 72%, transparent);
}

.rail-section-heading h2 {
  margin: 2px 0 0;
  color: var(--color-forest);
  font-family: var(--font-display);
  font-size: 1.15rem;
  line-height: 1.12;
}

.results-refinement-rail .provider-filter,
.results-refinement-rail .data-scope-note {
  width: 100%;
  border-color: color-mix(in srgb, var(--color-line) 76%, transparent);
  background: rgba(255, 253, 250, 0.58);
}

.results-refinement-rail .provider-filter {
  display: grid;
  align-items: stretch;
}

.results-refinement-rail .provider-filter-button {
  width: 100%;
}

.results-refinement-rail .confidence {
  width: 100%;
  min-width: 0;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.profile-chip-list {
  display: grid;
  gap: 7px;
}

.profile-chip-list div {
  display: grid;
  gap: 2px;
  padding: 8px 9px;
  border: 1px solid color-mix(in srgb, var(--color-line) 78%, transparent);
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--color-surface-inset) 62%, white);
}

.profile-chip-list span {
  color: var(--color-text-muted);
  font-size: 0.72rem;
  font-weight: 850;
  text-transform: uppercase;
}

.profile-chip-list strong {
  color: var(--color-forest);
  font-size: 0.9rem;
  line-height: 1.18;
}

.profile-chip-list p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.9rem;
}

.results-table-panel {
  overflow: hidden;
  padding: 0;
}

.results-table-panel .shortlist-header {
  padding: var(--space-5);
}

.results-table-panel .results-grid {
  gap: 0;
}

.result-row-card {
  display: grid;
  gap: 0;
  overflow: hidden;
  padding: 0;
  border-radius: 0;
  border-width: 1px 0 0;
  box-shadow: none;
}

.result-row-card:first-child {
  border-top-color: color-mix(in srgb, var(--color-gold) 48%, var(--color-line));
}

.result-row-card::before,
.result-row-card::after {
  content: none;
}

.result-row-ribbon {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  padding: 5px 10px;
  border-radius: 0 0 var(--radius-sm) 0;
  background: var(--color-gold);
  color: var(--color-on-brand);
}

.result-row-grid {
  display: grid;
  grid-template-columns: 44px minmax(220px, 1.2fr) 118px minmax(190px, 1fr) minmax(170px, 0.9fr) 132px;
  grid-template-areas:
    "rank plan fit why coverage actions"
    "rank plan fit why check actions";
  min-width: 0;
}

.result-row-card .result-rank {
  grid-area: rank;
  align-self: start;
  justify-self: center;
  margin-top: var(--space-5);
}

.result-plan-cell,
.result-fit-cell,
.result-why-cell,
.result-coverage-cell,
.result-check-cell,
.result-action-cell {
  min-width: 0;
  padding: var(--space-5);
}

.result-plan-cell {
  grid-area: plan;
  padding-left: var(--space-4);
}

.result-row-card .fund-name {
  margin-bottom: 6px;
  font-size: 0.72rem;
}

.result-row-card h2 {
  max-width: none;
  font-size: clamp(1.08rem, 1.55vw, 1.28rem);
  line-height: 1.15;
}

.result-fit-cell {
  grid-area: fit;
  display: grid;
  justify-items: center;
  align-content: center;
  gap: var(--space-2);
  border-left: 1px solid color-mix(in srgb, var(--color-line) 68%, transparent);
}

.result-why-cell {
  grid-area: why;
  border-left: 1px solid color-mix(in srgb, var(--color-line) 68%, transparent);
}

.result-coverage-cell {
  grid-area: coverage;
  border-left: 1px solid color-mix(in srgb, var(--color-line) 68%, transparent);
}

.result-check-cell {
  grid-area: check;
  border-top: 1px solid color-mix(in srgb, var(--color-line) 68%, transparent);
  border-left: 1px solid color-mix(in srgb, var(--color-line) 68%, transparent);
}

.result-action-cell {
  grid-area: actions;
  display: grid;
  align-content: center;
  gap: var(--space-2);
  border-left: 1px solid color-mix(in srgb, var(--color-line) 68%, transparent);
  background: rgba(255, 253, 250, 0.42);
}

.result-plan-cell .account-price {
  width: min(100%, 230px);
}

.result-row-card .result-meta {
  display: flex;
}

.result-fit-ring {
  --fit-fill: 70%;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 3px;
  width: 86px;
  height: 86px;
  border-radius: 50%;
  background:
    radial-gradient(circle closest-side, var(--color-surface-raised) 72%, transparent 73%),
    conic-gradient(var(--color-sage) var(--fit-fill), color-mix(in srgb, var(--color-line) 54%, white) 0);
}

.result-fit-ring strong {
  color: var(--color-forest);
  font-family: var(--font-display);
  font-size: 1.28rem;
  line-height: 1;
}

.result-fit-ring span {
  max-width: 64px;
  color: var(--color-text-muted);
  font-size: 0.66rem;
  font-weight: 820;
  line-height: 1.05;
  text-align: center;
}

.result-plan-cell h2 {
  overflow-wrap: anywhere;
}

.result-why-cell ul,
.result-coverage-cell ul,
.result-check-cell ul {
  display: grid;
  gap: 8px;
  margin: var(--space-2) 0 0;
  padding: 0;
  color: var(--color-text);
  font-size: 0.88rem;
  line-height: 1.3;
  list-style: none;
}

.result-why-cell li,
.result-coverage-cell li,
.result-check-cell li {
  position: relative;
  padding-left: 18px;
}

.result-why-cell li::before,
.result-coverage-cell li::before,
.result-check-cell li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.45em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--color-sage);
}

.result-check-cell li::before {
  background: var(--color-gold);
}

.result-compare-button {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 8px 10px;
  border: 1px solid color-mix(in srgb, var(--color-line) 92%, transparent);
  border-radius: var(--radius-sm);
  background: var(--color-surface-raised);
  color: var(--color-text);
  font-weight: 860;
}

.result-compare-button > span {
  width: 16px;
  height: 16px;
  border: 1px solid color-mix(in srgb, var(--color-sage) 54%, var(--color-line));
  border-radius: var(--radius-xs);
  background: white;
}

.result-compare-button.compare-selected > span {
  border-color: var(--color-forest);
  background:
    linear-gradient(135deg, transparent 0 42%, var(--color-on-brand) 42% 57%, transparent 57%),
    var(--color-forest);
}

.result-reveal-button {
  min-height: 38px;
  width: 100%;
}

.result-row-card .detail-panel {
  margin: 0 var(--space-4) var(--space-4) calc(44px + var(--space-4));
}

@media (max-width: 1180px) {
  .results-layout {
    grid-template-columns: 1fr;
  }

  .results-refinement-rail {
    position: static;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
  }

  .results-refinement-rail .fine-print,
  .results-refinement-rail .data-scope-note {
    grid-column: 1 / -1;
  }
}

@media (max-width: 980px) {
  .result-row-grid {
    grid-template-columns: 40px minmax(0, 1fr) 108px;
    grid-template-areas:
      "rank plan fit"
      "why why why"
      "coverage coverage coverage"
      "check check actions";
  }

  .result-why-cell,
  .result-coverage-cell,
  .result-check-cell,
  .result-action-cell {
    border-top: 1px solid color-mix(in srgb, var(--color-line) 68%, transparent);
    border-left: 0;
  }

  .result-action-cell {
    align-content: stretch;
  }
}

@media (max-width: 860px) {
  .app-shell-warmup-focus .question-card.workflow-card {
    width: 100%;
    max-width: 560px;
    height: calc(100dvh - 32px);
    min-height: calc(100dvh - 156px);
    max-height: calc(100dvh - 32px);
    padding: var(--space-4);
  }

  .workflow-header {
    grid-template-columns: 1fr;
  }

  .workflow-header-side,
  .workflow-trail {
    display: grid;
  }

  .workflow-readiness {
    min-width: 0;
  }

  .workflow-trail .trail span:nth-child(n + 3) {
    display: none;
  }

  .refinement-choice-grid,
  .results-refinement-rail {
    grid-template-columns: 1fr;
  }

  .refinement-choice {
    min-height: 152px;
  }

  .results-summary-actions {
    display: grid;
  }

  .results-summary-actions .ghost-button {
    width: 100%;
  }

  .result-row-card .detail-panel {
    margin: 0;
  }
}

@media (max-width: 620px) {
  .result-row-grid {
    grid-template-columns: 36px minmax(0, 1fr);
    grid-template-areas:
      "rank plan"
      "fit fit"
      "why why"
      "coverage coverage"
      "check check"
      "actions actions";
  }

  .result-fit-cell,
  .result-why-cell,
  .result-coverage-cell,
  .result-check-cell,
  .result-action-cell {
    border-left: 0;
    border-top: 1px solid color-mix(in srgb, var(--color-line) 68%, transparent);
  }

  .result-fit-cell {
    justify-items: start;
  }

  .result-action-cell {
    grid-template-columns: 1fr;
  }
}
