/* Costwise — "Plain Answer" design system.
   Calm, anti-marketing, type-and-data led. 1px borders, almost no shadows. */

:root {
  --page: #f6f7f5;
  --surface: #ffffff;
  --surface-2: #f8faf8;
  --ink: #15171a;
  --ink-2: #3a3e42;
  --ink-soft: #4a4e52;
  --muted: #5a5f63;
  --muted-2: #6a6e72;
  --faint: #9aa09a;
  --line: #e4e7e3;
  --line-strong: #d4d8d3;
  --line-faint: #eef0ee;
  --line-head: #ececec;
  --ac: #3f7d72;
  --ac-tint: #eef4f2;
  --font-sans: "Space Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body { margin: 0; background: var(--page); color: var(--ink); font-family: var(--font-sans); font-size: 16px; line-height: 1.6; -webkit-font-smoothing: antialiased; }
a { text-decoration: none; color: inherit; }
img, svg { display: block; max-width: 100%; }
h1, h2, h3 { margin: 0; }
p { margin: 0; }
button { font-family: inherit; }
.num, .mono { font-variant-numeric: tabular-nums; }
.mono { font-family: var(--font-mono); }
.ico { flex: none; display: inline-block; vertical-align: middle; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

.wrap { max-width: 1000px; margin: 0 auto; padding: 0 30px; }

/* eyebrows */
.eyebrow-mono { font-family: var(--font-mono); font-weight: 600; font-size: 12px; line-height: 1; letter-spacing: .16em; text-transform: uppercase; color: var(--ac); }

/* buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 9px; font-family: var(--font-sans); font-weight: 600; font-size: 15.5px; padding: 15px 28px; border-radius: 11px; border: 1px solid transparent; cursor: pointer; transition: filter .12s ease; white-space: nowrap; }
.btn-primary { background: var(--ac); color: #fff; }
.btn-primary:hover { filter: brightness(.92); color: #fff; }
.btn-outline { background: var(--surface); color: var(--ink); border-color: var(--line-strong); }
.btn-outline:hover { border-color: var(--ac); color: var(--ac); }
.btn-sm { padding: 11px 18px; font-size: 14px; border-radius: 10px; }
.btn .ico { width: 17px; height: 17px; }
.btn-sm .ico { width: 15px; height: 15px; }

/* header */
.site-head { border-bottom: 1px solid var(--line-head); background: var(--page); }
.site-head .wrap { display: flex; align-items: center; justify-content: space-between; padding: 18px 30px; }
.brand { display: inline-flex; align-items: center; gap: 9px; font-weight: 700; font-size: 18px; letter-spacing: -.01em; color: var(--ink); }
.brand-mark { width: 26px; height: 26px; flex: none; }
.nav { display: flex; align-items: center; gap: 24px; font-size: 14px; font-weight: 500; color: var(--muted); }
.nav a { color: var(--muted); }
.nav a:hover { color: var(--ink); }
.nav a.active { color: var(--ink); font-weight: 600; }
.nav .free { color: var(--faint); font-size: 13px; }
@media (max-width: 560px) { .nav .free { display: none; } }

/* range bar (shared: home answer + price card) */
.range-bar { position: relative; height: 8px; background: var(--line); border-radius: 999px; }
.range-fill { position: absolute; top: 0; bottom: 0; background: var(--ac); border-radius: 999px; }
.range-mark { position: absolute; top: -4px; width: 16px; height: 16px; border-radius: 50%; background: #fff; border: 3px solid var(--ac); transform: translateX(-8px); }

/* ===== HOME ===== */
.answer { max-width: 700px; margin: 0 auto; padding: 66px 30px 0; text-align: center; }
.answer .eyebrow-mono { display: block; margin-bottom: 26px; }
.answer-q { font-weight: 500; font-size: 31px; line-height: 1.35; letter-spacing: -.01em; color: var(--ink-soft); }
.job-pill { display: inline-flex; align-items: center; gap: 9px; background: #fff; border: 1.5px solid var(--ink); border-radius: 11px; padding: 5px 15px; margin: 0 2px; color: var(--ink); font-weight: 600; font-size: 30px; letter-spacing: -.01em; box-shadow: 0 2px 0 var(--ink); cursor: pointer; line-height: 1.1; }
.job-pill .ico { width: 18px; height: 18px; color: var(--ac); }

.answer-fig { max-width: 700px; margin: 0 auto; padding: 14px 30px 0; text-align: center; }
.answer-label { font-size: 14.5px; color: var(--muted-2); font-weight: 500; margin-bottom: 4px; }
.answer-big { font-weight: 700; font-size: 88px; line-height: 1; letter-spacing: -.03em; font-variant-numeric: tabular-nums; }
@media (max-width: 560px) { .answer-big { font-size: 62px; } .answer-q, .job-pill { font-size: 25px; } }
.answer-range { font-size: 18px; color: var(--ink-soft); margin-top: 14px; font-weight: 500; }
.answer-range strong { color: var(--ink); }
.answer-bar { max-width: 430px; margin: 24px auto 0; }
.answer-cap { font-family: var(--font-mono); font-weight: 500; font-size: 11.5px; color: var(--faint); margin-top: 13px; letter-spacing: .04em; text-transform: uppercase; }

.switcher { max-width: 760px; margin: 0 auto; padding: 38px 30px 0; }
.chips { display: flex; flex-wrap: wrap; justify-content: center; gap: 9px; }
.chip { border: 1px solid var(--line-strong); background: #fff; color: var(--ink-soft); border-radius: 999px; padding: 9px 18px; font-size: 14px; font-weight: 500; cursor: pointer; transition: border-color .12s, color .12s; }
.chip:hover { border-color: var(--ac); color: var(--ac); }
.chip.active { border: 1.5px solid var(--ac); background: var(--ac); color: #fff; font-weight: 600; }
.answer-cta-row { text-align: center; margin-top: 32px; }
.answer-help { font-size: 13.5px; color: var(--faint); margin-top: 12px; }
.answer-help a { color: var(--ac); font-weight: 600; text-decoration: underline; text-underline-offset: 3px; }

/* why these numbers */
.why { border-top: 1px solid var(--line); margin-top: 54px; }
.why-grid { max-width: 880px; margin: 0 auto; padding: 46px 30px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 36px; text-align: center; }
@media (max-width: 720px) { .why-grid { grid-template-columns: 1fr; gap: 30px; } }
.why-ico { width: 40px; height: 40px; border-radius: 50%; border: 1.5px solid var(--ac); display: grid; place-items: center; margin: 0 auto 14px; color: var(--ac); }
.why-ico .ico { width: 20px; height: 20px; }
.why-cell h3 { font-weight: 600; font-size: 15.5px; margin-bottom: 5px; }
.why-cell p { font-size: 13.5px; line-height: 1.55; color: var(--muted-2); }

/* every cost guide (home) */
.guides-home { border-top: 1px solid var(--line); }
.guides-home .inner { max-width: 1000px; margin: 0 auto; padding: 56px 30px 50px; }
.sec-head { text-align: center; margin-bottom: 34px; }
.sec-head .eyebrow-mono { display: block; margin-bottom: 12px; letter-spacing: .14em; }
.sec-head h2 { font-weight: 700; font-size: 30px; letter-spacing: -.02em; }
.sec-head p { font-size: 15.5px; color: var(--muted-2); margin: 12px auto 0; max-width: 46ch; }
.guide-list { display: grid; grid-template-columns: 1fr 1fr; gap: 0 56px; }
@media (max-width: 720px) { .guide-list { grid-template-columns: 1fr; gap: 0; } }
.guide-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 16px 0; border-bottom: 1px solid var(--line); color: var(--ink); transition: padding-left .12s ease; }
.guide-row:hover { padding-left: 6px; }
.guide-row .gr-left { display: flex; align-items: center; gap: 13px; }
.guide-row .gr-ico { color: var(--ac); display: inline-flex; }
.guide-row .gr-ico .ico { width: 19px; height: 19px; }
.guide-row .gr-name { font-weight: 600; font-size: 16px; }
.guide-row .gr-price { font-weight: 600; font-size: 15px; color: var(--ink-soft); font-variant-numeric: tabular-nums; }

/* honesty band */
.honesty { background: var(--ac); }
.honesty .inner { max-width: 760px; margin: 0 auto; padding: 58px 30px; text-align: center; color: #fff; }
.honesty h2 { font-weight: 700; font-size: 30px; letter-spacing: -.02em; color: #fff; }
.honesty p { font-size: 16.5px; line-height: 1.6; margin: 16px auto 0; max-width: 48ch; color: rgba(255,255,255,.86); }
.honesty-points { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px 28px; margin-top: 26px; font-size: 14px; font-weight: 500; color: rgba(255,255,255,.92); }
.honesty-points span { display: inline-flex; align-items: center; gap: 8px; }
.honesty-points .ico { width: 16px; height: 16px; }

/* ===== QUOTE ===== */
.quote { border-top: 1px solid var(--line); }
.quote .inner { max-width: 600px; margin: 0 auto; padding: 58px 30px 64px; text-align: center; }
.quote h2 { font-weight: 700; font-size: 28px; letter-spacing: -.02em; }
.quote .q-lede { font-size: 15.5px; line-height: 1.6; color: var(--muted-2); margin: 13px auto 0; max-width: 42ch; }
.quote-form { margin-top: 26px; display: grid; gap: 11px; text-align: left; }
.quote-form .full { grid-column: 1 / -1; }
.qf-job { width: 100%; font: inherit; font-size: 15px; font-weight: 600; border: 1.5px solid var(--ink); border-radius: 11px; padding: 14px 44px 14px 16px; background-color: #fff; color: var(--ink); cursor: pointer; appearance: none; -webkit-appearance: none; background-repeat: no-repeat; background-position: right 16px center; background-size: 17px; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233f7d72' stroke-width='2.2'><path d='M6 9l6 6 6-6'/></svg>"); }
.qf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 11px; }
@media (max-width: 460px) { .qf-grid { grid-template-columns: 1fr; } }
.quote-form input { font: inherit; font-size: 14.5px; border: 1px solid var(--line-strong); border-radius: 11px; padding: 14px 16px; background: #fff; color: var(--ink); width: 100%; }
.quote-form input::placeholder { color: var(--faint); }
.quote-form input:focus, .qf-job:focus { outline: none; border-color: var(--ac); box-shadow: 0 0 0 3px var(--ac-tint); }
.qf-consent { display: flex; align-items: flex-start; gap: 10px; font-size: 12.5px; line-height: 1.45; color: var(--muted-2); cursor: pointer; }
.qf-consent input { margin-top: 2px; width: 17px; height: 17px; flex: none; accent-color: var(--ac); }
.quote-form .btn { width: 100%; margin-top: 2px; }
.qf-trust { display: inline-flex; align-items: center; gap: 8px; margin-top: 16px; font-size: 13px; color: var(--faint); justify-content: center; }
.qf-trust .ico { width: 15px; height: 15px; }
.qf-foot { font-size: 12.5px; color: var(--faint); margin-top: 6px; text-align: center; }
.qf-progress { display: flex; gap: 8px; justify-content: center; margin-bottom: 4px; }
.qf-dot { width: 30px; height: 4px; border-radius: 2px; background: var(--line-strong); transition: background .15s; }
.qf-dot.is-on { background: var(--ac); }
.qf-step { display: grid; gap: 11px; }
.qf-stepped .qf-step { display: none; }
.qf-stepped .qf-step.is-active { display: grid; }
.qf-step-label { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .04em; text-transform: uppercase; color: var(--faint); }
.qf-nav { display: flex; gap: 11px; }
.qf-nav .btn-primary { flex: 1; }

/* ===== ARTICLE / JOB PAGE ===== */
.article { max-width: 720px; margin: 0 auto; padding: 34px 30px 0; }
.crumb { font-family: var(--font-mono); font-weight: 500; font-size: 13px; line-height: 1; color: var(--faint); margin-bottom: 22px; }
.crumb a { color: var(--faint); }
.crumb a:hover { color: var(--ac); }
.crumb .here { color: var(--muted); }
.article h1 { font-weight: 700; font-size: 39px; line-height: 1.1; letter-spacing: -.025em; max-width: 20ch; }
@media (max-width: 560px) { .article h1 { font-size: 31px; } }
.summary { font-size: 18px; line-height: 1.6; color: var(--ink-soft); margin: 18px 0 0; max-width: 60ch; }

.price-card { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 24px 26px; margin-top: 28px; }
.pc-figs { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; align-items: end; }
.pc-label { font-family: var(--font-mono); font-weight: 600; font-size: 10.5px; letter-spacing: .06em; text-transform: uppercase; color: var(--faint); }
.pc-amt { font-weight: 600; font-size: 23px; margin-top: 3px; font-variant-numeric: tabular-nums; }
.pc-fig.typical .pc-label { color: var(--ac); }
.pc-fig.typical .pc-amt { font-weight: 700; font-size: 36px; color: var(--ink); line-height: 1; margin-top: 1px; }
.pc-fig.up { text-align: right; }
.price-card .range-bar { margin: 18px 0 9px; }
.pc-foot { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 8px; }
.pc-meta { font-size: 11.5px; color: var(--faint); text-transform: uppercase; letter-spacing: .04em; }
.pc-time { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: var(--ink-soft); font-weight: 500; }
.pc-time .ico { width: 15px; height: 15px; color: var(--ac); }

/* calculator card + controls (shared by job page + calculator page) */
.calc-card { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 26px; margin-top: 20px; }
.calc-head { display: flex; align-items: center; gap: 11px; }
.calc-head .ico { width: 22px; height: 22px; color: var(--ac); }
.calc-head h2 { font-weight: 700; font-size: 19px; letter-spacing: -.01em; }
.calc-hint { font-size: 13.5px; color: var(--faint); margin: 6px 0 20px; }
.calc-label { font-size: 13px; font-weight: 600; color: var(--ink); margin-bottom: 9px; }
.calc-tiers { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }
.calc-tier { border: 1px solid var(--line-strong); background: #fff; color: var(--ink-soft); border-radius: 10px; padding: 10px 15px; font-size: 13.5px; font-weight: 500; cursor: pointer; }
.calc-tier:hover { border-color: var(--ac); color: var(--ac); }
.calc-tier.active { border: 1.5px solid var(--ac); background: var(--ac); color: #fff; font-weight: 600; }
.calc-num { width: 100%; font: inherit; font-size: 14.5px; padding: 13px 15px; border: 1px solid var(--line-strong); border-radius: 11px; background: #fff; color: var(--ink); margin-bottom: 20px; appearance: textfield; }
.calc-num:focus, .calc-sel:focus { outline: none; border-color: var(--ac); box-shadow: 0 0 0 3px var(--ac-tint); }
.calc-addon { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 14px; background: var(--surface-2); border: 1px solid var(--line); border-radius: 11px; padding: 13px 15px; cursor: pointer; text-align: left; margin-bottom: 11px; }
.calc-addon-label { display: block; font-weight: 600; font-size: 14.5px; color: var(--ink); }
.calc-addon-sub { display: block; font-family: var(--font-mono); font-weight: 500; font-size: 11.5px; color: var(--faint); margin-top: 2px; }
.calc-addon-pill { background: #fff; color: var(--ac); border: 1.5px solid var(--ac); border-radius: 999px; padding: 6px 15px; font-size: 13px; font-weight: 600; flex: none; }
.calc-addon.on .calc-addon-pill { background: var(--ac); color: #fff; border-color: var(--ac); padding: 7px 15px; }
.calc-addons-gap { margin-bottom: 20px; }
.calc-sel { width: 100%; font: inherit; font-size: 14.5px; padding: 13px 40px 13px 15px; border: 1px solid var(--line-strong); border-radius: 11px; background-color: #fff; color: var(--ink); cursor: pointer; margin-bottom: 22px; appearance: none; -webkit-appearance: none; background-repeat: no-repeat; background-position: right 14px center; background-size: 18px; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233f7d72' stroke-width='2.2'><path d='M6 9l6 6 6-6'/></svg>"); }
.calc-out { background: var(--ac-tint); border-radius: 12px; padding: 18px 20px; }
.calc-out-label { font-family: var(--font-mono); font-weight: 600; font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--ac); }
.calc-out-range { font-weight: 700; font-size: 32px; letter-spacing: -.02em; margin-top: 4px; font-variant-numeric: tabular-nums; }
.calc-out-note { font-size: 13px; color: var(--muted); margin-top: 4px; }
.calc-out .btn { margin-top: 14px; }

/* affiliate */
.affiliate { margin: 24px 0; border: 1px solid var(--line); background: var(--ac-tint); border-radius: 16px; padding: 20px 22px; }
.aff-tag { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 11px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--ac); margin-bottom: 9px; }
.aff-tag .ico { width: 14px; height: 14px; }
.aff-blurb { color: var(--ink); font-size: 15px; margin-bottom: 14px; line-height: 1.55; }
.aff-disc { font-size: 12px; color: var(--muted); margin-top: 12px; }

/* article body sections */
.article h2 { font-weight: 700; font-size: 24px; letter-spacing: -.02em; margin: 46px 0 0; }
.incl { list-style: none; padding: 0; margin: 18px 0 0; }
.incl li { display: flex; gap: 13px; align-items: flex-start; padding: 11px 0; border-bottom: 1px solid var(--line); font-size: 16px; }
.incl .ico { width: 19px; height: 19px; flex: none; margin-top: 3px; color: var(--ac); }
.factors { margin-top: 16px; display: grid; gap: 12px; }
.factor { display: flex; gap: 13px; align-items: flex-start; }
.factor-num { font-family: var(--font-mono); font-weight: 600; font-size: 13px; color: var(--ac); margin-top: 2px; flex: none; }
.factor p { font-size: 15.5px; color: var(--ink-2); line-height: 1.55; }
.regional { font-size: 15.5px; color: var(--ink-2); line-height: 1.6; margin-top: 14px; }
.faq { border-top: 1px solid var(--line); margin-top: 14px; }
.faq-item { padding: 18px 0; border-bottom: 1px solid var(--line); }
.faq-q { font-weight: 600; font-size: 16.5px; margin-bottom: 6px; }
.faq-a { font-size: 15px; color: var(--muted); line-height: 1.6; }
.disclaimer { font-size: 12.5px; color: var(--faint); line-height: 1.55; margin: 26px 0 0; border-top: 1px solid var(--line-faint); padding-top: 16px; }
.related h3 { font-weight: 600; font-size: 15px; margin: 30px 0 12px; color: var(--muted); }
.related-links { display: flex; flex-wrap: wrap; gap: 10px; }
.related-link { display: inline-flex; align-items: center; gap: 7px; border: 1px solid var(--line-strong); border-radius: 999px; padding: 9px 16px; font-size: 14px; font-weight: 500; color: var(--ink); background: #fff; }
.related-link:hover { border-color: var(--ac); color: var(--ac); }
.related-link .ico { width: 14px; height: 14px; }

/* ===== HUB ===== */
.hub-intro { max-width: 820px; margin: 0 auto; padding: 54px 30px 8px; text-align: center; }
.hub-intro .eyebrow-mono { display: block; margin-bottom: 16px; }
.hub-intro h1 { font-weight: 700; font-size: 40px; line-height: 1.08; letter-spacing: -.025em; max-width: 18ch; margin: 0 auto; }
@media (max-width: 560px) { .hub-intro h1 { font-size: 31px; } }
.hub-intro .lede { font-size: 17px; line-height: 1.6; color: var(--ink-soft); margin: 16px auto 0; max-width: 54ch; }
.hub-search { display: inline-flex; align-items: center; gap: 10px; margin-top: 24px; background: #fff; border: 1px solid var(--line-strong); border-radius: 999px; padding: 12px 18px; max-width: 380px; width: 100%; }
.hub-search .ico { width: 18px; height: 18px; flex: none; color: var(--faint); }
.hub-search input { border: 0; outline: none; font: inherit; font-size: 14.5px; color: var(--ink); background: transparent; width: 100%; }
.hub-search input::placeholder { color: var(--faint); }
.hub-cats { max-width: 920px; margin: 0 auto; padding: 14px 30px 10px; display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; }
.hub-cat { border: 1px solid var(--line-strong); background: #fff; color: var(--ink-soft); border-radius: 999px; padding: 8px 16px; font-size: 13.5px; font-weight: 500; cursor: pointer; }
.hub-cat:hover { border-color: var(--ac); color: var(--ac); }
.hub-cat.active { border: 1.5px solid var(--ink); background: var(--ink); color: #fff; font-weight: 600; }
.hub-list { max-width: 920px; margin: 0 auto; padding: 26px 30px 56px; }
.hub-card { background: #fff; border: 1px solid var(--line); border-radius: 18px; overflow: hidden; }
.hub-row { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 16px; padding: 18px 24px; border-bottom: 1px solid var(--line-faint); color: var(--ink); }
.hub-row:last-child { border-bottom: 0; }
.hub-row:hover { background: var(--surface-2); }
.hub-row-ico { width: 40px; height: 40px; border-radius: 11px; background: var(--ac-tint); color: var(--ac); display: grid; place-items: center; flex: none; }
.hub-row-ico .ico { width: 21px; height: 21px; }
.hub-row-name { display: block; font-weight: 600; font-size: 16.5px; }
.hub-row-sub { display: block; font-size: 13px; color: var(--faint); }
.hub-row-price { text-align: right; }
.hub-row-range { display: block; font-weight: 600; font-size: 15px; font-variant-numeric: tabular-nums; }
.hub-row-unit { display: block; font-family: var(--font-mono); font-weight: 500; font-size: 11px; color: var(--faint); text-transform: uppercase; }
.hub-foot { text-align: center; font-size: 13.5px; color: var(--faint); margin: 20px 0 0; }
.hub-foot a { color: var(--ac); font-weight: 600; }

/* ===== FOOTER ===== */
.site-foot { border-top: 1px solid var(--line); background: #fff; }
.site-foot .foot-main { max-width: 1000px; margin: 0 auto; padding: 40px 30px; display: flex; flex-wrap: wrap; gap: 28px; justify-content: space-between; align-items: flex-start; }
.site-foot .foot-brand { max-width: 34ch; }
.site-foot .foot-brand p { font-size: 13.5px; color: var(--muted-2); margin-top: 12px; line-height: 1.55; }
.foot-cols { display: flex; gap: 40px; font-size: 14px; }
.foot-col { display: grid; gap: 10px; align-content: start; }
.foot-col .foot-h { font-size: 12px; font-weight: 600; color: var(--faint); text-transform: uppercase; letter-spacing: .06em; }
.foot-col a { color: var(--ink-soft); }
.foot-col a:hover { color: var(--ac); }
.foot-legal { max-width: 1000px; margin: 0 auto; padding: 0 30px 36px; }
.foot-legal p { font-size: 12px; color: var(--faint); line-height: 1.55; border-top: 1px solid var(--line-faint); padding-top: 18px; max-width: 80ch; }
.foot-compact { max-width: 1000px; margin: 0 auto; padding: 36px 30px; display: flex; flex-wrap: wrap; gap: 24px; justify-content: space-between; align-items: center; }
.foot-compact p { font-size: 12.5px; color: var(--faint); }

/* toast (quote.js) */
.toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(20px); background: var(--ink); color: #fff; padding: 13px 20px; border-radius: 11px; font-size: 14px; opacity: 0; pointer-events: none; transition: opacity .2s, transform .2s; z-index: 60; }
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* generic section + calculator page */
.section { padding: 54px 0; }
.calc-page { max-width: 760px; margin: 0 auto; padding: 48px 30px 0; }
.calc-page-head { text-align: center; margin-bottom: 8px; }
.calc-page-head .eyebrow-mono { display: block; margin-bottom: 14px; }
.calc-page-head h1 { font-weight: 700; font-size: 38px; line-height: 1.1; letter-spacing: -.025em; max-width: 20ch; margin: 0 auto; }
@media (max-width: 560px) { .calc-page-head h1 { font-size: 30px; } }
.calc-page-head p { font-size: 17px; color: var(--ink-soft); margin: 14px auto 0; max-width: 52ch; }
.simple { max-width: 600px; margin: 0 auto; padding: 48px 30px 0; text-align: center; }
.simple h1 { font-weight: 700; font-size: 34px; letter-spacing: -.025em; }
.simple p { font-size: 17px; color: var(--ink-soft); margin: 14px auto 0; max-width: 46ch; }
.simple .btn-row { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 24px; }

/* answer-first + byline + section leads */
.answer-lead { font-size: 19px; line-height: 1.55; color: var(--ink); font-weight: 500; margin: 16px 0 0; max-width: 62ch; }
.byline { font-family: var(--font-mono); font-size: 12.5px; color: var(--faint); margin: 10px 0 0; }
.byline a { color: var(--ac); }
.sec-lead { font-size: 15.5px; color: var(--ink-soft); margin: 14px 0 0; }
.article-wide { max-width: 880px; }

/* cost tables */
.table-wrap { overflow-x: auto; margin: 16px 0 0; -webkit-overflow-scrolling: touch; }
.table-wrap .cost-table { margin-top: 0; }
.cost-table { width: 100%; border-collapse: collapse; margin: 16px 0 0; font-size: 15px; }
.cost-table th { text-align: left; font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; color: var(--faint); padding: 0 14px 10px 0; border-bottom: 1px solid var(--line-strong); }
.cost-table td { padding: 11px 14px 11px 0; border-bottom: 1px solid var(--line); vertical-align: top; }
.cost-table td.num { text-align: right; white-space: nowrap; font-variant-numeric: tabular-nums; }
.cost-table tr:last-child td { border-bottom: 0; }
.cost-table .ct-total td { font-weight: 600; border-top: 1px solid var(--line-strong); }
.cost-table a { color: var(--ink); font-weight: 500; }
.cost-table a:hover { color: var(--ac); }

/* cost index chart */
.cost-chart { margin: 16px 0 0; display: grid; gap: 4px; }
.cc-row { display: grid; grid-template-columns: 150px 1fr auto; align-items: center; gap: 14px; padding: 7px 0; color: var(--ink); }
.cc-row:hover .cc-name { color: var(--ac); }
.cc-name { font-size: 14px; font-weight: 500; }
.cc-track { height: 20px; background: var(--ac-tint); border-radius: 6px; overflow: hidden; }
.cc-bar { display: block; height: 100%; background: var(--ac); border-radius: 6px; }
.cc-val { font-size: 13.5px; font-weight: 600; font-variant-numeric: tabular-nums; min-width: 64px; text-align: right; }
@media (max-width: 560px) { .cc-row { grid-template-columns: 108px 1fr auto; gap: 10px; } .cc-name { font-size: 13px; } }

/* comparison panes */
.cmp-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 24px 0 0; }
@media (max-width: 560px) { .cmp-grid { grid-template-columns: 1fr; } }
.cmp-pane { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 22px; color: var(--ink); display: block; transition: border-color .12s; }
.cmp-pane:hover { border-color: var(--ac); }
.cmp-ico { width: 42px; height: 42px; border-radius: 11px; background: var(--ac-tint); color: var(--ac); display: grid; place-items: center; }
.cmp-ico .ico { width: 22px; height: 22px; }
.cmp-name { font-weight: 600; font-size: 16px; margin-top: 12px; }
.cmp-typ { font-weight: 700; font-size: 30px; letter-spacing: -.02em; margin-top: 6px; font-variant-numeric: tabular-nums; }
.cmp-range { font-size: 14px; color: var(--ink-soft); margin-top: 2px; }
.cmp-unit { font-size: 11px; color: var(--faint); text-transform: uppercase; margin-top: 2px; }
.cmp-link { display: inline-flex; align-items: center; gap: 6px; margin-top: 12px; font-size: 13px; font-weight: 600; color: var(--ac); }
.cmp-link .ico { width: 14px; height: 14px; }

/* footer mini nav */
.foot-mini { display: flex; flex-wrap: wrap; gap: 8px 20px; font-size: 13.5px; }
.foot-mini a { color: var(--ink-soft); }
.foot-mini a:hover { color: var(--ac); }
@media (max-width: 600px) { .foot-compact { flex-direction: column; align-items: flex-start; gap: 14px; } }
