/* HomeMortgageOnline — design tokens + base + components
   Direction: warm editorial credibility. Ivory + ink + a restrained brass accent. */

:root {
  /* Type scale (fluid) */
  --text-xs:   clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --text-sm:   clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
  --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.125rem);
  --text-lg:   clamp(1.125rem, 1rem + 0.75vw, 1.5rem);
  --text-xl:   clamp(1.5rem, 1.2rem + 1.25vw, 2.25rem);
  --text-2xl:  clamp(2rem, 1.2rem + 2.5vw, 3.5rem);
  --text-3xl:  clamp(2.5rem, 1rem + 4vw, 5rem);

  /* Spacing */
  --space-1:.25rem; --space-2:.5rem; --space-3:.75rem; --space-4:1rem;
  --space-5:1.25rem; --space-6:1.5rem; --space-8:2rem; --space-10:2.5rem;
  --space-12:3rem; --space-16:4rem; --space-20:5rem; --space-24:6rem; --space-32:8rem;

  --radius-sm:.375rem; --radius-md:.5rem; --radius-lg:.75rem; --radius-xl:1rem;
  --radius-full:9999px;
  --transition: 200ms cubic-bezier(0.16, 1, 0.3, 1);

  --content-narrow:680px; --content-default:1040px; --content-wide:1240px;

  --font-display:'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono:'JetBrains Mono', ui-monospace, monospace;
}

:root, [data-theme="light"] {
  --color-bg:           #f6f1e7;   /* warm ivory */
  --color-surface:      #fbf8f1;
  --color-surface-2:    #ffffff;
  --color-surface-offset:#efe9dc;
  --color-border:       #d9cfb8;
  --color-divider:      #e6dfca;

  --color-text:         #1c2a3a;   /* deep ink navy */
  --color-text-muted:   #5b6878;
  --color-text-faint:   #9aa4b1;
  --color-text-inverse: #fbf8f1;

  --color-primary:      #0f2e4a;   /* navy */
  --color-primary-hover:#0a223a;
  --color-primary-active:#061629;
  --color-primary-tint: #e3eaf3;

  --color-accent:       #b08236;   /* brass */
  --color-accent-hover: #946b27;
  --color-accent-tint:  #f4e9d3;

  --color-success:      #2f6a3f;
  --color-warning:      #a06205;
  --color-error:        #9e2a2b;

  --shadow-sm: 0 1px 2px rgba(28,42,58,.06);
  --shadow-md: 0 6px 18px rgba(28,42,58,.08);
  --shadow-lg: 0 14px 40px rgba(28,42,58,.12);
}

[data-theme="dark"] {
  --color-bg:           #0d1118;
  --color-surface:      #141a23;
  --color-surface-2:    #1a212b;
  --color-surface-offset:#191f29;
  --color-border:       #2a3340;
  --color-divider:      #222a36;

  --color-text:         #e8e5dd;
  --color-text-muted:   #95a0ad;
  --color-text-faint:   #5e6772;
  --color-text-inverse: #0d1118;

  --color-primary:      #4a82c6;
  --color-primary-hover:#6a9dde;
  --color-primary-active:#3a6cab;
  --color-primary-tint: #1b2737;

  --color-accent:       #d9aa55;
  --color-accent-hover: #ecc171;
  --color-accent-tint:  #2c2515;

  --color-success:      #4d9a64;
  --color-warning:      #d39432;
  --color-error:        #c4595a;

  --shadow-sm: 0 1px 2px rgba(0,0,0,.4);
  --shadow-md: 0 6px 18px rgba(0,0,0,.5);
  --shadow-lg: 0 14px 40px rgba(0,0,0,.6);
}

/* Reset / base */
*,*::before,*::after { box-sizing: border-box; margin:0; padding:0; }
html {
  -webkit-text-size-adjust: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  scroll-behavior: smooth;
  scroll-padding-top: var(--space-16);
  overflow-x: clip;
}
body {
  min-height: 100dvh;
  line-height: 1.6;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-text);
  background-color: var(--color-bg);
}
img, picture, svg, video { display:block; max-width:100%; height:auto; }
button { cursor:pointer; background:none; border:none; font:inherit; color:inherit; }
input, textarea, select { font:inherit; color:inherit; }
a { color: var(--color-primary); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
a:hover { color: var(--color-accent-hover); }
ul[role="list"], ol[role="list"] { list-style:none; }
table { border-collapse: collapse; width:100%; }
h1,h2,h3,h4 { font-family: var(--font-display); font-weight: 500; line-height: 1.15; text-wrap: balance; letter-spacing:-0.01em; }
h1 { font-size: var(--text-2xl); }
h2 { font-size: var(--text-xl); margin-top: var(--space-12); margin-bottom: var(--space-4); }
h3 { font-size: var(--text-lg); margin-top: var(--space-8); margin-bottom: var(--space-3); }
p, li { text-wrap: pretty; max-width: 70ch; }
:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 3px; border-radius: var(--radius-sm); }
::selection { background: var(--color-accent-tint); color: var(--color-text); }

@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after { animation-duration:.01ms!important; transition-duration:.01ms!important; }
}

.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.container { width:100%; max-width: var(--content-wide); margin-inline:auto; padding-inline: clamp(var(--space-4), 4vw, var(--space-10)); }
.narrow { max-width: var(--content-narrow); margin-inline:auto; }
.default { max-width: var(--content-default); margin-inline:auto; }

