:root {
  --green: #017848;
  --green-dark: #015c37;
  --green-soft: #e8f3ec;
  --navy: #0e1d31;
  --navy-soft: #16263d;
  --purple: #6d5cff;
  --ink: #10231b;
  --muted: #5b6b64;
  --line: rgba(16, 35, 27, 0.12);
  --bg: #f5f8f6;
  --panel: #ffffff;
  --radius: 16px;
  --shadow: 0 18px 48px rgba(16, 35, 27, 0.10);
  /* Single source of truth for legal/disclaimer/footer text width so every page's
     fine print lines up at the same measure (matches the top rate disclaimer). */
  --legal-w: 820px;
}
/* Purple theme: remap the primary accent so green CTAs/accents become purple.
   The navy hero + Betsy avatar glow stay constant; only the brand color flips,
   which is the A/B the deck wants (green = money/trust vs purple = AI). */
body.theme-purple {
  --green: #6d5cff;
  --green-dark: #574bd6;
  --green-soft: #efeaff;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; background: var(--bg); color: var(--ink);
  font: 16px/1.55 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
}
.wrap { max-width: 1120px; margin: 0 auto; padding: 0 22px; }
a { color: inherit; }
img { max-width: 100%; }

/* header */
.lp-header { background: var(--panel); border-bottom: 1px solid var(--line); }
.lp-header .wrap { display: flex; align-items: center; justify-content: space-between; height: 64px; }
.brand { font-weight: 800; font-size: 24px; letter-spacing: -0.02em; text-decoration: none; color: var(--ink); }
.brand b { color: var(--green); }
.secure { color: var(--muted); font-size: 13px; display: flex; align-items: center; gap: 6px; }

/* buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-weight: 700; font-size: 16px; border: 0; border-radius: 12px; padding: 15px 22px;
  cursor: pointer; text-decoration: none; transition: transform .08s ease, box-shadow .12s ease, background .12s ease; }
.btn:active { transform: translateY(1px); }
.btn-green { background: var(--green); color: #fff; width: 100%; }
.btn-green:hover { background: var(--green-dark); }
.btn-purple { background: var(--purple); color: #fff; width: 100%; }
.btn-purple:hover { filter: brightness(1.06); }
.btn-ghost { background: transparent; color: var(--green); border: 1px solid var(--green); width: 100%; }

/* hero */
.hero { padding: 56px 0 40px; position: relative; overflow: hidden; }
.hero > .wrap { position: relative; z-index: 1; }
/* AI person photo as a subtle grayed hero background under the text (standup: image as
   hero background, not floating). Low opacity keeps headline/CTA fully readable; the
   AI-generated disclaimer sits in the corner. */
.hero-bg { position: absolute; inset: 0; background-size: cover; background-position: center 28%;
  filter: grayscale(1) contrast(.95); opacity: .13; z-index: 0; pointer-events: none; }
.hero-ai-tag { position: absolute; right: 12px; bottom: 8px; z-index: 1; font-size: 10px;
  color: var(--muted); opacity: .6; font-style: italic; }
.under-cta { display: flex; gap: 8px; align-items: flex-start; font-size: 13px; font-weight: 700;
  color: var(--ink); margin: 12px 0 0; }
.under-cta .chk { flex: 0 0 auto; }
.hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 40px; align-items: center; }
.eyebrow { display: inline-block; font-size: 12px; font-weight: 800; letter-spacing: .12em;
  text-transform: uppercase; color: var(--green); background: var(--green-soft);
  padding: 6px 12px; border-radius: 999px; margin-bottom: 14px; }
h1 { font-size: clamp(34px, 5vw, 52px); line-height: 1.05; letter-spacing: -0.03em; margin: 0 0 16px; }
h1 .hl { color: var(--green); }
.lede { font-size: 18px; color: var(--muted); max-width: 46ch; margin: 0 0 22px; }
/* Worked payment example. Moved from the hero to the footer fine print (Jess + Pat
   06-12); the footer-scoped override below restyles it as plain fine print. */
.pay-example { font-size: 14px; line-height: 1.5; color: var(--ink); max-width: 52ch;
  background: var(--green-soft); border-radius: 10px; padding: 10px 14px; margin: -8px 0 22px; }
.pay-example .pay-asof { display: block; font-size: 12px; color: var(--muted); margin-top: 2px; }
.foot-fine .pay-example { font-size: 12px; color: var(--muted); max-width: 100%;
  background: none; border-radius: 0; padding: 0; margin: 0 0 10px; }