/* Header */
.header {
  position: sticky; top:0; z-index: 50;
  background: color-mix(in oklab, var(--color-bg) 88%, transparent);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--color-divider);
}
.header__inner {
  display:flex; align-items:center; justify-content:space-between;
  padding-block: var(--space-3);
  gap: var(--space-6);
}
.brand { display:flex; align-items:center; gap: var(--space-3); text-decoration:none; color: var(--color-text); }
.brand__mark { color: var(--color-primary); }
.brand__name { font-family: var(--font-display); font-size: var(--text-lg); font-weight:500; letter-spacing:-.01em; }
.nav { display:flex; gap: var(--space-5); align-items:center; }
.nav a { font-size: var(--text-sm); color: var(--color-text); text-decoration:none; }
.nav a:hover { color: var(--color-accent-hover); }
.header__actions { display:flex; gap: var(--space-2); align-items:center; }
.icon-btn { width:36px; height:36px; display:inline-flex; align-items:center; justify-content:center; border:1px solid var(--color-border); border-radius: var(--radius-full); color: var(--color-text); }
.icon-btn:hover { background: var(--color-surface); }

@media (max-width: 800px) {
  .nav { display:none; }
  .nav--open { display:flex; flex-direction:column; position:absolute; top:100%; left:0; right:0; padding: var(--space-4); background: var(--color-surface); border-bottom: 1px solid var(--color-divider); }
  .menu-toggle { display:inline-flex; }
}
@media (min-width: 801px) {
  .menu-toggle { display:none; }
}

/* Buttons */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap: var(--space-2);
  padding: .75rem 1.25rem; border-radius: var(--radius-md);
  font-size: var(--text-sm); font-weight: 600;
  text-decoration: none; border: 1px solid transparent;
  transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition);
}
.btn--primary { background: var(--color-primary); color: var(--color-text-inverse); }
.btn--primary:hover { background: var(--color-primary-hover); color: var(--color-text-inverse); }
.btn--accent { background: var(--color-accent); color: #1d1305; }
.btn--accent:hover { background: var(--color-accent-hover); color: #1d1305; }
.btn--outline { border-color: var(--color-border); color: var(--color-text); background: transparent; }
.btn--outline:hover { border-color: var(--color-primary); color: var(--color-primary); }
.btn--lg { padding: .95rem 1.6rem; font-size: var(--text-base); }

/* Hero */
.hero { padding-block: clamp(var(--space-12), 8vw, var(--space-24)); }
/* Tighter hero + first content section, for editorial pages where a big gap
   between the headline and the first data block feels disconnected. */
.hero--tight { padding-block: clamp(var(--space-8), 5vw, var(--space-12)) clamp(var(--space-6), 3vw, var(--space-8)); }
.section--snug { padding-top: clamp(var(--space-6), 3vw, var(--space-8)); }
.hero h1 { font-size: var(--text-2xl); max-width: 22ch; }
.hero__lede { margin-top: var(--space-4); font-size: var(--text-lg); color: var(--color-text-muted); max-width: 60ch; }
.hero__actions { display:flex; flex-wrap:wrap; gap: var(--space-3); margin-top: var(--space-6); }
.hero__trust { margin-top: var(--space-8); display:flex; flex-wrap:wrap; gap: var(--space-6) var(--space-8); align-items:center; color: var(--color-text-muted); font-size: var(--text-sm); }
.hero__trust strong { color: var(--color-text); font-weight: 600; }

/* Disclosure banner */
.disclosure {
  background: var(--color-accent-tint);
  border: 1px solid color-mix(in oklab, var(--color-accent) 30%, transparent);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  color: var(--color-text);
  margin-block: var(--space-4);
}
.disclosure strong { color: var(--color-accent-hover); }

/* Cards */
.card {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
}
.card--feature { display:flex; flex-direction:column; gap: var(--space-3); }
.card--feature h3 { margin:0; font-size: var(--text-lg); }
.card__icon { width:44px; height:44px; border-radius: var(--radius-md); background: var(--color-primary-tint); color: var(--color-primary); display:flex; align-items:center; justify-content:center; }

.grid-3 { display:grid; gap: var(--space-6); grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.grid-2 { display:grid; gap: var(--space-8); grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); align-items: start; }
.section-head { max-width: 780px; margin-bottom: var(--space-8); }
.section-head p { color: var(--color-text-muted); font-size: var(--text-lg); }

section { padding-block: clamp(var(--space-10), 5vw, var(--space-16)); }
section + section { border-top: 1px solid var(--color-divider); }

.eyebrow {
  display:inline-block; font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .12em;
  color: var(--color-accent-hover); font-weight: 600; margin-bottom: var(--space-2);
}

/* Rate table */
.rate-table { width:100%; font-size: var(--text-sm); }
.table-scroll { display:block; width:100%; max-width:100%; min-width:0; overflow-x:auto; -webkit-overflow-scrolling:touch; }
@media (max-width: 640px) {
  .table-scroll { white-space:nowrap; }
}
.rate-table th, .rate-table td { padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--color-divider); text-align:left; }
.rate-table th { font-weight: 600; color: var(--color-text-muted); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .08em; }
.rate-table tr:last-child td { border-bottom: none; }
.rate-table tbody tr:hover { background: var(--color-surface-offset); }
.rate-pill { display:inline-block; padding: .15rem .55rem; font-size: var(--text-xs); border-radius: var(--radius-full); background: var(--color-primary-tint); color: var(--color-primary); font-weight:600; }

/* -------------------- RATE SNAPSHOT (graphical module) -------------------- */
.rate-snapshot-section { background: var(--color-surface-offset); padding-block: var(--space-12); }
.rate-snapshot { display:flex; flex-direction:column; gap: var(--space-6); }

/* Header row: left title block, right "At a glance" card */
.rate-snapshot__top {
  display:grid; gap: var(--space-6); align-items:start;
  grid-template-columns: minmax(0, 1.6fr) minmax(260px, 1fr);
}
.rate-snapshot__head { min-width: 0; }
.rate-snapshot__head h2 { margin-top: var(--space-1); margin-bottom: 0; font-size: var(--text-2xl); }
.rate-snapshot__sub { color: var(--color-text-muted); font-size: var(--text-base); margin-top: var(--space-3); max-width: 48ch; }
.rate-snapshot__pill {
  display:inline-flex; align-items:center; gap: var(--space-2);
  margin-top: var(--space-4); padding: .5rem .9rem;
  border-radius: var(--radius-full);
  background: var(--color-primary-tint); color: var(--color-primary);
  font-size: var(--text-sm); font-weight: 500; line-height: 1.3;
  border: 1px solid color-mix(in oklab, var(--color-primary) 18%, transparent);
}
.rate-snapshot__pill-dot {
  display:inline-flex; align-items:center; justify-content:center; flex:0 0 auto;
  width: 1.25rem; height: 1.25rem; border-radius: var(--radius-full);
  background: var(--color-primary); color: var(--color-text-inverse);
  font-family: var(--font-display); font-style: italic; font-weight: 600;
  font-size: .8rem;
}

/* At-a-glance card (top-right): three compact signal blocks */
.glance-card {
  display:flex; flex-direction:column; gap: var(--space-3);
  background: var(--color-surface-2);
  border:1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
  box-shadow: var(--shadow-md);
}
.glance-card__title {
  font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .12em;
  color: var(--color-text-muted); font-weight: 700;
}
.glance-card__grid { display:grid; gap: var(--space-3); }
.glance-block {
  display:flex; align-items:center; gap: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
}
.glance-block__icon {
  display:inline-flex; align-items:center; justify-content:center; flex:0 0 auto;
  width: 2.4rem; height: 2.4rem; border-radius: var(--radius-full);
  background: var(--color-accent-tint); color: var(--color-accent-hover);
}
.glance-block--down .glance-block__icon  { background: color-mix(in oklab, var(--color-success) 16%, transparent); color: var(--color-success); }
.glance-block--up .glance-block__icon    { background: color-mix(in oklab, var(--color-error) 16%, transparent); color: var(--color-error); }
.glance-block--mixed .glance-block__icon { background: color-mix(in oklab, var(--color-warning) 18%, transparent); color: var(--color-warning); }
.glance-block__body { display:flex; flex-direction:column; min-width:0; }
.glance-block__label { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .08em; color: var(--color-text-muted); font-weight: 600; }
.glance-block__value { font-weight: 700; color: var(--color-text); line-height: 1.2; }
.glance-block__sub { font-size: var(--text-xs); color: var(--color-text-faint); }

/* Standalone glance strip (state pages + current-rates) */
.glance-strip {
  display:grid; gap: var(--space-4);
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.glance-strip .glance-card { display:flex; flex-direction:column; gap: var(--space-1); position:relative; overflow:hidden; box-shadow:none; border-radius: var(--radius-lg); background: var(--color-surface); }
.glance-strip .glance-card::before { content:""; position:absolute; inset:0 auto 0 0; width:4px; background: var(--color-accent); }
.glance-strip .glance-card--down::before  { background: var(--color-success); }
.glance-strip .glance-card--up::before    { background: var(--color-error); }
.glance-strip .glance-card--mixed::before { background: var(--color-warning); }
.glance-strip .glance-card__label { display:flex; align-items:center; gap: var(--space-2); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .1em; color: var(--color-text-muted); font-weight: 600; }
.glance-strip .glance-card__icon { display:inline-flex; align-items:center; justify-content:center; width:1.4rem; height:1.4rem; flex:0 0 auto; border-radius: var(--radius-full); background: var(--color-accent-tint); color: var(--color-accent-hover); }
.glance-strip .glance-card--down .glance-card__icon  { background: color-mix(in oklab, var(--color-success) 16%, transparent); color: var(--color-success); }
.glance-strip .glance-card--up .glance-card__icon    { background: color-mix(in oklab, var(--color-error) 16%, transparent); color: var(--color-error); }
.glance-strip .glance-card--mixed .glance-card__icon { background: color-mix(in oklab, var(--color-warning) 18%, transparent); color: var(--color-warning); }
.glance-strip .glance-card__value { font-family: var(--font-display); font-weight: 500; line-height: 1.05; font-size: var(--text-xl); color: var(--color-text); letter-spacing: -0.01em; }
.glance-strip .glance-card__sub { color: var(--color-text-muted); font-size: var(--text-sm); }

/* Full-width rate table card with dark navy header */
.rate-table-card {
  background: var(--color-surface-2);
  border:1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  overflow:hidden;
}
.rate-grid { display:flex; flex-direction:column; }
.rate-grid__head, .rate-row {
  display:grid; align-items:center; gap: var(--space-4);
  grid-template-columns: minmax(150px, 1.5fr) minmax(140px, 1.2fr) minmax(96px, .8fr) minmax(150px, 1.3fr) minmax(150px, 1.3fr);
}
.rate-grid__head {
  background: var(--color-primary); color: var(--color-text-inverse);
  padding: var(--space-4) var(--space-5);
  font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .08em; font-weight: 700;
}
.rate-grid__head span { color: color-mix(in oklab, var(--color-text-inverse) 88%, transparent); }
.rate-row {
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid var(--color-divider);
  transition: background .15s ease;
}
.rate-row:hover { background: var(--color-surface); }
.rate-row__cell { min-width: 0; }
.rate-row__celllabel { display:none; font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .08em; color: var(--color-text-faint); font-weight: 600; margin-bottom: var(--space-1); }

/* Loan-type badge: large circular colored icon + name */
.loan-badge { display:flex; align-items:center; gap: var(--space-3); }
.loan-badge__icon {
  display:inline-flex; align-items:center; justify-content:center;
  width: 2.75rem; height: 2.75rem; flex: 0 0 auto;
  border-radius: var(--radius-full);
  background: var(--color-primary-tint); color: var(--color-primary);
}
.loan-badge__icon svg { width: 22px; height: 22px; }
.loan-badge__icon--navy   { background: var(--color-primary-tint); color: var(--color-primary); }
.loan-badge__icon--blue   { background: color-mix(in oklab, #2f6fb0 16%, transparent); color: #2f6fb0; }
.loan-badge__icon--green  { background: color-mix(in oklab, var(--color-success) 16%, transparent); color: var(--color-success); }
.loan-badge__icon--gold   { background: var(--color-accent-tint); color: var(--color-accent-hover); }
.loan-badge__icon--purple { background: color-mix(in oklab, #6b4ea0 16%, transparent); color: #6b4ea0; }
.loan-badge__name { font-weight: 700; color: var(--color-text); line-height: 1.2; }
.loan-badge__term { display:block; font-size: var(--text-xs); color: var(--color-text-muted); font-weight: 500; }

/* Large rate value + APR */
.rate-value { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.4rem, 1.1rem + 1vw, 1.9rem); color: var(--color-primary); line-height: 1; letter-spacing: -0.02em; }
.rate-value sup { font-size: .5em; font-weight: 600; vertical-align: super; margin-left: 1px; }
.rate-apr { display:block; font-size: var(--text-xs); color: var(--color-text-muted); margin-top: 3px; }

/* Range bar: where this rate sits in the week's low-high band */
.range-bar { display:flex; flex-direction:column; gap: 4px; margin-top: var(--space-3); max-width: 13rem; }
.range-bar__track {
  position:relative; height: 8px; border-radius: var(--radius-full);
  background: linear-gradient(90deg, color-mix(in oklab, var(--color-success) 45%, transparent), var(--color-surface-offset) 55%, color-mix(in oklab, var(--color-error) 45%, transparent));
}
.range-bar__dot {
  position:absolute; top: 50%; width: 14px; height: 14px;
  transform: translate(-50%, -50%);
  border-radius: var(--radius-full);
  background: var(--color-surface-2); border: 3px solid var(--color-primary);
  box-shadow: 0 1px 3px rgba(15,46,74,.3);
}
.range-bar__ends { display:flex; justify-content:space-between; font-size: var(--text-xs); color: var(--color-text-faint); }

/* Week change delta: prominent signed value (sign glyph + color, never color-only) */
.delta { display:inline-flex; align-items:center; gap: .35rem; font-weight: 700; font-size: var(--text-base); }
.delta__glyph { font-size: .8em; }
.delta__num { font-variant-numeric: tabular-nums; }
.delta--down { color: var(--color-success); }
.delta--up   { color: var(--color-error); }
.delta--flat { color: var(--color-text-muted); }

/* Bottom legend + big-picture summary */
.rate-snapshot__foot { display:grid; gap: var(--space-5); grid-template-columns: minmax(0, 1.4fr) minmax(240px, 1fr); align-items:start; }
.rate-legend { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap: var(--space-2); font-size: var(--text-sm); color: var(--color-text-muted); }
.rate-legend li { display:flex; align-items:center; gap: var(--space-2); }
.rate-legend__key { display:inline-block; width: 1.5rem; height: .55rem; border-radius: var(--radius-full); flex:0 0 auto; }
.rate-legend__key--range { background: linear-gradient(90deg, var(--color-success), var(--color-surface-offset), var(--color-error)); }
.rate-legend__key--down { background: var(--color-success); }
.rate-legend__key--mixed { background: var(--color-warning); }
.rate-legend__key--up { background: var(--color-error); }
.big-picture {
  background: var(--color-primary); color: var(--color-text-inverse);
  border-radius: var(--radius-xl); padding: var(--space-5);
  box-shadow: var(--shadow-md);
}
.big-picture__title { display:block; font-family: var(--font-display); font-size: var(--text-lg); margin-bottom: var(--space-2); }
.big-picture p { margin:0; color: color-mix(in oklab, var(--color-text-inverse) 90%, transparent); font-size: var(--text-sm); line-height: 1.5; }
.big-picture strong { color: var(--color-text-inverse); }

@media (max-width: 940px) {
  .rate-snapshot__top { grid-template-columns: 1fr; }
}
@media (max-width: 860px) {
  .rate-table-card { background: transparent; border: none; box-shadow: none; overflow: visible; }
  .rate-grid { gap: var(--space-3); }
  .rate-grid__head { display:none; }
  .rate-row {
    grid-template-columns: 1fr 1fr; gap: var(--space-4) var(--space-5);
    background: var(--color-surface-2);
    border: 1px solid var(--color-divider);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    padding: var(--space-5);
  }
  .rate-row:hover { background: var(--color-surface-2); }
  .rate-row__cell--loan { grid-column: 1 / -1; }
  .rate-row__cell--nextweek, .rate-row__cell--nextmonth { grid-column: span 1; }
  .rate-row__celllabel { display:block; }
  .range-bar { max-width: none; }
  .rate-snapshot__foot { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
  .rate-row { grid-template-columns: 1fr; }
  .rate-row__cell--rate, .rate-row__cell--change,
  .rate-row__cell--nextweek, .rate-row__cell--nextmonth { grid-column: 1 / -1; }
}

/* Rate-movement chips (accessible: arrow glyph + text + bar, never color-only) */
.movement { display:inline-flex; flex-direction:column; gap: 5px; min-width: 9.5rem; }
.movement__chip {
  display:inline-flex; align-items:center; gap: .5rem;
  padding: .25rem .5rem .25rem .3rem;
  border:1px solid var(--color-divider);
  border-radius: var(--radius-full);
  background: var(--color-surface);
  font-size: var(--text-xs); line-height: 1.15;
  white-space: normal;
}
.movement__arrow {
  display:inline-flex; align-items:center; justify-content:center;
  width: 1.75rem; height: 1.75rem; flex: 0 0 auto;
  border-radius: var(--radius-full);
  font-weight: 700; font-size: 1rem;
  background: var(--color-text-faint); color: var(--color-text-inverse);
}
.movement__text { display:inline-flex; flex-direction:column; }
.movement__dir { font-weight: 700; color: var(--color-text); }
.movement__range { color: var(--color-text-muted); }
.movement__bar {
  position: relative; height: 5px; border-radius: var(--radius-full);
  background: var(--color-divider); overflow: hidden; max-width: 9rem;
}
.movement__bar > span {
  position:absolute; inset: 0 auto 0 0; height: 100%;
  border-radius: var(--radius-full);
  background: var(--color-text-faint);
}
.movement--down .movement__arrow { background: var(--color-success); }
.movement--down .movement__bar > span { background: var(--color-success); }
.movement--up .movement__arrow { background: var(--color-error); }
.movement--up .movement__bar > span { background: var(--color-error); }
.movement--mixed .movement__arrow { background: var(--color-warning); }
.movement--mixed .movement__bar > span { background: var(--color-warning); }
.movement--flat .movement__arrow { background: var(--color-text-muted); }
.movement--flat .movement__bar > span { background: var(--color-text-muted); }
@media (max-width: 640px) {
  .movement { min-width: 8rem; }
}

/* Calculator */
.calc {
  background: var(--color-surface);
  border:1px solid var(--color-divider);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display:grid;
  gap: var(--space-6);
  grid-template-columns: 1fr 1fr;
  box-shadow: var(--shadow-sm);
}
@media (max-width: 720px) { .calc { grid-template-columns: 1fr; } }
.calc__group { display:flex; flex-direction:column; gap: var(--space-1); }
.calc label { font-size: var(--text-sm); color: var(--color-text-muted); font-weight: 500; }
.calc input {
  padding: .65rem .8rem;
  border:1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface-2); color: var(--color-text);
}
.calc select,
.quiz-card select {
  padding: .65rem .8rem;
  border:1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface-2);
  color: var(--color-text);
}
.calc--stacked { grid-template-columns: 1.15fr .85fr; }
.calc__grid { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: var(--space-4); }
@media (max-width: 820px) { .calc--stacked, .calc__grid { grid-template-columns: 1fr; } }
.calc input:focus { border-color: var(--color-primary); outline: none; box-shadow: 0 0 0 3px var(--color-primary-tint); }
.calc__results { background: var(--color-primary); color: var(--color-text-inverse); border-radius: var(--radius-md); padding: var(--space-5); display:flex; flex-direction:column; gap: var(--space-3); }
.calc__results .big { font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 500; line-height:1; }
.calc__results .row { display:flex; justify-content:space-between; font-size: var(--text-sm); color: rgba(251,248,241,.85); }
.calc__results .row span:last-child { color: var(--color-text-inverse); font-weight:600; }

/* Sidebar layout (article) */
.article {
  display:grid; grid-template-columns: minmax(0,1fr) 300px; gap: var(--space-12);
  align-items: start;
}
@media (max-width: 900px) { .article { grid-template-columns: 1fr; } }
.article .prose { max-width: 68ch; }
.article .prose p, .article .prose ul, .article .prose ol { margin-bottom: var(--space-4); }
.article .prose ul, .article .prose ol { padding-left: var(--space-6); }
.article .prose li { margin-bottom: var(--space-2); }
.article .prose h2 { margin-top: var(--space-2); }

/* Editorial rhythm helpers for long-form guides */
.prose-rule {
  border: 0; height: 1px; background: var(--color-divider);
  margin-block: var(--space-8);
}
.prose-callout {
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  padding: var(--space-5) var(--space-6);
  margin-bottom: var(--space-6);
  box-shadow: var(--shadow-sm);
}
.prose-callout__label {
  display:block; font-size: var(--text-xs); font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--color-text-muted); margin-bottom: var(--space-2);
}
.prose-callout p { margin: 0; }
.prose-callout ul { margin: 0; padding-left: var(--space-5); }
.prose-callout li:last-child { margin-bottom: 0; }
.prose-callout--lead {
  background: linear-gradient(135deg, var(--color-primary-tint), var(--color-surface));
  border-color: color-mix(in oklab, var(--color-primary) 22%, transparent);
}
.prose-callout--lead p { font-size: var(--text-lg); line-height: 1.5; color: var(--color-text); }
.prose-callout--checklist { border-left: 4px solid var(--color-accent); }
.aside { position: sticky; top: var(--space-20); display:flex; flex-direction:column; gap: var(--space-4); }
.aside .card { padding: var(--space-5); }
.aside h4 { font-family: var(--font-body); font-size: var(--text-sm); text-transform:uppercase; letter-spacing:.1em; color: var(--color-text-muted); margin-bottom: var(--space-2); }

/* Embed slot */
.embed-slot {
  border: 2px dashed var(--color-border);
  background: var(--color-surface-offset);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.embed-slot strong { color: var(--color-text); display:block; margin-bottom: var(--space-2); }
.embed-slot code { font-family: var(--font-mono); font-size: var(--text-xs); background: var(--color-surface); padding: .15rem .35rem; border-radius: var(--radius-sm); }

/* Competitor-inspired modules */
.tool-band {
  display:grid;
  grid-template-columns: minmax(0, .9fr) minmax(320px, .7fr);
  gap: var(--space-8);
  align-items:center;
  background: linear-gradient(135deg, var(--color-primary-tint), var(--color-surface));
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: clamp(var(--space-6), 5vw, var(--space-12));
  box-shadow: var(--shadow-md);
}
.tool-band > * { min-width: 0; }
@media (max-width: 860px) { .tool-band { grid-template-columns: 1fr; } }
.quiz-card {
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  display:flex;
  flex-direction:column;
  gap: var(--space-3);
  min-width: 0;
}
.quiz-card select { width: 100%; min-width: 0; }
.quiz-card label { font-size: var(--text-sm); color: var(--color-text-muted); font-weight:600; }
.recommendation {
  margin-top: var(--space-2);
  padding: var(--space-4);
  background: var(--color-accent-tint);
  border: 1px solid color-mix(in oklab, var(--color-accent) 28%, transparent);
  border-radius: var(--radius-md);
}
.recommendation p { margin-block: var(--space-2); font-size: var(--text-sm); color: var(--color-text-muted); }
.callout-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--space-4); margin-block: var(--space-5) var(--space-8); }
.callout {
  background: var(--color-surface);
  border-left: 4px solid var(--color-accent);
  border-radius: var(--radius-md);
  padding: var(--space-5);
}
.callout h3 { margin-top:0; font-family: var(--font-body); font-size: var(--text-base); font-weight:700; }
.outlook-panel {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: clamp(var(--space-5), 4vw, var(--space-8));
  box-shadow: var(--shadow-md);
  margin-block: var(--space-6);
}
.rate-chart { width: 100%; overflow-x:auto; }
.rate-chart svg { min-width: 720px; width: 100%; height:auto; }
.chart-grid { stroke: var(--color-divider); stroke-width: 1; }
.chart-label { fill: var(--color-text-muted); font-size: 12px; font-family: var(--font-body); }
.chart-label--forecast { fill: var(--color-accent-hover); font-weight: 700; }
.chart-band { fill: color-mix(in oklab, var(--color-accent) 22%, transparent); stroke: none; }
.chart-line { fill: none; stroke-width: 4; stroke-linecap: round; stroke-linejoin: round; }
.chart-line--history { stroke: var(--color-primary); }
.chart-line--forecast { stroke: var(--color-accent); stroke-dasharray: 7 7; }
.chart-dot { fill: var(--color-primary); stroke: var(--color-surface); stroke-width: 2; }
.chart-dot--forecast { fill: var(--color-accent); }
.chart-divider { stroke: var(--color-border); stroke-width: 1; stroke-dasharray: 4 6; }
.chart-note, .chart-value { fill: var(--color-text); font-size: 13px; font-weight: 700; font-family: var(--font-body); }
.rate-watch {
  display:grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(260px, .95fr);
  gap: var(--space-6);
  align-items:start;
}
.rate-watch--compact { grid-template-columns: minmax(0, .85fr) minmax(280px, 1.15fr); }
.rate-watch__lead { min-width:0; }
.rate-watch__lead p { color: var(--color-text-muted); }
.rate-bias {
  margin-block: var(--space-5);
  padding: var(--space-4);
  background: var(--color-accent-tint);
  border: 1px solid color-mix(in oklab, var(--color-accent) 24%, transparent);
  border-radius: var(--radius-lg);
}
.rate-bias span, .signal-card span {
  display:block;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.rate-bias strong {
  display:block;
  margin-top: var(--space-1);
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--color-text);
}
.rate-bias small { display:block; color: var(--color-text-muted); font-size: var(--text-xs); margin-top: var(--space-2); }
.rate-bias__bar {
  height: 10px;
  margin-top: var(--space-3);
  border-radius: var(--radius-full);
  background: color-mix(in oklab, var(--color-border) 70%, transparent);
  overflow:hidden;
}
.rate-bias__bar span {
  display:block;
  height:100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
}
.signal-board {
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}
.signal-card {
  min-width:0;
  background: var(--color-surface-2);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
}
.signal-card strong {
  display:block;
  margin-top: var(--space-2);
  color: var(--color-text);
}
.signal-card p {
  margin-top: var(--space-2);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.signal-card--down {
  background: color-mix(in oklab, var(--color-success) 10%, var(--color-surface-2));
  border-color: color-mix(in oklab, var(--color-success) 28%, var(--color-divider));
}
.decision-card {
  grid-column: 1 / -1;
  display:grid;
  grid-template-columns: minmax(240px, .8fr) minmax(280px, 1.2fr);
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--color-surface-2);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
}
.rate-watch--compact .decision-card { grid-column:auto; }
.toggle-group {
  display:flex;
  gap: var(--space-2);
  flex-wrap:wrap;
  align-self:start;
}
.toggle-group button {
  min-height:44px;
  padding: .65rem .9rem;
  border:1px solid var(--color-border);
  border-radius: var(--radius-full);
  color: var(--color-text);
  background: var(--color-surface);
  font-size: var(--text-sm);
  font-weight:700;
}
.toggle-group button.is-active {
  color: var(--color-text-inverse);
  background: var(--color-primary);
  border-color: var(--color-primary);
}
.decision-card__copy h3 { margin-top:0; font-family: var(--font-body); font-size: var(--text-lg); }
.decision-card__copy p { color: var(--color-text-muted); margin-top: var(--space-2); }
.watch-list {
  grid-column: 1 / -1;
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}
.watch-list div {
  padding: var(--space-4);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-md);
  background: var(--color-surface);
}
.watch-list p { margin-top: var(--space-2); color: var(--color-text-muted); font-size: var(--text-sm); }
.scenario-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-4); margin-top: var(--space-5); }
.scenario { border:1px solid var(--color-divider); border-radius: var(--radius-md); padding: var(--space-4); background: var(--color-surface-2); }
.scenario strong { display:block; font-size: var(--text-lg); color: var(--color-primary); font-family: var(--font-display); }
.scenario p { color: var(--color-text-muted); font-size: var(--text-sm); margin-top: var(--space-2); }
.comparison-cards { display:grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--space-5); }
.loan-card {
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}
.loan-card h2 { margin-top: var(--space-3); }
.loan-card ul { margin-top: var(--space-4); padding-left: var(--space-5); color: var(--color-text-muted); }
.state-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: var(--space-3); margin-block: var(--space-6); }
.state-link {
  display:block;
  padding: var(--space-3) var(--space-4);
  background: var(--color-surface);
  border:1px solid var(--color-divider);
  border-radius: var(--radius-md);
  text-decoration:none;
  font-weight:600;
}
.state-link:hover { border-color: var(--color-accent); background: var(--color-accent-tint); }
details {
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  background: var(--color-surface);
  margin-block: var(--space-3);
}
summary { cursor:pointer; font-weight:700; color: var(--color-text); }
details p { margin-top: var(--space-3); color: var(--color-text-muted); }