.foot-fine .pay-example .pay-asof { display: inline; font-size: 12px; }
/* TCPA consent in proximity to the phone field (Betsy arm): under the submit button. */
.card-consent { font-size: 10.5px; line-height: 1.5; color: var(--muted); margin: 10px 0 0; text-align: left; }
.checks { list-style: none; padding: 0; margin: 0 0 8px; display: grid; gap: 10px; }
.checks li { display: flex; gap: 10px; align-items: flex-start; font-weight: 600; }
.checks svg { flex: 0 0 auto; margin-top: 3px; }
.hero-art { border-radius: 20px; overflow: hidden; box-shadow: var(--shadow);
  background: linear-gradient(135deg, #dff0e6, #c7e6d3); aspect-ratio: 4/3;
  display: flex; align-items: flex-end; }
.hero-art .ph { padding: 18px; color: #2c4a3a; font-weight: 700; }

/* form card */
.card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 26px; }
.card h2 { margin: 0 0 4px; font-size: 22px; letter-spacing: -0.01em; }
.card .sub { color: var(--muted); font-size: 14px; margin: 0 0 18px; }
.field { margin-bottom: 14px; }
.field-row { display: flex; gap: 12px; }
.field-row .field { flex: 1; }
.field label { display: block; font-size: 13px; font-weight: 700; margin-bottom: 6px; }
.field input { width: 100%; padding: 13px 14px; border: 1px solid var(--line); border-radius: 10px;
  font-size: 16px; background: #fcfdfc; }
.field input:focus { outline: 2px solid var(--green); border-color: var(--green); }
.or { text-align: center; color: var(--muted); font-size: 13px; margin: 12px 0; }
.fineprint { color: var(--muted); font-size: 12px; margin-top: 12px; display: flex; gap: 6px; align-items: center; }
.demo-note { color: var(--muted); font-size: 11px; opacity: .8; margin-top: 10px; text-align: center; }
.success { display: none; text-align: center; padding: 30px 10px; }
.success.show { display: block; }
.success .tick { width: 56px; height: 56px; border-radius: 50%; background: var(--green-soft);
  color: var(--green); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.success h2 { margin: 0 0 8px; }
form.hide { display: none; }
.est { text-align: left; margin-top: 16px; }
.est-out { text-align: center; }
.est-out .save { font-size: 40px; font-weight: 900; color: var(--green); letter-spacing: -0.03em; }
.est-out .btn { margin-top: 12px; }

/* --- Gonz feedback: Better wordmark, ticker, social proof, minimal footer --- */
.brand { color: #0a0a0a; text-decoration: none; display: inline-flex; align-items: center; }
.better-logo { height: 26px; width: auto; display: block; color: #0a0a0a; }
.lp-footer .better-logo { height: 22px; }
.lp-header .wrap { height: 60px; }
.btn { border-radius: 10px; }            /* Better-style button radius */
.field input { border-radius: 10px; }

/* live ticker: funded counter + today's rate */
.ticker { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: var(--muted);
  background: var(--green-soft); border-radius: 999px; padding: 7px 14px; margin-top: 16px; font-weight: 600; }
.ticker b { color: var(--green-dark); }
.tdot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); animation: tpulse 1.8s infinite; }
@keyframes tpulse { 0% { box-shadow: 0 0 0 0 rgba(1,120,72,.45); } 70% { box-shadow: 0 0 0 8px rgba(1,120,72,0); } 100% { box-shadow: 0 0 0 0 rgba(1,120,72,0); } }
@media (prefers-reduced-motion: reduce) { .tdot { animation: none; } }

/* social proof bar (replaces the generic benefit cards) */
.proof { padding: 28px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--panel); }
.proof .wrap { text-align: center; }
.proof-stars { color: #e0a800; font-size: 18px; letter-spacing: 2px; }
.proof-stars span { color: var(--ink); font-size: 13px; font-weight: 600; letter-spacing: 0; margin-left: 6px; }
.proof-logos { display: flex; flex-wrap: wrap; gap: 28px; justify-content: center; align-items: center; margin: 16px 0 10px; }
.plogo { font-weight: 800; font-size: 16px; letter-spacing: -0.01em; color: #6b7280; }
.proof-stats { font-size: 13px; color: var(--muted); }
/* Trustpilot aggregate badge (proof bar) + inline (reviews header) + per-card source */
.tp-badge { display: inline-flex; align-items: center; flex-wrap: wrap; gap: 10px; justify-content: center; text-decoration: none; color: var(--ink); }
.tp-badge:hover .tp-name { text-decoration: underline; }
.tp-star { color: #00b67a; font-size: 20px; line-height: 1; }
.tp-name { font-weight: 800; letter-spacing: -0.01em; color: var(--ink); }
.tp-count { font-size: 13px; color: var(--muted); }
.tp-inline { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: var(--muted); text-decoration: none; margin-top: 6px; }
.tp-inline b { color: var(--ink); font-size: 15px; }
.tp-inline .review-stars { color: #00b67a; }
.review-src { font-weight: 600; color: #9aa3ad; }
.lp-trustbox-section { padding: 10px 0 6px; }

/* minimal footer: Better logo + one legal line */
.lp-footer .foot { text-align: center; padding: 48px 22px; }
.lp-footer .brand { display: inline-block; margin-bottom: 8px; }
/* All fine print sits below the logo in one left-aligned column at the shared legal width. */
.foot-fine { max-width: var(--legal-w); margin: 22px auto 0; text-align: left; }
.foot-fine .lp-disclaimer { max-width: 100%; margin: 0 0 10px; }
.foot-fine .lp-disclaimer:last-of-type { margin-bottom: 0; }
.foot-fine .lp-consent { max-width: 100%; margin: 0 0 8px; }
.foot-fine .foot-legal { margin: 22px auto 0; padding-top: 18px; border-top: 1px solid var(--line); }
.foot-legal { font-size: 11px; color: var(--muted); max-width: var(--legal-w); margin: 0 auto; line-height: 1.6; text-align: left; }
.foot-legal p { margin: 0 0 10px; }
.foot-legal p:last-child { margin-bottom: 0; }

/* HELOC competitor compare: rate vs rate */
.vs { display: flex; align-items: stretch; justify-content: center; gap: 14px; margin: 10px auto 0; max-width: 520px; }
.vs-box { flex: 1; border-radius: 16px; padding: 20px; text-align: center; border: 1px solid var(--line); background: var(--panel); }
.vs-us { background: var(--green-soft); border-color: #a7dbbf; }
.vs-label { font-size: 13px; font-weight: 700; color: var(--muted); }
.vs-them .vs-label { color: #b00020; }
.vs-us .vs-label { color: var(--green-dark); }
.vs-rate { font-size: 42px; font-weight: 900; letter-spacing: -0.03em; margin-top: 4px; }
.vs-them .vs-rate { color: #b00020; }
.vs-us .vs-rate { color: var(--green); }
.vs-mid { align-self: center; color: var(--muted); font-weight: 700; font-size: 14px; }
.vs-mo { font-size: 14px; color: var(--muted); font-weight: 600; margin-top: 2px; }
.vs-save { font-size: 16px; color: var(--ink); margin: 16px auto 0; max-width: 520px; }
.vs-save b { color: var(--green); }
.cost-bars { max-width: 560px; margin: 22px auto 0; text-align: left; }
.cost-cap { font-size: 12px; color: var(--muted); margin-bottom: 10px; text-align: center; }
.cost-row { display: grid; grid-template-columns: 110px 1fr auto; align-items: center; gap: 10px; margin-bottom: 8px; }
.cost-lbl { font-size: 13px; font-weight: 600; }
.cost-bar { height: 18px; background: #e7ece9; border-radius: 999px; overflow: hidden; }
.cost-fill { display: block; height: 100%; border-radius: 999px; }
.cost-them { background: #d68a8a; }
.cost-us { background: var(--green); }
.cost-val { font-size: 13px; font-weight: 700; }
.disclaimer-mini { font-size: 11px; color: var(--muted); text-align: center; max-width: 72ch; margin: 18px auto 0; line-height: 1.5; padding: 0 22px; }
/* compare LP rate face-off (replaces .vs + .cost-bars): two rates side by side,
   competitor struck through, enlarged "lower with Better" delta. */
.rcompare { max-width: 540px; margin: 14px auto 0; }
.rcompare-faces { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 10px; }
.rcompare-side { text-align: center; padding: 18px 10px; border-radius: 16px; border: 1px solid var(--line); }
.rcompare-them { background: #faf8f7; }
.rcompare-us { background: var(--green-soft); border-color: #a7dbbf; }
.rcompare-name { font-size: 12px; font-weight: 800; letter-spacing: 0.03em; text-transform: uppercase; color: var(--muted); }
.rcompare-us .rcompare-name { color: var(--green-dark); }
.rcompare-rate { font-size: clamp(34px, 6vw, 52px); line-height: 1; font-weight: 900; letter-spacing: -0.03em; margin: 6px 0 3px; color: #9aa1ac; }
.rcompare-them .rcompare-rate s { text-decoration-thickness: 3px; text-decoration-color: #c2564f; }
.rcompare-us .rcompare-rate { color: var(--green); }
.rcompare-sub { font-size: 11px; color: var(--muted); }
.rcompare-vs { font-size: 13px; font-weight: 800; color: #aab0b8; }
.rcompare-delta { display: block; width: max-content; max-width: 100%; margin: 18px auto 0; background: var(--green); color: #fff; font-weight: 850; font-size: clamp(16px, 2.4vw, 20px); letter-spacing: -0.01em; border-radius: 999px; padding: 12px 26px; }
.rcompare-save { text-align: center; font-size: 14px; color: var(--ink); margin: 12px auto 0; }
.rcompare-save b { color: var(--green); }

/* sections */
section { padding: 48px 0; }
/* Visual separation between sections (standup 06-10): more breathing room + alternating
   bands so reviews / FAQ / compare read as distinct blocks instead of one wall. Applies
   only to in-<main> content sections; compliance/disclaimer/footer sit after </main>. */
main > section { padding: 56px 0; }
main > section:nth-of-type(even) { background: #fff; }
main > section + section { border-top: 1px solid var(--line); }
.section-head { text-align: center; max-width: 60ch; margin: 0 auto 30px; }

/* Cookie/consent banner (TrustArc, mounts into #consent_blackbar): keep it a small,
   unobtrusive corner toast — NOT a primary-CTA-sized bar (standup 06-10). */
#consent_blackbar { position: fixed; left: 14px; right: auto; bottom: 14px; z-index: 90;
  max-width: 340px; font-size: 12px; line-height: 1.4; border-radius: 12px;
  box-shadow: 0 8px 28px rgba(19,35,28,.20); overflow: hidden; }
#consent_blackbar:empty { display: none; }
@media (max-width: 640px) { #consent_blackbar { left: 10px; right: 10px; max-width: none; } }
.section-head h2 { font-size: clamp(26px, 3.4vw, 34px); letter-spacing: -0.02em; margin: 0 0 8px; }
.section-head p { color: var(--muted); margin: 0; }
.cards3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.feature { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 24px; }
.feature .ic { width: 44px; height: 44px; border-radius: 12px; background: var(--green-soft);
  color: var(--green); display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.feature h3 { margin: 0 0 8px; font-size: 18px; }
.feature p, .feature ul { color: var(--muted); margin: 0; font-size: 15px; }
.feature ul { padding-left: 18px; }

/* equity visual */
.equity { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 28px; display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr; gap: 16px; align-items: center; text-align: center; }
.equity .op { font-size: 28px; color: var(--muted); font-weight: 300; }
.equity .lbl { font-size: 13px; color: var(--muted); margin-bottom: 6px; }
.equity .val { font-size: 26px; font-weight: 800; letter-spacing: -0.02em; }
.equity .val.green { color: var(--green); }

/* steps */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.step { text-align: center; }
.step .n { width: 40px; height: 40px; border-radius: 50%; background: var(--green); color: #fff;
  font-weight: 800; display: inline-flex; align-items: center; justify-content: center; margin-bottom: 12px; }
.step p { color: var(--muted); font-size: 14px; margin: 4px 0 0; }
.step h4 { margin: 0; font-size: 15px; }

/* bottom CTA band */
.cta-band { background: var(--navy); color: #fff; border-radius: 22px; padding: 40px;
  text-align: center; box-shadow: var(--shadow); }
.cta-band h2 { color: #fff; font-size: clamp(24px, 3vw, 32px); margin: 0 0 6px; }
.cta-band p { color: #c8d4e2; margin: 0 0 22px; }
.cta-band form { max-width: 460px; margin: 0 auto; }
.cta-band .field input { background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.18); color: #fff; }
.cta-band .field label { color: #c8d4e2; }

/* trust row */
.trust { display: flex; flex-wrap: wrap; gap: 26px; justify-content: center; align-items: center;
  color: var(--muted); font-size: 13px; padding: 26px 0; }
.trust span { display: inline-flex; align-items: center; gap: 8px; }
.disclaimer { color: var(--muted); font-size: 11px; text-align: center; max-width: 80ch; margin: 0 auto; padding-bottom: 30px; line-height: 1.5; }

/* ---- Betsy (page 2) ---- */
.betsy-hero { background: radial-gradient(120% 120% at 50% -10%, var(--navy-soft), var(--navy)); color: #fff; }
.betsy-hero .wrap { padding: 56px 22px 48px; text-align: center; }
.betsy-hero h1 { color: #fff; }
.betsy-hero h1 .hl { color: #fff; }
.betsy-hero .lede { color: #c8d4e2; margin-left: auto; margin-right: auto; }
.betsy-hero .eyebrow { background: rgba(255,255,255,.10); color: #fff; }
.avatar { width: 168px; height: 168px; border-radius: 50%; margin: 22px auto 8px; position: relative;
  background: linear-gradient(160deg, #2a3c57, #16263d); display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 0 3px rgba(109,92,255,.45), 0 0 60px rgba(109,92,255,.35); font-size: 64px; }
.wave { display: flex; gap: 4px; justify-content: center; align-items: flex-end; height: 34px; margin: 12px 0 4px; }
.wave i { width: 4px; background: var(--purple); border-radius: 2px; animation: w 1s ease-in-out infinite; }
.wave i:nth-child(2){animation-delay:.1s} .wave i:nth-child(3){animation-delay:.2s}
.wave i:nth-child(4){animation-delay:.3s} .wave i:nth-child(5){animation-delay:.15s}
.wave i:nth-child(6){animation-delay:.25s} .wave i:nth-child(7){animation-delay:.05s}
@keyframes w { 0%,100%{height:8px} 50%{height:30px} }
@media (prefers-reduced-motion: reduce) { .wave i { animation: none; height: 18px; } }
.betsy-mini { display: flex; gap: 22px; justify-content: center; flex-wrap: wrap; color: #c8d4e2; font-size: 14px; margin: 14px 0 4px; }
.betsy-mini span { display: inline-flex; align-items: center; gap: 8px; }
.betsy-card { max-width: 440px; margin: 26px auto 0; background: var(--panel); color: var(--ink);
  border-radius: var(--radius); box-shadow: var(--shadow); padding: 24px; }
.betsy-card h2 { margin: 0 0 2px; font-size: 20px; }
.betsy-card .sub { color: var(--muted); font-size: 13px; text-align: center; margin: 0 0 16px; }
.learn { max-width: 560px; margin: 0 auto; display: grid; gap: 12px; }
.learn li { display: flex; gap: 10px; align-items: flex-start; }
.quote { max-width: 560px; margin: 26px auto 0; background: var(--green-soft); border-radius: var(--radius);
  padding: 20px 24px; text-align: center; }
.quote .stars { color: #e0a800; letter-spacing: 2px; }

/* ---- Savings calculator (page 3) ---- */
.calc { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 28px; }
/* Calculator embedded in the hero CTA card (debt-consolidation): the card is the chrome,
   so the calc itself goes flat and compact, and the savings readout leads into the button. */
.card .calc { background: transparent; border: 0; border-radius: 0; box-shadow: none; padding: 0; margin: 2px 0 4px; }
.card .calc .row { margin-bottom: 14px; }
.card-save { background: var(--green-soft); border-radius: 10px; padding: 10px 14px; margin: 0 0 12px;
  font-size: 14px; text-align: center; }
.card-save b { color: var(--green-dark); font-size: 17px; }
.card-save .demo-note, .card .calc .demo-note { font-size: 11px; color: var(--muted); margin: 6px 0 0; }
/* Rate-reveal concept demo (heloc-rate-reveal): the post-submit "here's your rate" card. */
.rr-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.rr-head h2 { font-size: 19px; }
.rr-sample { flex: 0 0 auto; font-size: 10px; font-weight: 800; letter-spacing: .05em; color: #92600a; background: #fff4d6; border-radius: 999px; padding: 2px 8px; }
.rr-rate { font-size: 46px; font-weight: 900; color: var(--green); letter-spacing: -0.02em; line-height: 1; }
.rr-apr { font-size: 13px; font-weight: 600; color: var(--muted); }
.rr-meta { font-size: 12px; color: var(--muted); margin: 4px 0 10px; }
.rr-betsy { border-top: 1px solid var(--line); margin-top: 14px; padding-top: 10px; font-size: 12.5px; color: var(--muted); text-align: center; }
.rr-betsy b { color: var(--green-dark); }
/* Hostage Counter (card-interest-counter): dark hero, live loss counter on the visitor's
   OWN card numbers. Villain color is red — green stays Better's. */
.hc { background: #0E1D31; color: #fff; }
.hc-wrap { max-width: 760px; margin: 0 auto; padding: 56px 22px 48px; text-align: center; }
.hc-eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 700;
  color: #ffb4a6; background: rgba(255,107,87,.12); border-radius: 999px; padding: 6px 14px; }
.hc-dot { width: 8px; height: 8px; border-radius: 50%; background: #ff6b57; animation: hcblink 1.2s infinite; }
@keyframes hcblink { 50% { opacity: .35; } }
.hc-h1 { font-size: clamp(28px, 5vw, 44px); line-height: 1.08; letter-spacing: -0.02em; margin: 16px 0 8px; color: #fff; }
.hc-hl { color: #ff8a73; }
.hc-meter { margin: 18px auto 6px; }
.hc-cap { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: #9fb0c4; }
.hc-counter { font-size: clamp(52px, 10vw, 92px); font-weight: 900; letter-spacing: -0.03em; line-height: 1.05;
  color: #ff6b57; font-variant-numeric: tabular-nums; margin: 6px 0 2px; }
.hc-counter .hc-micro { font-size: .42em; opacity: .6; }
.hc-sub { font-size: 14px; color: #9fb0c4; margin: 0; }
.hc-stats { display: flex; justify-content: center; gap: 28px; margin: 18px 0 6px; }
.hc-stats div { display: flex; flex-direction: column; }
.hc-stats b { font-size: 22px; font-weight: 800; color: #fff; font-variant-numeric: tabular-nums; }
.hc-stats span { font-size: 12px; color: #9fb0c4; }
.hc-card { background: #16263D; border: 1px solid rgba(255,255,255,.08); border-radius: 14px; padding: 18px 20px;
  margin: 18px auto 16px; max-width: 480px; text-align: left; }
.hc-row { margin-bottom: 14px; } .hc-row:last-child { margin-bottom: 0; }
.hc-row label { display: flex; justify-content: space-between; font-size: 13px; font-weight: 700; color: #c8d4e2; margin-bottom: 8px; }
.hc-row label b { color: #fff; }
.hc-row input[type=range] { width: 100%; accent-color: #ff6b57; }
.hc-cta { max-width: 480px; margin: 0 auto; }
.hc-under { display: flex; gap: 8px; align-items: flex-start; justify-content: center; font-size: 13px; font-weight: 700;
  color: #d9f3e4; margin: 10px 0 0; }
.hc-under .chk { color: #00D46E; }
.hc-fine { font-size: 11px; color: #9fb0c4; margin: 8px 0 0; }
@media (max-width: 640px) { .hc-stats { gap: 18px; } }
/* Two Doors (two-doors): near-black stage, one assumption, two buttons. */
.td { background: #0B100E; color: #E8ECE9; min-height: 72vh; display: flex; align-items: center; }
.td-wrap { max-width: 720px; margin: 0 auto; padding: 64px 22px; text-align: center; }
.td-eyebrow { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: #6e7a73; }
.td-h1 { font-size: clamp(30px, 6vw, 54px); color: #fff; letter-spacing: -0.02em; margin: 14px 0 10px; }
.td-sub { font-size: 16px; color: #93a09a; margin: 0 0 30px; }
.td-sub b { color: #ff8a73; }
.td-doors { display: flex; gap: 16px; justify-content: center; }
.td-door { flex: 1; max-width: 280px; border-radius: 18px; padding: 24px 18px; font-size: 19px; font-weight: 800;
  cursor: pointer; text-decoration: none; display: inline-block; box-sizing: border-box; border: 0; font-family: inherit; }
.td-keep { background: #161D19; color: #7d8a83; border: 1px solid #242E28; transition: background .15s ease; }
.td-keep:hover { background: #101512; }
.td-stop { background: #00D46E; color: #04342C; box-shadow: 0 16px 44px rgba(0,212,110,.25); transition: transform .15s ease; }
.td-stop:hover { transform: translateY(-2px); }
.td-stop.td-pulse { animation: tdpulse 1.6s infinite; }
@keyframes tdpulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.04); } }
.td-reaction { min-height: 52px; font-size: 16px; color: #ff8a73; margin: 22px 0 6px; font-variant-numeric: tabular-nums; }
.td-reaction b { color: #ff6b57; }
.td-fine { font-size: 11px; color: #5d6862; max-width: 560px; margin: 18px auto 0; }
@media (max-width: 560px) { .td-doors { flex-direction: column; align-items: center; } .td-door { width: 100%; max-width: 340px; } }
@media (max-width: 860px) {
  /* Mobile: the CTA stays above the fold — button right under the sub, sliders + readout
     directly below it (desktop keeps set-sliders -> see-savings -> button). */
  .card-has-calc { display: flex; flex-direction: column; }
  .card-has-calc h2 { order: 1; } .card-has-calc .sub { order: 2; }
  .card-has-calc .preapp-cta { order: 3; } .card-has-calc .under-cta { order: 4; }
  .card-has-calc .calc { order: 5; margin-top: 14px; } .card-has-calc .card-save { order: 6; }
  .card-has-calc .bvr-trust { order: 7; } .card-has-calc .fineprint { order: 8; }
}
.calc h2 { margin: 0 0 18px; font-size: 22px; }
.calc .row { margin-bottom: 20px; }
.calc .row label { display: flex; justify-content: space-between; font-weight: 700; font-size: 14px; margin-bottom: 8px; }
.calc .row label b { color: var(--green); }
.calc input[type=range] { width: 100%; accent-color: var(--green); }
.result { background: linear-gradient(160deg, var(--green-soft), #f2faf5); border-radius: var(--radius);
  padding: 24px; text-align: center; }
.result .save { font-size: 44px; font-weight: 900; color: var(--green); letter-spacing: -0.03em; line-height: 1; }
.result .per { color: var(--muted); font-weight: 700; }
.result .sub { color: var(--muted); font-size: 14px; margin-top: 10px; }
.result .pay { font-size: 22px; font-weight: 800; margin-top: 6px; }
.cardstack { aspect-ratio: 5/3; border-radius: 18px; background: linear-gradient(135deg, #1c2c46, #324a73);
  position: relative; box-shadow: var(--shadow); overflow: hidden; }
.cardstack .badge { position: absolute; top: 18px; right: 18px; background: #fff; color: #b00020;
  border: 2px solid #b00020; border-radius: 10px; padding: 8px 12px; font-weight: 800; transform: rotate(8deg); text-align: center; }
.cardstack .badge small { display: block; color: var(--muted); font-weight: 600; }
.calc-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 24px; align-items: start; }

/* check icon + footer + demo variant switcher */
.chk { flex: 0 0 auto; width: 22px; height: 22px; border-radius: 50%; background: var(--green); color: #fff;
  display: inline-flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 900; margin-top: 1px; }
.betsy-mini .chk, .betsy-card .chk { background: var(--purple); }
.lp-footer { background: var(--panel); border-top: 1px solid var(--line); margin-top: 30px; }
.variant-switch { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; justify-content: center;
  padding: 16px 22px; font-size: 12px; color: var(--muted); }
.variant-switch b { color: var(--ink); }
.variant-switch a { color: var(--green); text-decoration: none; }
.variant-switch a:hover { text-decoration: underline; }
.variant-switch .tag { background: #fff5d6; color: #8a6d00; border-radius: 6px; padding: 2px 8px; font-weight: 700; }

@media (max-width: 860px) {
  .calc-grid { grid-template-columns: 1fr; }
  .cards3, .steps { grid-template-columns: 1fr; }
  .equity { grid-template-columns: 1fr; }
  .equity .op { transform: rotate(90deg); }
  .hero-art { order: -1; }
  /* Mobile hero order: lede -> form (CTA above the fold) -> checks/benefits below the
     input box (standup 06-10). display:contents flattens .hero-text so its two halves
     can be ordered around the form column. */
  .hero-grid { display: flex; flex-direction: column; gap: 22px; }
  .hero-text { display: contents; }
  .hero-lede { order: 1; }
  .hero-form-col { order: 2; }
  .hero-supports { order: 3; }
  /* No images on mobile at all (standup 06-10) — they push the CTA down and read as
     filler on a 360px screen. Desktop keeps them. */
  .hero-person-fig, .hero-person-section, .hero-supports img { display: none; }
}

/* ===== Better vs Rocket interactive LP (.bvr-*) — scoped, no global bleed ===== */
.bvr { --bvr-rocket: #b33a3a; --bvr-page: #FAFAF7; --bvr-tint: #E6F4EE;
  background: var(--bvr-page); padding: 0; }
.bvr-wrap { padding-top: 26px; padding-bottom: 28px; max-width: 1240px; }
.bvr-head { text-align: center; max-width: 880px; margin: 0 auto; }
.bvr-eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 700;
  color: var(--green); background: var(--green-soft); border-radius: 999px; padding: 6px 13px; margin-bottom: 14px; }
.bvr-eyebrow b { color: var(--green-dark); }
.bvr h1 { font-size: clamp(26px, 3.6vw, 46px); line-height: 1.06; letter-spacing: -0.025em; margin: 0 auto; max-width: 16ch; }
.bvr h1 .hl { color: var(--green); }
@media (min-width: 981px) { .bvr h1 { max-width: 24ch; } }
.bvr-sub { font-size: clamp(14px, 1.4vw, 17px); color: var(--muted); max-width: 52ch; margin: 14px auto 0; }
.bvr-sub strong { color: var(--ink); font-weight: 700; }
.bvr-note { text-align: center; font-size: 11px; color: var(--muted); margin: 7px auto 0; letter-spacing: .02em; }

/* split: chart 2/3, form 1/3 */
.bvr-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 26px; align-items: start; margin-top: 26px; }
.bvr-card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: 0 2px 14px rgba(16,35,27,0.05); padding: 18px 20px; }

/* chart card */
.bvr-chart-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 8px; }
.bvr-chart-head h3 { margin: 0; font-size: 19px; letter-spacing: -0.01em; }
.bvr-chart-head p { margin: 3px 0 0; font-size: 12px; color: var(--muted); }
.bvr-legend { display: flex; gap: 16px; font-size: 12px; color: var(--muted); font-weight: 600; flex: 0 0 auto; }
.bvr-legend span { display: inline-flex; align-items: center; gap: 6px; }
.bvr-dot { width: 12px; height: 3px; border-radius: 999px; display: inline-block; }
.bvr-dot-better { background: var(--green); }
.bvr-dot-rocket { background: var(--bvr-rocket); }
.bvr-chart { width: 100%; }
.bvr-chart svg { width: 100%; height: auto; display: block; }
.bvr-axis { fill: #6B6B6B; font-size: 13px; }
.bvr-grid-line { stroke: #E8E6E0; stroke-dasharray: 3 3; }
.bvr-ref-line { stroke: #B0AFA8; stroke-dasharray: 3 3; }
.bvr-anno { fill: #1A1A1A; font-size: 17px; font-weight: 800; }
.bvr-anno-bg { fill: #ffffff; opacity: 0.9; }
.bvr-end-better { fill: var(--green); font-size: 21px; font-weight: 900; }
.bvr-end-rocket { fill: var(--bvr-rocket); font-size: 21px; font-weight: 900; }
.bvr-end-cap { font-size: 11px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; }
@media (max-width: 640px) {
  .bvr-axis, .om-axis { font-size: 14px; }
  .bvr-anno, .om-anno { font-size: 15px; font-weight: 700; }
  .bvr-end-better, .bvr-end-rocket, .om-end-better, .om-end-comp { font-size: 14px; font-weight: 700; }
  .bvr-end-cap, .om-end-cap { font-size: 12px; }
}

/* form card */
.bvr-form-card h2 { margin: 0 0 4px; font-size: 20px; letter-spacing: -0.01em; }
.bvr-form-card .sub { color: var(--muted); font-size: 13px; margin: 0 0 16px; }
.bvr-center { justify-content: center; text-align: center; }
.bvr-customize { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--line); }
.bvr-customize-toggle { width: 100%; display: flex; align-items: center; justify-content: space-between;
  background: none; border: 0; padding: 0; cursor: pointer; font-size: 14px; font-weight: 600; color: var(--muted); font-family: inherit; }
.bvr-customize-toggle:hover { color: var(--ink); }
.bvr-chevron { transition: transform .15s ease; font-size: 12px; }
.bvr-customize-toggle[aria-expanded="true"] .bvr-chevron { transform: rotate(180deg); }
.bvr-customize-panel { margin-top: 12px; }
.bvr-slider-row { display: flex; align-items: center; justify-content: space-between; font-size: 12px; color: var(--muted); margin-bottom: 8px; }
.bvr-slider-row b { color: var(--ink); }
.bvr-customize-panel input[type=range] { width: 100%; accent-color: var(--green); }
.bvr-slider-ends { display: flex; justify-content: space-between; font-size: 10px; color: rgba(16,35,27,0.4); margin-top: 4px; }

/* press / trust / testimonial (right column, below form) */
.bvr-press { text-align: center; margin-top: 22px; }
.bvr-press-cap { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: 0.16em; color: rgba(16,35,27,0.45); font-weight: 600; margin-bottom: 6px; }
.bvr-press-logos { margin: 0; font-size: 15px; font-weight: 700; color: rgba(16,35,27,0.7); letter-spacing: -0.01em; }
.bvr-press-logos i, .bvr-trust i { color: rgba(16,35,27,0.3); font-style: normal; margin: 0 4px; }
.bvr-trust { text-align: center; font-size: 12px; color: var(--muted); margin: 18px auto 0; line-height: 1.6; max-width: 40ch; }
.bvr-trust b { color: var(--ink); }
.bvr-stars { color: #e0a800; letter-spacing: 1px; }
.bvr-testimonial { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: 0 2px 14px rgba(16,35,27,0.05); padding: 18px 20px; margin: 18px 0 0; }
.bvr-testimonial blockquote { margin: 8px 0 0; font-size: 15px; line-height: 1.5; color: var(--ink); }
.bvr-testimonial blockquote b { color: var(--green); }
.bvr-testimonial figcaption { margin-top: 12px; font-size: 13px; color: var(--muted); }
.bvr-testimonial figcaption b { color: rgba(16,35,27,0.75); font-weight: 600; }

.bvr-disclaimer { font-size: 11px; color: var(--muted); text-align: center; max-width: var(--legal-w); margin: 24px auto 0; line-height: 1.55; }

/* sticky mobile CTA */
.bvr-sticky-cta { display: none; }

@media (max-width: 980px) {
  .bvr-grid { grid-template-columns: 1fr; }
}
@media (max-width: 860px) {
  .bvr-wrap { padding-bottom: 96px; }
  .bvr-chart-head { flex-direction: column; }
  .bvr-sticky-cta { display: flex; align-items: center; justify-content: center; gap: 8px;
    position: fixed; left: 12px; right: 12px; bottom: 12px; z-index: 40;
    background: var(--green); color: #fff; font-weight: 700; font-size: 16px; text-decoration: none;
    padding: 14px 18px; border-radius: 12px; box-shadow: 0 4px 16px rgba(1,120,72,0.28); }
  .bvr-sticky-cta:hover { background: var(--green-dark); }
}
@media (prefers-reduced-motion: reduce) { .bvr-chevron { transition: none; } }

/* ===== Paste-your-quote Rate-Buster LP (.rb-*). Scoped, no global bleed ===== */
.rb { --rb-them: #b33a3a; --rb-page: #FAFAF7; background: var(--rb-page); padding: 0; }
.rb-wrap { padding-top: 26px; padding-bottom: 28px; max-width: 1240px; }
.rb-head { text-align: center; max-width: 880px; margin: 0 auto; }
.rb-eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 700;
  color: var(--green); background: var(--green-soft); border-radius: 999px; padding: 6px 13px; margin-bottom: 14px; }
.rb-eyebrow b { color: var(--green-dark); }
.rb h1 { font-size: clamp(28px, 4vw, 48px); line-height: 1.05; letter-spacing: -0.025em; margin: 0 auto; max-width: 18ch; }
.rb h1 .hl { color: var(--green); }
.rb-sub { font-size: clamp(14px, 1.4vw, 17px); color: var(--muted); max-width: 50ch; margin: 14px auto 0; }
.rb-sub strong { color: var(--ink); font-weight: 700; }

/* split: work column 2/3, form 1/3 */
.rb-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 26px; align-items: start; margin-top: 26px; }
.rb-work-col { display: grid; gap: 18px; }
.rb-card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: 0 2px 14px rgba(16,35,27,0.05); padding: 18px 20px; }

/* input card */
.rb-input-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.rb-input-row.rb-solo { grid-template-columns: 1fr; }
.rb-field label { display: block; font-size: 13px; font-weight: 700; margin-bottom: 6px; }
.rb-field select, .rb-rate-input input { width: 100%; padding: 13px 14px; border: 1px solid var(--line);
  border-radius: 10px; font-size: 16px; background: #fcfdfc; font-family: inherit; color: var(--ink); }
.rb-field select { appearance: none; -webkit-appearance: none; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%235f615c' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }
.rb-field select:focus, .rb-rate-input input:focus { outline: 2px solid var(--green); border-color: var(--green); }
.rb-rate-input { position: relative; }
.rb-pct { position: absolute; right: 14px; top: 50%; transform: translateY(-50%); color: var(--muted); font-weight: 700; font-size: 15px; pointer-events: none; }
.rb-rate-input input { padding-right: 32px; }
.rb-slider-block { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--line); }
.rb-slider-row { display: flex; align-items: center; justify-content: space-between; font-size: 12px; color: var(--muted); margin-bottom: 8px; }
.rb-slider-row b { color: var(--ink); }
#rb-slider { width: 100%; accent-color: var(--green); }
.rb-slider-ends { display: flex; justify-content: space-between; font-size: 10px; color: rgba(16,35,27,0.4); margin-top: 4px; }

/* result card */
.rb-pays { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.rb-pay { border-radius: 12px; padding: 16px 16px 14px; border: 1px solid var(--line); background: #fcfdfc; }
.rb-pay-them { background: #fdf3f3; border-color: #ecc9c9; }
.rb-pay-us { background: var(--green-soft); border-color: #a7dbbf; }
.rb-pay-lbl { display: block; font-size: 12px; font-weight: 600; color: var(--muted); margin-bottom: 4px; }
.rb-pay-them .rb-pay-lbl b { color: var(--rb-them); font-weight: 700; }
.rb-pay-us .rb-pay-lbl { color: var(--green-dark); }
.rb-pay-amt { font-size: clamp(28px, 4vw, 38px); font-weight: 900; letter-spacing: -0.03em; line-height: 1; }
.rb-pay-them .rb-pay-amt { color: var(--rb-them); }
.rb-pay-us .rb-pay-amt { color: var(--green); }
.rb-pay-unit { font-size: 14px; font-weight: 700; color: var(--muted); margin-left: 3px; }
.rb-strip { margin-top: 14px; background: var(--green); color: #fff; border-radius: 10px; padding: 12px 16px;
  font-size: clamp(14px, 1.5vw, 16px); font-weight: 600; text-align: center; }
.rb-strip b { font-weight: 900; }

/* chart card */
.rb-chart-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 8px; }
.rb-chart-head h3 { margin: 0; font-size: 15px; letter-spacing: -0.01em; }
.rb-chart-head p { margin: 3px 0 0; font-size: 12px; color: var(--muted); }
.rb-legend { display: flex; gap: 16px; font-size: 12px; color: var(--muted); font-weight: 600; flex: 0 0 auto; }
.rb-legend span { display: inline-flex; align-items: center; gap: 6px; }
.rb-dot { width: 12px; height: 3px; border-radius: 999px; display: inline-block; }
.rb-dot-better { background: var(--green); }
.rb-dot-them { background: var(--rb-them); }
.rb-chart { width: 100%; }
.rb-chart svg { width: 100%; height: auto; display: block; }
.rb-axis { fill: #6B6B6B; font-size: 11px; }
.rb-grid-line { stroke: #E8E6E0; stroke-dasharray: 3 3; }
.rb-anno { fill: #1A1A1A; font-size: 12px; font-weight: 600; }
.rb-anno-bg { fill: #ffffff; opacity: 0.82; }
.rb-end-better { fill: var(--green); font-size: 12px; font-weight: 700; }
.rb-end-them { fill: var(--rb-them); font-size: 12px; font-weight: 700; }
.rb-end-cap { font-size: 10px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; }

/* form card */
.rb-form-card h2 { margin: 0 0 4px; font-size: 20px; letter-spacing: -0.01em; }
.rb-form-card .sub { color: var(--muted); font-size: 13px; margin: 0 0 16px; }
.rb-center { justify-content: center; text-align: center; }

/* press / trust (right column, below form) */
.rb-press { text-align: center; margin-top: 22px; }
.rb-press-cap { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: 0.16em; color: rgba(16,35,27,0.45); font-weight: 600; margin-bottom: 6px; }
.rb-press-logos { margin: 0; font-size: 15px; font-weight: 700; color: rgba(16,35,27,0.7); letter-spacing: -0.01em; }
.rb-press-logos i, .rb-trust i { color: rgba(16,35,27,0.3); font-style: normal; margin: 0 4px; }
.rb-trust { text-align: center; font-size: 12px; color: var(--muted); margin: 18px auto 0; line-height: 1.6; max-width: 40ch; }
.rb-trust b { color: var(--ink); }
.rb-stars { color: #e0a800; letter-spacing: 1px; }

.rb-disclaimer { font-size: 11px; color: var(--muted); text-align: center; max-width: var(--legal-w); margin: 24px auto 0; line-height: 1.55; }

/* sticky mobile CTA */
.rb-sticky-cta { display: none; }

@media (max-width: 980px) {
  .rb-grid { grid-template-columns: 1fr; }
}
@media (max-width: 860px) {
  .rb-wrap { padding-bottom: 96px; }
  .rb-chart-head { flex-direction: column; }
  .rb-input-row { grid-template-columns: 1fr; }
  .rb-sticky-cta { display: flex; align-items: center; justify-content: center; gap: 8px;
    position: fixed; left: 12px; right: 12px; bottom: 12px; z-index: 40;
    background: var(--green); color: #fff; font-weight: 700; font-size: 16px; text-decoration: none;
    padding: 14px 18px; border-radius: 12px; box-shadow: 0 4px 16px rgba(1,120,72,0.28); }
  .rb-sticky-cta:hover { background: var(--green-dark); }
}
@media (max-width: 520px) {
  .rb-pays { grid-template-columns: 1fr; }
}
/* ===== Overpayment Meter conquest LP (.om-*) — scoped, no global bleed ===== */
.om { --om-comp: #b33a3a; background: var(--panel); }

/* dark hero: the meter glows here */
.om-hero { background: radial-gradient(1100px 520px at 50% -8%, #16314a 0%, var(--navy) 58%, #0a1525 100%); color: #eaf3ee; }
.om-hero-wrap { padding: 46px 22px 40px; text-align: center; }
.om-eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 700;
  color: #bfe8d3; background: rgba(1,120,72,0.20); border: 1px solid rgba(1,120,72,0.45);
  border-radius: 999px; padding: 6px 13px; margin-bottom: 18px; letter-spacing: .02em; }
.om-eyebrow b { color: #fff; }
.om-dot { width: 8px; height: 8px; border-radius: 50%; background: #2fd07e; box-shadow: 0 0 0 0 rgba(47,208,126,.5); animation: omPulse 1.8s infinite; }
@keyframes omPulse { 0% { box-shadow: 0 0 0 0 rgba(47,208,126,.5); } 70% { box-shadow: 0 0 0 9px rgba(47,208,126,0); } 100% { box-shadow: 0 0 0 0 rgba(47,208,126,0); } }
.om-headline { font-size: clamp(28px, 4.4vw, 50px); line-height: 1.04; letter-spacing: -0.03em;
  margin: 0 auto; max-width: 18ch; color: #fff; }

/* the meter (centerpiece) */
.om-meter { margin: 30px auto 0; max-width: 640px; }
.om-meter-cap { font-size: 13px; font-weight: 600; color: rgba(234,243,238,0.62); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 10px; }
.om-counter { font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;
  font-size: clamp(54px, 12vw, 116px); line-height: 1; font-weight: 700; letter-spacing: -0.02em;
  color: #2fd07e; text-shadow: 0 0 28px rgba(47,208,126,0.55), 0 0 4px rgba(47,208,126,0.45);
  font-variant-numeric: tabular-nums; }
.om-meter-sub { font-size: clamp(14px, 1.5vw, 17px); color: rgba(234,243,238,0.80); max-width: 44ch; margin: 16px auto 0; }
.om-meter-sub b { color: #fff; }

/* CTA pinned right under the meter */
.om-cta { max-width: 460px; margin: 26px auto 0; }
.om-form { text-align: left; }
.om-field { margin-bottom: 12px; }
.om-field label { display: block; font-size: 13px; font-weight: 700; margin-bottom: 6px; color: rgba(234,243,238,0.88); }
.om-field input { width: 100%; padding: 14px 14px; border: 1px solid rgba(234,243,238,0.22); border-radius: 10px;
  font-size: 16px; background: rgba(255,255,255,0.06); color: #fff; }
.om-field input::placeholder { color: rgba(234,243,238,0.45); }
.om-field input:focus { outline: 2px solid #2fd07e; border-color: #2fd07e; background: rgba(255,255,255,0.10); }
.om-btn { width: 100%; font-size: 17px; padding: 16px 22px; }
.om-risk { color: rgba(234,243,238,0.66); font-size: 12px; margin: 12px 0 0; text-align: center; }
.om-success { display: none; text-align: center; padding: 26px 10px; color: #eaf3ee; }
.om-success.show { display: block; }
.om-success .tick { width: 56px; height: 56px; border-radius: 50%; background: rgba(1,120,72,0.25);
  color: #2fd07e; display: inline-flex; align-items: center; justify-content: center; margin-bottom: 14px; font-size: 26px; }
.om-success h2 { margin: 0 0 8px; color: #fff; }
.om-success .sub { color: rgba(234,243,238,0.80); font-size: 14px; }
.om-success b { color: #fff; }

/* loan slider rescales the meter */
.om-slider-wrap { margin: 22px auto 0; max-width: 420px; padding-top: 18px; border-top: 1px solid rgba(234,243,238,0.14); }
.om-slider-row { display: flex; align-items: center; justify-content: space-between; font-size: 13px; color: rgba(234,243,238,0.66); margin-bottom: 8px; }
.om-slider-row b { color: #fff; }
.om-slider-wrap input[type=range] { width: 100%; accent-color: #2fd07e; }
.om-slider-ends { display: flex; justify-content: space-between; font-size: 11px; color: rgba(234,243,238,0.40); margin-top: 4px; }

/* below the meter: the chart on the page brand */
.om-body { padding-top: 34px; padding-bottom: 34px; max-width: 980px; }
.om-card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: 0 2px 14px rgba(16,35,27,0.05); padding: 20px 22px; }
.om-chart-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 10px; }
.om-chart-head h3 { margin: 0; font-size: 16px; letter-spacing: -0.01em; }
.om-chart-head p { margin: 3px 0 0; font-size: 12px; color: var(--muted); }
.om-legend { display: flex; gap: 16px; font-size: 12px; color: var(--muted); font-weight: 600; flex: 0 0 auto; }
.om-legend span { display: inline-flex; align-items: center; gap: 6px; }
.om-leg { width: 12px; height: 3px; border-radius: 999px; display: inline-block; }
.om-leg-better { background: var(--green); }
.om-leg-comp { background: var(--om-comp); }
.om-chart { width: 100%; }
.om-chart svg { width: 100%; height: auto; display: block; }
.om-axis { fill: #6B6B6B; font-size: 11px; }
.om-grid-line { stroke: #E8E6E0; stroke-dasharray: 3 3; }
.om-ref-line { stroke: #B0AFA8; stroke-dasharray: 3 3; }
.om-anno { fill: #1A1A1A; font-size: 12px; font-weight: 600; }
.om-anno-bg { fill: #ffffff; opacity: 0.82; }
.om-end-better { fill: var(--green); font-size: 12px; font-weight: 700; }
.om-end-comp { fill: var(--om-comp); font-size: 12px; font-weight: 700; }
.om-end-cap { font-size: 10px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; }
.om-chart-line { margin: 12px 0 0; font-size: 14px; font-weight: 600; color: var(--ink); text-align: center; }
.om-chart-line b { color: var(--green); }

/* press / trust / disclaimer */
.om-press { text-align: center; margin-top: 26px; }
.om-press-cap { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: 0.16em; color: rgba(16,35,27,0.45); font-weight: 600; margin-bottom: 6px; }
.om-press-logos { margin: 0; font-size: 15px; font-weight: 700; color: rgba(16,35,27,0.7); letter-spacing: -0.01em; }
.om-press-logos i, .om-trust i { color: rgba(16,35,27,0.3); font-style: normal; margin: 0 4px; }
.om-trust { text-align: center; font-size: 12px; color: var(--muted); margin: 18px auto 0; line-height: 1.6; max-width: 44ch; }
.om-trust b { color: var(--ink); }
.om-stars { color: #e0a800; letter-spacing: 1px; }
.om-disclaimer { font-size: 11px; color: var(--muted); text-align: center; max-width: var(--legal-w); margin: 24px auto 0; line-height: 1.55; }

/* sticky mobile CTA */
.om-sticky-cta { display: none; }
@media (max-width: 860px) {
  .om-body { padding-bottom: 96px; }
  .om-chart-head { flex-direction: column; }
  .om-sticky-cta { display: flex; align-items: center; justify-content: center; gap: 8px;
    position: fixed; left: 12px; right: 12px; bottom: 12px; z-index: 40;
    background: var(--green); color: #fff; font-weight: 700; font-size: 16px; text-decoration: none;
    padding: 14px 18px; border-radius: 12px; box-shadow: 0 4px 16px rgba(1,120,72,0.28); }
  .om-sticky-cta:hover { background: var(--green-dark); }
}
@media (prefers-reduced-motion: reduce) { .om-dot { animation: none; } }

/* Analysis-doc improvements: equity cue, FAQ, HELOC-vs-HELoan, article link */
.equity-cue { margin: 4px 0 12px; font-size: 14px; font-weight: 700; color: var(--green-dark); }
/* Rate-offer badge: rate + APR shown at EQUAL prominence (TILA), points disclosed. */
.rate-badge { margin: 12px 0 14px; padding: 12px 16px; background: var(--green-soft, #e8f3ec); border: 1px solid var(--line, #dfe5e1); border-radius: 10px; }
.rate-badge-nums { display: flex; flex-wrap: wrap; align-items: baseline; gap: 16px; }
.rate-badge-rate b, .rate-badge-apr b { font-size: 30px; line-height: 1; color: var(--green-dark); }
.rate-badge-rate, .rate-badge-apr { font-size: 14px; color: var(--ink, #1a2b22); font-weight: 600; }
.rate-badge-note { margin: 8px 0 0; font-size: 11px; line-height: 1.5; color: var(--muted); }
/* faq + heloan inherit the global main>section 56px rhythm (no tight override) */
.section-head .sub { color: var(--muted); font-size: 15px; margin: 6px 0 0; max-width: 60ch; }
.faq { max-width: 760px; margin: 14px auto 0; }
.faq details { border: 1px solid var(--line); border-radius: 10px; background: #fff; margin: 8px 0; }
.faq summary { cursor: pointer; padding: 14px 16px; font-weight: 700; font-size: 15px; list-style: none; position: relative; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary .faq-q { display: inline; margin: 0; font-size: inherit; font-weight: inherit; line-height: inherit; color: inherit; }
.faq summary::after { content: "+"; position: absolute; right: 16px; top: 12px; color: var(--green); font-size: 20px; font-weight: 700; }
.faq details[open] summary::after { content: "\2212"; }
.faq details p { margin: 0; padding: 0 16px 16px; color: var(--muted); font-size: 14.5px; line-height: 1.55; }
.faq-article { max-width: 760px; margin: 14px auto 0; font-weight: 700; }
.cmp-wrap { max-width: 760px; margin: 16px auto 0; overflow-x: auto; }
table.cmp { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
table.cmp th, table.cmp td { padding: 12px 14px; text-align: left; border-bottom: 1px solid var(--line); font-size: 14px; vertical-align: top; }
table.cmp thead th { font-size: 12px; text-transform: uppercase; letter-spacing: .03em; color: var(--muted); background: var(--green-soft); }
table.cmp td:first-child, table.cmp th:first-child { color: var(--muted); font-weight: 600; width: 150px; }
table.cmp tr:last-child td { border-bottom: 0; }
table.cmp .cmp-pick { font-weight: 800; color: var(--green-dark); background: rgba(1,120,72,.10); font-size: 15px; }
table.cmp thead th.cmp-pick { color: var(--green-dark); background: var(--green-soft); }
table.cmp thead th.cmp-pick span { display: block; font-size: 10px; font-weight: 800; color: var(--green); text-transform: uppercase; letter-spacing: .04em; }
/* Compare page: table 2/3 + form 1/3 (Gonz 06-10, like the savings calc). */
.cmp-hero { padding: 40px 0 48px; }
.cmp-head { text-align: center; max-width: 760px; margin: 0 auto 28px; }
.cmp-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 34px; align-items: start; }
.cmp-aside .card { position: sticky; top: 20px; }
@media (max-width: 860px) {
  .cmp-grid { grid-template-columns: 1fr; gap: 24px; }
  .cmp-aside { order: -1; }            /* form above the table on mobile -> CTA above fold */
  .cmp-aside .card { position: static; }
}
.cmp-note { max-width: var(--legal-w); margin: 10px auto 0; font-size: 12px; color: var(--muted); }
.cmp-note a { color: var(--green-dark); }
.cmp-catch { max-width: 760px; margin: 14px auto 0; padding: 12px 16px; background: var(--green-soft); border: 1px solid var(--line); border-radius: 10px; font-size: 14px; color: var(--ink); }
.cmp-catch b { color: var(--green-dark); }
.speed-line { margin: 0 0 10px; font-size: 15px; font-weight: 800; color: var(--green-dark); }
/* Rate-battle hero (Better vs competitor): two fighters, one obvious winner. */
.battle { display: flex; align-items: stretch; justify-content: center; gap: 14px; margin: 26px auto 8px; max-width: 640px; }
.fighter { flex: 1; border-radius: 16px; padding: 22px 16px 18px; text-align: center; }
.fighter .f-name { font-size: 13px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; }
.fighter .f-rate { font-size: clamp(42px, 6vw, 58px); font-weight: 900; letter-spacing: -0.03em; line-height: 1.05; margin: 6px 0 2px; }
.fighter .f-sub { font-size: 13px; margin: 10px 0 0; line-height: 1.55; }
.fighter .f-yes { color: var(--green); font-weight: 800; }
.fighter .f-no { color: #b33a3a; font-weight: 800; }
.fighter.f-win { background: var(--green-soft); border: 2px solid var(--green); color: var(--green-dark);
  box-shadow: 0 16px 38px rgba(1,120,72,.16); position: relative; }
.fighter.f-win .f-rate { color: var(--green); }
.fighter.f-win .f-tag { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); white-space: nowrap;
  background: var(--green); color: #fff; font-size: 11px; font-weight: 800; letter-spacing: .04em;
  text-transform: uppercase; border-radius: 999px; padding: 3px 12px; }
.fighter.f-lose { background: #f1f0ec; border: 1px solid var(--line); color: #848985; }
.fighter.f-lose .f-name, .fighter.f-lose .f-rate { color: #9aa09b; }
.fighter .f-cap { font-size: 12px; font-weight: 700; margin: 0; }
.fighter.f-lose .f-cap { color: #9aa09b; }
.battle-vs { align-self: center; font-weight: 900; font-size: 17px; color: var(--muted); flex: 0 0 auto; }
.battle-rateline { font-size: 13px; color: var(--ink); max-width: 640px; margin: 12px auto 0; }
.battle-note { font-size: 11px; color: var(--muted); max-width: 640px; margin: 8px auto 0; }
@media (max-width: 640px) { .battle { gap: 8px; } .fighter { padding: 16px 8px 14px; } .battle-vs { font-size: 14px; } }
.lp-disclaimer-section { padding: 6px 0 18px; }
.lp-disclaimer { max-width: var(--legal-w); margin: 0 auto 6px; font-size: 11.5px; line-height: 1.5; color: var(--muted); }
.lp-consent { max-width: var(--legal-w); margin: 0 auto 8px; font-size: 11px; line-height: 1.55; color: var(--muted); }
.lp-disclaimer sup { color: var(--green-dark); font-weight: 700; }
.claims-strip { display: flex; flex-wrap: wrap; gap: 8px; margin: 12px 0 2px; }
.claim-chip { display: inline-flex; align-items: flex-start; gap: 6px; font-size: 13px; font-weight: 700;
  color: var(--green-dark); background: var(--green-soft); border: 1px solid var(--line); border-radius: 999px; padding: 5px 12px; }
.claim-chip .claim-tick { color: var(--green); }
.claim-chip sup { font-weight: 600; color: var(--muted); }
/* ratecompare inherits the global main>section 56px rhythm */
.rc2-wrap { max-width: 720px; margin: 16px auto 0; overflow-x: auto; }
table.rc2 { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
table.rc2 th, table.rc2 td { padding: 13px 16px; text-align: left; border-bottom: 1px solid var(--line); font-size: 15px; }
table.rc2 thead th { font-size: 13px; text-transform: uppercase; letter-spacing: .03em; color: var(--muted); background: var(--green-soft); }
table.rc2 td:first-child { color: var(--muted); font-weight: 600; }
table.rc2 tr:last-child td { border-bottom: 0; }
table.rc2 .rc2-better { font-weight: 800; color: var(--green-dark); background: rgba(1,120,72,.05); }
table.rc2 thead th.rc2-better { color: var(--green-dark); background: var(--green-soft); }
.rc2-note { max-width: 720px; margin: 10px auto 0; font-size: 12px; color: var(--muted); }
/* articles inherit the global main>section 56px rhythm */
.articles-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin: 16px 0 0; }
.article-card { display: block; background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 18px 20px; text-decoration: none; color: var(--ink); transition: border-color .12s ease, box-shadow .12s ease; }
.article-card:hover { border-color: var(--green); box-shadow: 0 8px 24px rgba(16,35,27,.08); }
.article-read { display: inline-block; font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; color: var(--green-dark); background: var(--green-soft); padding: 3px 9px; border-radius: 999px; }
.article-card strong { display: block; margin: 10px 0 8px; font-size: 16px; line-height: 1.3; }
.article-more { font-size: 13px; font-weight: 700; color: var(--green-dark); }
@media (max-width: 640px) { .articles-grid { grid-template-columns: 1fr; } }
.hero-person { display: block; width: 100%; height: auto; max-height: 280px; object-fit: cover; object-position: center 28%;
  border-radius: 14px; margin: 18px 0 0; box-shadow: 0 1px 2px rgba(16,35,27,.05), 0 12px 30px rgba(16,35,27,.10); }
.hero-person-fig { margin: 0; }
/* Floating AI hero images removed on ALL views (standup 06-10): they read as out-of-place
   filler "mid-page" on desktop and push the CTA down on mobile. Humanity now comes from the
   real customer testimonial video (above the reviews) + the Trustpilot review faces. Keep the
   markup so we can swap in a proper hero treatment (background or real photo) later. */
.hero-person-fig, .hero-person-section { display: none !important; }
.ai-tag { display: block; font-size: 11px; color: var(--muted); opacity: .75; margin: 6px 0 0; font-style: italic; }
/* Honest comparison bar charts (savings on the 5.75 page; upfront cost on Figure/SoFi).
   Better always wins the dimension shown. Pure CSS — no JS, works in the static build. */
.lp-chart-section { padding: 44px 0; }
.barchart { max-width: 600px; margin: 8px auto 0; display: grid; gap: 16px; }
.bar-row { display: grid; grid-template-columns: 150px 1fr; align-items: center; gap: 12px; }
.bar-name { font-size: 13px; font-weight: 700; color: var(--ink); text-align: right; }
.bar-track { background: #eef2ef; border-radius: 10px; height: 40px; position: relative; overflow: hidden; }
.bar-fill { display: flex; align-items: center; justify-content: flex-end; height: 100%;
  padding: 0 14px; border-radius: 10px; color: #fff; font-weight: 800; font-size: 14px; white-space: nowrap;
  min-width: 56px; box-sizing: border-box; }
.bar-win { background: var(--green); }
.bar-them { background: #b33a3a; }
.bar-zero { width: 64px; justify-content: center; padding: 0; }
.chart-delta { text-align: center; font-size: 17px; margin: 20px 0 0; color: var(--ink); }
@media (max-width: 560px) {
  .bar-row { grid-template-columns: 1fr; gap: 4px; }
  .bar-name { text-align: left; }
}
/* Real-customer video testimonial (full-width, above the reviews). */
.lp-video-section { padding: 40px 0; }
/* Video sits in a card so it reads as a contained example (Gonz 06-10). */
.lp-video { margin: 0 auto; max-width: 760px; background: #fff; border: 1px solid var(--line);
  border-radius: 18px; padding: 16px; box-shadow: 0 1px 2px rgba(16,35,27,.05), 0 12px 30px rgba(16,35,27,.08); }
.lp-video video { width: 100%; aspect-ratio: 16 / 9; background: #000; border-radius: 16px;
  box-shadow: 0 1px 2px rgba(16,35,27,.05), 0 16px 40px rgba(16,35,27,.14); display: block; }
.lp-video figcaption { text-align: center; font-size: 13px; color: var(--muted); margin: 10px 0 0; }
@media (max-width: 640px) { .lp-video video { aspect-ratio: 4 / 5; } }
/* reviews inherit the global main>section 56px rhythm */
.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin: 16px 0 0; }
.review { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 18px 20px; }
.review-stars { color: #e7a400; font-size: 16px; letter-spacing: 1px; }
.review-text { margin: 10px 0 12px; font-size: 14px; line-height: 1.55; color: var(--ink); }
.review-name { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 700; color: var(--muted); }
.review-ava { font-size: 18px; }
@media (max-width: 760px) { .reviews-grid { grid-template-columns: 1fr; } }

/* ===== Better brand skin (Better Sans + warm palette, from better.com) ===== */
/* Font URLs are RELATIVE (resolve against the stylesheet's own directory):
   /lp.css -> /fonts/* and /a/lp.css -> /a/fonts/*. Root-absolute '/fonts/' 404'd on
   the better.com/a proxy (better.com/fonts doesn't exist — found in console 06-12).
   Also safe inlined in doc_css: those pages live at the site root. */
@font-face{font-family:'Better Sans';src:url('fonts/better-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Better Sans';src:url('fonts/better-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Better Sans';src:url('fonts/better-700.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Better Sans';src:url('fonts/better-800.woff2') format('woff2');font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:'Better Sans';src:url('fonts/better-900.woff2') format('woff2');font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:'Better Sans Fallback';src:local('Arial');ascent-override:86.12%;descent-override:19.14%;line-gap-override:19.14%;size-adjust:104.50%}
body,h1,h2,h3,h4,h5,h6,button,input,select,textarea,.btn{font-family:'Better Sans','Better Sans Fallback',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif}
:root{--ink:#292b29;--muted:#5f615c;--line:rgba(41,43,41,.12);--green:#017848;--green-dark:#004733;--green-soft:#eef5ef;--soft:#eef5ef;--bg:#f6f6f3;--panel:#fffdfa}
body{background:#f6f6f3;color:#292b29}
.card,.bvr-card{background:#fffdfa;border-color:rgba(41,43,41,.10)}
.eyebrow,.bvr-eyebrow{background:#eef5ef;color:#004733}
.btn,.btn-green{border-radius:9999px}

/* ===== Bolder "tech, not bank" pass (2026-06-11, Vishal: more color / less bland) ===== */
:root{--green:#019a5c;--green-dark:#015c37;--green-soft:#e6f5ec;--volt:#00d68f;--amber:#ffb020;--ink:#0e1d31;--bg:#f3f7f4}
body{background:var(--bg);color:var(--ink)}
.hero{position:relative;background:radial-gradient(120% 120% at 88% -12%, rgba(0,214,143,.16), transparent 55%), linear-gradient(180deg,#fbfdfb,var(--bg))}
.hero h1,.cmp-head h1,.bvr-head h1{font-weight:900;letter-spacing:-.025em}
.hero .hl,.cmp-head .hl,.bvr-head .hl{background:linear-gradient(90deg,var(--green-dark),var(--volt));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:var(--green)}
.eyebrow,.bvr-eyebrow{background:linear-gradient(90deg,rgba(0,214,143,.18),rgba(1,154,92,.12));color:var(--green-dark);font-weight:850;border:1px solid rgba(1,154,92,.20)}
.card,.bvr-card{box-shadow:0 18px 44px rgba(14,29,49,.10);border-radius:16px}
.btn-green{background:linear-gradient(135deg,#02b06a,#015c37);box-shadow:0 10px 26px rgba(1,140,84,.30);transition:transform .12s,box-shadow .12s,filter .12s}
.btn-green:hover{background:linear-gradient(135deg,#02c074,#016b40);filter:brightness(1.03);transform:translateY(-1px);box-shadow:0 14px 32px rgba(1,140,84,.40)}
.proof-band{background:#0e1d31}
.proof-band .bvr-press-cap{color:var(--volt);font-weight:800}
.proof-band .bvr-press-logos{color:#dfe7ef}

/* ===== Polish pass (Gonz 06-11): Better type reads solid, green hero, sharper proof ===== */
:root{--ink:#292b29;--green:#017848;--green-dark:#004733;--green-soft:#eef5ef;--bg:#f6f6f3}
body{color:var(--ink);background:var(--bg)}
/* The Better face, unobstructed: no gradient-clipped headlines anywhere. */
.hero .hl,.cmp-head .hl,.bvr-head .hl{background:none;-webkit-background-clip:initial;background-clip:initial;-webkit-text-fill-color:currentColor;color:var(--green)}
/* Green hero on the LPs (compare hero stays light); the AI image is gone. */
.hero:not(.cmp-hero){background:radial-gradient(110% 140% at 90% -12%, rgba(0,214,143,.30), transparent 52%),linear-gradient(155deg,#015c3d 0%,#004733 58%,#01392a 100%);border-bottom:0}
.hero:not(.cmp-hero) .hero-bg,.hero:not(.cmp-hero) .hero-ai-tag{display:none}
.hero:not(.cmp-hero) h1{color:#fff}
.hero:not(.cmp-hero) .hl{color:var(--volt)}
.hero:not(.cmp-hero) .lede{color:#cfe8db}
.hero:not(.cmp-hero) .lede strong{color:#fff}
.hero:not(.cmp-hero) .eyebrow{background:rgba(255,255,255,.10);color:#beeeda;border:1px solid rgba(255,255,255,.16)}
.hero:not(.cmp-hero) .checks li{color:#e9f5ee}
.hero:not(.cmp-hero) .chk{color:var(--volt)}
.hero:not(.cmp-hero) .equity-cue{color:#9ccdb6}
.hero:not(.cmp-hero) .speed-line{color:var(--volt)}
.hero:not(.cmp-hero) .card{border:0;box-shadow:0 26px 64px rgba(0,28,18,.38);border-radius:18px}
/* Sharper social proof: gold stars + press wordmarks that read like logos. */
.bvr-stars{color:#ffb020;font-size:15px;letter-spacing:1.5px}
.bvr-press-cap{font-size:10.5px;letter-spacing:.16em;font-weight:800}
.bvr-press-logos{font-size:17px;font-weight:900;letter-spacing:.01em}
.bvr-press-logos .lg-wsj,.bvr-press-logos .lg-forbes{font-family:Georgia,'Times New Roman',serif;font-weight:700}
.bvr-press-logos .lg-fool{font-style:italic}
.bvr-press-logos i{opacity:.45;font-style:normal}
.hero:not(.cmp-hero) .bvr-press-cap{color:var(--volt)}
.hero:not(.cmp-hero) .bvr-press-logos{color:#fff;opacity:.96}
.hero:not(.cmp-hero) .bvr-trust{color:#b9d7c7}
.hero:not(.cmp-hero) .bvr-trust b{color:#fff}
.hero:not(.cmp-hero) .bvr-trust a{color:#dffaee}
/* proof band: stars + rating up top, logo wordmarks, identity line under */
.proof-band .pb-stars{margin:0 0 8px;font-size:13.5px;color:#dfe7ef}
.proof-band .pb-stars b{color:#fff;font-size:15px}
.proof-band .pb-stars a{color:#9fdcbd}
.proof-band .pb-meta{margin:8px 0 0;font-size:11px;color:#8fa3b8}
/* proof band inside the green hero: same block, readable on green */
.hero .proof-band{background:transparent}
.hero:not(.cmp-hero) .proof-band .pb-stars{color:#d6ebdf}
.hero:not(.cmp-hero) .proof-band .pb-stars b{color:#fff}
.hero:not(.cmp-hero) .proof-band .pb-stars a{color:#aee8cd}
.hero:not(.cmp-hero) .proof-band .pb-meta{color:#9ccdb6}
/* testimonial cards (Gonz 06-11, reference style): cream card, big green quote
   marks, extracted keyword headline, plain attribution */
.rv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:10px}
.rv-card{position:relative;background:#F5E9CB;border-radius:18px;padding:62px 26px 60px;text-align:left}
.rv-q{position:absolute;font-family:Georgia,'Times New Roman',serif;font-weight:700;color:var(--green-dark);font-size:58px;line-height:1}
.rv-q.open{top:16px;left:24px}
.rv-q.close{bottom:2px;right:24px}
.rv-kw{font-size:20px;font-weight:800;letter-spacing:-.01em;margin:0 0 10px;color:#26282a}
.rv-text{font-size:14px;line-height:1.6;color:#3d3f3b;margin:0 0 16px}
.rv-name{font-size:13px;color:#3d3f3b;margin:0}
@media(max-width:880px){.rv-grid{grid-template-columns:1fr}.rv-card{padding:56px 22px 54px}}
/* footer sits flush against whatever section ends the page (no stray bg strip) */
.lp-footer{margin-top:0}
/* closing CTA band (better.com reference): soft green, page h1 echoed, one pill */
section.bottom-cta{background:#E7F1EA;border-top:0;text-align:center;padding:64px 0 68px}
.bottom-cta h2{font-size:clamp(28px,4.4vw,44px);font-weight:900;letter-spacing:-.02em;color:var(--ink);margin:0 0 28px}
.bottom-cta .btn{display:inline-block;width:auto;min-width:220px;box-sizing:border-box;font-size:16px;padding:15px 38px}
.bottom-cta-proof{margin:18px auto 0;max-width:640px;font-size:13px;color:#5b6b5f;line-height:1.6}
.bottom-cta-proof b{color:var(--ink)}
.bottom-cta-proof a{color:var(--green-dark)}
.bottom-cta-proof .bvr-stars{font-size:13px}
/* in-card proof: subtle line under the button, then stars + press wordmarks */
.card-fine{font-size:12px;color:var(--muted);text-align:center;margin:10px 0 0;line-height:1.5}
.card-proof{border-top:1px solid var(--line);margin-top:12px;padding-top:11px;text-align:center}
.card-proof .cp-stars{margin:0;font-size:12.5px;color:var(--ink)}
.card-proof .cp-stars b{font-size:13.5px}
.card-proof .cp-stars a{color:var(--green-dark)}
.card-proof .cp-stars .bvr-stars{font-size:13px;letter-spacing:1px}
.card-proof .cp-logos{margin:6px 0 0;font-size:13px;font-weight:900;color:#6a6c68;letter-spacing:.02em}
.card-proof .cp-logos .lg-wsj,.card-proof .cp-logos .lg-forbes{font-family:Georgia,'Times New Roman',serif;font-weight:700}
.card-proof .cp-logos .lg-fool{font-style:italic}
.card-proof .cp-logos i{opacity:.4;font-style:normal}
.card-proof .cp-meta{margin:6px 0 0;font-size:10px;color:var(--muted);opacity:.8}
/* print: strip chrome so Save-as-PDF gives a clean document (site-level PDF feature) */
@media print{
  .pdf-btn,.pdf-link,.bvr-sticky-cta,.rb-sticky-cta,.om-sticky-cta,[id^="revw-"],#consent_blackbar,.preview-banner{display:none!important}
  body{background:#fff!important}
}