/* Comparison table */
.cmp-table { font-size: var(--text-sm); }
.cmp-table th, .cmp-table td { padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--color-divider); vertical-align: top; }
.cmp-table th { background: var(--color-surface-offset); text-align:left; color: var(--color-text); font-weight: 600; }
.cmp-table th:first-child { width: 24%; }

/* Newsletter */
.newsletter { display:flex; gap: var(--space-2); flex-wrap:wrap; align-items:stretch; }
.newsletter input { flex:1 1 220px; padding: .75rem .9rem; border:1px solid var(--color-border); border-radius: var(--radius-md); background: var(--color-surface-2); color: var(--color-text); }
.newsletter button { padding: .75rem 1.25rem; border-radius: var(--radius-md); background: var(--color-primary); color: var(--color-text-inverse); font-weight:600; }
.newsletter button:hover { background: var(--color-primary-hover); }
.newsletter__note { font-size: var(--text-xs); color: var(--color-text-muted); margin-top: var(--space-2); }

/* Cookie banner */
.cookie-banner {
  background: var(--color-surface);
  border:1px solid var(--color-divider);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  box-shadow: var(--shadow-sm);
  display:flex; gap: var(--space-3) var(--space-4); align-items:center; flex-wrap:wrap;
  font-size: var(--text-sm);
  max-width: 760px;
  margin: var(--space-4) auto 0;
}
.cookie-banner p { margin:0; flex:1 1 260px; color: var(--color-text-muted); line-height: 1.45; }
.cookie-banner p a { color: var(--color-primary); }
.cookie-banner .btns { display:flex; gap: var(--space-2); flex:0 0 auto; flex-wrap:wrap; }
.cookie-banner .btns .btn { padding: .5rem .9rem; font-size: var(--text-sm); }
.cookie-banner.hidden { display:none; }
@media (max-width: 480px) {
  .cookie-banner { align-items:stretch; }
  .cookie-banner .btns { width:100%; }
  .cookie-banner .btns .btn { flex:1 1 auto; text-align:center; }
}

/* Footer */
.footer {
  background: var(--color-surface-offset);
  border-top: 1px solid var(--color-divider);
  padding-block: var(--space-16) var(--space-8);
  margin-top: var(--space-20);
  font-size: var(--text-sm);
}
.footer__grid { display:grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: var(--space-8); }
@media (max-width: 720px) { .footer__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 920px) {
  .rate-watch,
  .rate-watch--compact { grid-template-columns: 1fr; }
  .decision-card { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .watch-list,
  .signal-board { grid-template-columns: 1fr; }
}
.footer h5 { font-family: var(--font-body); font-size: var(--text-xs); text-transform:uppercase; letter-spacing:.1em; color: var(--color-text-muted); margin-bottom: var(--space-3); }
.footer ul { list-style:none; display:flex; flex-direction:column; gap: var(--space-2); }
.footer a { color: var(--color-text); text-decoration:none; }
.footer a:hover { color: var(--color-accent-hover); text-decoration: underline; }
.footer__legal { margin-top: var(--space-10); padding-top: var(--space-6); border-top:1px solid var(--color-divider); display:flex; justify-content:space-between; gap: var(--space-4); flex-wrap:wrap; color: var(--color-text-muted); font-size: var(--text-xs); }
.footer__disclaimer { margin-top: var(--space-4); color: var(--color-text-muted); font-size: var(--text-xs); max-width: 80ch; }

/* Misc */
.divider-rule { height:1px; background: var(--color-divider); border:none; margin-block: var(--space-8); }
.kbd { font-family: var(--font-mono); font-size: .85em; background: var(--color-surface-offset); padding: .05rem .35rem; border-radius: var(--radius-sm); border:1px solid var(--color-divider); }
.tag { display:inline-block; font-size: var(--text-xs); padding: .15rem .55rem; border-radius: var(--radius-full); border:1px solid var(--color-border); color: var(--color-text-muted); margin-right: var(--space-1); }

/* Mobile menu toggle button */
.menu-toggle {
  display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:36px; border-radius: var(--radius-full); border:1px solid var(--color-border);
}

/* -------------------- "Rates pulled" date stamp -------------------- */
.date-stamp {
  display:inline-flex; align-items:center; gap: var(--space-2);
  margin-top: var(--space-3); margin-bottom: 0;
  font-size: var(--text-sm); color: var(--color-text-muted); font-weight: 500;
}
.date-stamp strong { color: var(--color-text); font-weight: 700; }
.date-stamp__dot {
  width: .55rem; height: .55rem; flex:0 0 auto; border-radius: var(--radius-full);
  background: var(--color-success);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--color-success) 18%, transparent);
}

/* -------------------- State-page compact rate cards -------------------- */
/* State page: full-width snapshot above the fold */
.state-snapshot-section { padding-top: clamp(var(--space-8), 4vw, var(--space-12)); }
.state-snapshot__head { max-width: 70ch; }
.state-snapshot__below {
  display:grid; gap: var(--space-6);
  grid-template-columns: minmax(0, 1.6fr) minmax(280px, 1fr);
  align-items: start;
  margin-top: var(--space-6);
}
@media (max-width: 860px) { .state-snapshot__below { grid-template-columns: 1fr; } }
.state-checklist { align-self: start; }
.state-checklist__list { padding-left: var(--space-5); color: var(--color-text-muted); display:flex; flex-direction:column; gap: var(--space-2); margin-bottom: var(--space-4); }

.srate-grid {
  display:grid; gap: var(--space-4);
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.srate-card {
  min-width: 0;
  display:flex; flex-direction:column; gap: var(--space-4);
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
}
.srate-card__top {
  display:flex; align-items:flex-start; justify-content:space-between;
  gap: var(--space-3); flex-wrap:wrap;
}
.srate-card__id { display:flex; flex-direction:column; min-width:0; }
.srate-card__loan { font-weight: 700; font-size: var(--text-base); color: var(--color-text); line-height: 1.2; }
.srate-card__use { font-size: var(--text-xs); color: var(--color-text-muted); }
.srate-card__rate { display:flex; flex-direction:column; align-items:flex-end; text-align:right; }
.srate-card__pct {
  font-family: var(--font-display); font-weight: 500; line-height: 1;
  font-size: var(--text-2xl); color: var(--color-primary); letter-spacing: -0.01em;
}
.srate-card__pct sup { font-size: .5em; font-weight: 600; top: -0.6em; }
.srate-card__apr { font-size: var(--text-xs); color: var(--color-text-muted); margin-top: var(--space-1); }
.srate-card__outlook {
  display:grid; grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
  padding-top: var(--space-4); border-top: 1px solid var(--color-divider);
}
.srate-card__col { display:flex; flex-direction:column; gap: var(--space-2); min-width:0; }
.srate-card__lbl {
  font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .08em;
  color: var(--color-text-faint); font-weight: 600;
}
.srate-card__col .movement { min-width: 0; gap: 7px; width: 100%; }
.srate-card__col .movement__chip { font-size: .8rem; padding: .35rem .6rem .35rem .35rem; }
.srate-card__col .movement__bar { max-width: none; }
@media (max-width: 380px) {
  .srate-card__outlook { grid-template-columns: 1fr; }
}

/* -------------------- About page -------------------- */
.about-grid {
  display:grid; gap: var(--space-5);
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  margin-bottom: var(--space-8);
}
.about-card {
  min-width: 0;
  background: var(--color-surface-2);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
}
.about-card__icon {
  display:inline-flex; align-items:center; justify-content:center;
  width: 3rem; height: 3rem; margin-bottom: var(--space-4);
  border-radius: var(--radius-lg);
  background: var(--color-primary-tint); color: var(--color-primary);
}
.about-card h2 { margin-top: 0; margin-bottom: var(--space-2); font-size: var(--text-lg); }
.about-card p { color: var(--color-text-muted); margin: 0; max-width: 56ch; }
.about-callout {
  display:flex; align-items:center; justify-content:space-between; gap: var(--space-6);
  flex-wrap:wrap;
  background: linear-gradient(135deg, var(--color-primary-tint), var(--color-surface));
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-xl);
  padding: clamp(var(--space-5), 4vw, var(--space-8));
  box-shadow: var(--shadow-sm);
}
.about-callout > div { min-width: 0; flex: 1 1 380px; }
.about-callout h2 { margin-top: 0; }
.about-callout p { color: var(--color-text-muted); margin-bottom: 0; }
.about-callout .btn { flex: 0 0 auto; }
.about-contact { margin-top: var(--space-10); }
.about-contact h2 { margin-bottom: var(--space-2); }
.about-contact p { color: var(--color-text-muted); }
