/* financialdoctors.co.nz — CSS v2 rebuilt 2026-04-16
   Tokens extracted per SOP Step 3d v2 from forbes.com/advisor/credit-cards/best-credit-cards/
   (YMYL-niche strategy, highly competitive financial-comparison vertical)
   Methodology: astro-design atomic tokens + BEM naming (fd- prefix)
   Pattern codes: Hero D / Rankings F / Reviews A */

:root {
  /* -- Surfaces (60%) — cool neutral, no warm beige -- */
  --fd-paper:         #F6F7FA;
  --fd-card:          #FFFFFF;
  --fd-paper-alt:     #EAECF2;

  /* -- Ink (30%) -- */
  --fd-ink:           #1A2D5C;
  --fd-ink-soft:      #3B4A8A;
  --fd-muted:         #4B5563;
  --fd-subtle:        #6B7480;

  /* -- Accent (10%) — Forbes CTA-blue (was gold, pivoted from yellow palette) -- */
  --fd-accent:        #0066A1;
  --fd-accent-hover:  #004B7A;
  --fd-accent-soft:   #E6F0F7;
  --fd-link:          #0066A1;

  /* -- Semantic -- */
  --fd-sage:          #3B6E4A;
  --fd-sage-soft:     #E6EDDF;
  --fd-caution:       #C20000;
  --fd-warn-soft:     #FCE7E5;

  /* -- Structure — cool grey hairline -- */
  --fd-hair:          #D5D8E0;
  --fd-hair-strong:   #A8ADB8;

  /* -- Typography -- */
  --fd-font-display: Georgia, 'Iowan Old Style', 'Palatino Linotype', 'Book Antiqua', Palatino, serif;
  --fd-font-body:    system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --fd-text-xs:   0.75rem;
  --fd-text-sm:   0.875rem;
  --fd-text-base: 1rem;
  --fd-text-lg:   1.125rem;
  --fd-text-xl:   1.375rem;
  --fd-text-2xl:  1.75rem;
  --fd-text-3xl:  2.25rem;
  --fd-text-4xl:  3rem;
  --fd-lh-tight:  1.2;
  --fd-lh-snug:   1.45;
  --fd-lh-base:   1.65;
  --fd-ls-eyebrow: 0.18em;
  --fd-ls-display: -0.005em;

  /* -- Spacing (8pt) -- */
  --fd-space-1: 4px; --fd-space-2: 8px; --fd-space-3: 12px; --fd-space-4: 16px;
  --fd-space-5: 24px; --fd-space-6: 32px; --fd-space-7: 40px; --fd-space-8: 48px;
  --fd-space-9: 64px; --fd-space-10: 80px; --fd-space-11: 96px;

  /* -- Effects -- */
  --fd-radius-sm: 3px;
  --fd-radius-md: 6px;
  --fd-radius-lg: 12px;
  --fd-radius-pill: 999px;
  --fd-shadow-sm: 0 1px 2px rgba(26,45,92,.04);
  --fd-shadow-md: 0 4px 16px rgba(26,45,92,.06);
  --fd-shadow-lg: 0 12px 32px rgba(26,45,92,.08);
  --fd-t-fast: 120ms ease-out;
  --fd-t-base: 200ms ease-out;

  /* -- Layout -- */
  --fd-max: 1120px;
  --fd-read: 680px;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--fd-font-body);
  font-size: var(--fd-text-base);
  line-height: var(--fd-lh-base);
  color: var(--fd-ink);
  background: var(--fd-card);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* -- Typography atoms (Merriweather display + Public Sans body, per Forbes Advisor) -- */
h1, h2, h3, h4 {
  font-family: var(--fd-font-display);
  font-weight: 700;
  color: var(--fd-ink);
  line-height: var(--fd-lh-tight);
  letter-spacing: var(--fd-ls-display);
  margin: 0;
}
h1 { font-size: clamp(2rem, 4.5vw, 2.75rem); font-weight: 700; }
h2 { font-size: clamp(1.375rem, 2.6vw, 1.75rem); margin-top: var(--fd-space-8); margin-bottom: var(--fd-space-4); font-weight: 700; }
h3 { font-size: 1.25rem; font-weight: 700; margin-top: var(--fd-space-6); margin-bottom: var(--fd-space-3); }
h4 { font-size: 1rem; font-weight: 700; margin-top: var(--fd-space-5); margin-bottom: var(--fd-space-2); }

p { margin: 0 0 var(--fd-space-4); }
p:last-child { margin-bottom: 0; }

a { color: var(--fd-link); text-decoration: underline; text-underline-offset: 2px; text-decoration-thickness: 1px; transition: color var(--fd-t-fast); }
a:hover { color: #0082CE; text-decoration-thickness: 2px; }

strong { font-weight: 700; color: var(--fd-ink); }
hr { border: 0; border-top: 1px solid var(--fd-hair); margin: var(--fd-space-9) 0; }
ul, ol { padding-left: var(--fd-space-5); margin: 0 0 var(--fd-space-4); }
li { margin: var(--fd-space-1) 0; }
code { background: var(--fd-paper-alt); padding: 1px 6px; border-radius: var(--fd-radius-sm); font-size: 0.92em; }

:focus-visible { outline: 2px solid var(--fd-accent); outline-offset: 3px; border-radius: var(--fd-radius-sm); }

/* -- Layout -- */
.fd-wrap { max-width: var(--fd-max); margin: 0 auto; padding: 0 var(--fd-space-5); }
.fd-read { max-width: var(--fd-read); }

.fd-skip { position: absolute; left: -999px; top: 0; background: var(--fd-ink); color: #fff; padding: var(--fd-space-3) var(--fd-space-4); z-index: 200; }
.fd-skip:focus { left: 0; }

/* -- Eyebrow (Forbes "BEST TRAVEL CARD" style pill) -- */
.fd-eyebrow {
  display: inline-block;
  font-size: var(--fd-text-xs);
  font-weight: 700;
  letter-spacing: var(--fd-ls-eyebrow);
  text-transform: uppercase;
  color: var(--fd-ink-soft);
}

/* -- Topbar -- */
.fd-topbar {
  border-bottom: 1px solid var(--fd-hair);
  background: var(--fd-paper);
  position: sticky; top: 0; z-index: 50;
}
.fd-topbar__inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--fd-space-4) 0; gap: var(--fd-space-4);
}
.fd-brand { display: inline-flex; align-items: center; text-decoration: none; }
.fd-brand img { display: block; height: 40px; width: auto; }
.fd-brand:hover { text-decoration: none; }

.fd-nav { display: flex; gap: var(--fd-space-6); align-items: center; }
.fd-nav a {
  color: var(--fd-ink);
  text-decoration: none;
  font-size: var(--fd-text-sm);
  font-weight: 600;
  padding: var(--fd-space-2) 0;
  border-bottom: 2px solid transparent;
  transition: border-color var(--fd-t-fast), color var(--fd-t-fast);
}
.fd-nav a:hover { border-color: var(--fd-ink-soft); color: var(--fd-ink-soft); }
.fd-nav a.is-active { border-color: var(--fd-accent); color: var(--fd-ink); }

.fd-burger { display: none; background: none; border: 0; padding: var(--fd-space-2); cursor: pointer; color: var(--fd-ink); }

/* -- Hero (Pattern D — minimal, editorial whitespace) -- */
.fd-hero {
  background: var(--fd-card);
  padding: var(--fd-space-11) 0 var(--fd-space-7);
  border-bottom: 1px solid var(--fd-hair);
}
.fd-hero__eyebrow {
  display: inline-block;
  font-size: var(--fd-text-xs);
  letter-spacing: var(--fd-ls-eyebrow);
  text-transform: uppercase;
  color: var(--fd-ink-soft);
  font-weight: 700;
  margin-bottom: var(--fd-space-5);
}
.fd-hero h1 {
  max-width: 920px;
  margin-bottom: var(--fd-space-5);
}
.fd-hero__lede {
  font-family: var(--fd-font-display);
  font-size: var(--fd-text-lg);
  line-height: var(--fd-lh-snug);
  color: var(--fd-muted);
  max-width: 720px;
  font-weight: 400;
  font-style: italic;
  margin: 0 0 var(--fd-space-7);
}
.fd-hero__byline {
  color: var(--fd-muted);
  font-size: var(--fd-text-sm);
  line-height: var(--fd-lh-snug);
  padding: var(--fd-space-3) 0;
  border-top: 1px solid var(--fd-hair);
  border-bottom: 1px solid var(--fd-hair);
  margin: 0 0 var(--fd-space-5);
}
.fd-hero__byline strong { color: var(--fd-ink); font-weight: 600; }
.fd-hero__byline-sep { color: var(--fd-hair-strong); margin: 0 var(--fd-space-2); user-select: none; }
.fd-hero__disclosure {
  font-size: 10.5px;
  line-height: 1.45;
  color: var(--fd-subtle);
  margin: 0 0 var(--fd-space-5);
  max-width: 760px;
}
.fd-hero__disclosure strong { color: var(--fd-muted); font-weight: 700; }
.fd-hero__disclosure a { color: var(--fd-muted); text-decoration: underline; text-underline-offset: 2px; }
.fd-hero__disclosure a:hover { color: var(--fd-ink); }

.fd-chips { display: flex; flex-wrap: wrap; gap: var(--fd-space-2); margin-top: var(--fd-space-5); }
.fd-chip {
  display: inline-block;
  background: var(--fd-card);
  border: 1px solid var(--fd-hair);
  padding: var(--fd-space-2) var(--fd-space-4);
  border-radius: var(--fd-radius-pill);
  text-decoration: none;
  color: var(--fd-ink);
  font-size: var(--fd-text-sm); font-weight: 600;
  transition: border-color var(--fd-t-fast), background var(--fd-t-fast);
}
.fd-chip:hover { border-color: var(--fd-ink-soft); background: var(--fd-accent-soft); color: var(--fd-ink); text-decoration: none; }

/* -- Section containers -- */
.fd-section { padding: var(--fd-space-8) 0; }
.fd-section--tint { background: var(--fd-paper); }

/* -- Editor's pick — compact horizontal editorial card -- */
.fd-editors-pick {
  background: var(--fd-card);
  border: 1px solid var(--fd-hair);
  border-left: 4px solid var(--fd-sage);
  padding: var(--fd-space-4) var(--fd-space-5);
  border-radius: var(--fd-radius-md);
  margin: 0 0 var(--fd-space-5);
  box-shadow: var(--fd-shadow-sm);
}
.fd-editors-pick__eyebrow {
  font-size: var(--fd-text-xs);
  letter-spacing: var(--fd-ls-eyebrow);
  text-transform: uppercase;
  font-weight: 700;
  color: var(--fd-sage);
  margin: 0 0 var(--fd-space-2);
}
.fd-editors-pick__body {
  display: flex;
  align-items: center;
  gap: var(--fd-space-5);
  justify-content: space-between;
}
.fd-editors-pick__logo {
  flex: 0 0 auto;
  width: 108px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #0A0D1F;
  border-radius: var(--fd-radius-sm);
  padding: 8px 12px;
}
.fd-editors-pick__logo img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
}
.fd-editors-pick__content { flex: 1 1 auto; min-width: 0; }
.fd-editors-pick__name {
  font-family: var(--fd-font-display);
  font-size: var(--fd-text-xl);
  line-height: var(--fd-lh-tight);
  letter-spacing: var(--fd-ls-display);
  color: var(--fd-ink);
  margin: 0 0 var(--fd-space-2);
  font-weight: 700;
}
.fd-editors-pick__bonus {
  font-weight: 400;
  color: var(--fd-ink-soft);
}
.fd-editors-pick__stats {
  font-size: var(--fd-text-sm);
  color: var(--fd-muted);
  line-height: var(--fd-lh-snug);
  margin: 0 0 var(--fd-space-2);
}
.fd-editors-pick__stats strong {
  color: var(--fd-ink);
  font-weight: 700;
}
.fd-editors-pick__verify {
  font-size: var(--fd-text-sm);
  color: var(--fd-ink);
  line-height: var(--fd-lh-snug);
  margin: 0;
}
.fd-editors-pick__verify strong {
  color: var(--fd-sage);
  font-weight: 700;
  letter-spacing: 0.01em;
}
.fd-editors-pick__check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  margin-right: 4px;
  background: var(--fd-sage);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  border-radius: 50%;
  vertical-align: -3px;
}
.fd-editors-pick__cta {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: var(--fd-space-2);
  padding: 10px var(--fd-space-4);
  background: transparent;
  color: var(--fd-ink);
  border: 1.5px solid var(--fd-ink);
  text-decoration: none;
  border-radius: var(--fd-radius-sm);
  font-size: var(--fd-text-sm);
  font-weight: 600;
  min-height: 40px;
  white-space: nowrap;
  transition: var(--fd-t-fast);
}
.fd-editors-pick__cta:hover { background: var(--fd-ink); color: #fff; }
.fd-editors-pick__cta-arrow { transition: var(--fd-t-fast); }
.fd-editors-pick__cta:hover .fd-editors-pick__cta-arrow { transform: translateX(2px); }

/* -- Ranking card — content-first with subtle corner numbering -- */
.fd-rank-card {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--fd-space-5);
  align-items: center;
  background: var(--fd-card);
  border: 1px solid var(--fd-hair);
  border-radius: var(--fd-radius-md);
  padding: var(--fd-space-5) var(--fd-space-6) var(--fd-space-5) var(--fd-space-6);
  margin-bottom: var(--fd-space-3);
  transition: border-color var(--fd-t-fast), box-shadow var(--fd-t-fast), transform var(--fd-t-fast);
  color: var(--fd-ink);
}
.fd-rank-card:hover { border-color: var(--fd-ink-soft); box-shadow: var(--fd-shadow-md); transform: translateY(-1px); }
.fd-rank-card--featured {
  border-top: 4px solid var(--fd-accent);
  padding-top: var(--fd-space-6);
}

/* Subtle corner numbering — tiny, barely noticeable */
.fd-rank-card__badge {
  position: absolute;
  top: 8px;
  left: 12px;
  font-family: var(--fd-font-body);
  color: var(--fd-subtle);
  pointer-events: none;
  opacity: 0.55;
}
.fd-rank-card__num { font-size: 0.68rem; font-weight: 500; letter-spacing: 0.02em; }
.fd-rank-card__num::before { content: "#"; opacity: 0.7; }
.fd-rank-card__label { display: none; }

/* Content — BONUS is the visual anchor, brand is the eyebrow */
.fd-rank-card__content { min-width: 0; padding-top: var(--fd-space-3); }
.fd-rank-card__brand {
  font-family: var(--fd-font-body);
  font-size: var(--fd-text-xs);
  font-weight: 600;
  color: var(--fd-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 var(--fd-space-1);
  line-height: 1.2;
}
.fd-rank-card__bonus {
  font-family: var(--fd-font-display);
  font-size: var(--fd-text-xl);
  font-weight: 700;
  color: var(--fd-ink);
  letter-spacing: var(--fd-ls-display);
  margin: 0 0 var(--fd-space-2);
  line-height: 1.55;
}
.fd-rank-card__meta { display: flex; flex-wrap: wrap; gap: var(--fd-space-2) var(--fd-space-4); font-size: var(--fd-text-sm); color: var(--fd-muted); }
.fd-rank-card__meta > span strong { color: var(--fd-ink); font-weight: 700; }
.fd-rank-card__code {
  display: inline-block; padding: 2px 8px;
  background: var(--fd-ink); color: #fff;
  border-radius: var(--fd-radius-sm);
  font-size: var(--fd-text-xs); font-weight: 700;
  letter-spacing: 0.06em; font-family: var(--fd-font-body);
}

.fd-rank-card__cta { white-space: nowrap; }

/* -- CTA button (Forbes blue CTA — we use gold for brand, blue is link colour) -- */
.fd-cta {
  background: var(--fd-accent);
  color: #fff;
  padding: var(--fd-space-3) var(--fd-space-5);
  border-radius: var(--fd-radius-sm);
  text-decoration: none;
  font-weight: 700;
  font-size: var(--fd-text-sm);
  letter-spacing: 0.02em;
  border: 2px solid var(--fd-accent);
  transition: background var(--fd-t-fast), border-color var(--fd-t-fast);
  text-align: center;
  min-height: 44px;
  line-height: 1;
  display: inline-flex; align-items: center; justify-content: center;
}
.fd-cta:hover { background: var(--fd-accent-hover); border-color: var(--fd-accent-hover); color: #fff; text-decoration: none; }
.fd-cta--ghost { background: transparent; color: var(--fd-accent); }
.fd-cta--ghost:hover { background: var(--fd-accent); color: #fff; }

/* -- Review card (Pattern A — stacked, Forbes card structure) -- */
.fd-review {
  background: var(--fd-card);
  border: 1px solid var(--fd-hair);
  border-radius: var(--fd-radius-md);
  padding: var(--fd-space-7) var(--fd-space-8);
  margin: var(--fd-space-6) 0;
  box-shadow: var(--fd-shadow-sm);
}
.fd-review--featured { border-top: 4px solid var(--fd-accent); padding-top: var(--fd-space-7); }
.fd-review__rank {
  display: inline-block;
  font-family: var(--fd-font-body);
  font-size: var(--fd-text-xs);
  color: var(--fd-accent);
  font-weight: 700;
  letter-spacing: var(--fd-ls-eyebrow);
  text-transform: uppercase;
  margin-bottom: var(--fd-space-2);
}
.fd-review__title { margin: 0 0 var(--fd-space-2); font-size: var(--fd-text-2xl); }
.fd-review__subtitle {
  font-family: var(--fd-font-display);
  font-size: var(--fd-text-base);
  color: var(--fd-muted);
  font-style: italic;
  margin-bottom: var(--fd-space-5);
}
.fd-review__meta {
  display: flex; flex-wrap: wrap; gap: var(--fd-space-2) var(--fd-space-5);
  padding: var(--fd-space-3) var(--fd-space-4);
  background: var(--fd-paper-alt);
  border: 1px solid var(--fd-hair);
  border-radius: var(--fd-radius-sm);
  margin: var(--fd-space-4) 0 var(--fd-space-5);
  font-size: var(--fd-text-sm);
  color: var(--fd-muted);
}
.fd-review__meta span strong { color: var(--fd-ink); }

.fd-prons { margin: var(--fd-space-4) 0; }
.fd-prons h4 { margin: 0 0 var(--fd-space-1); }
.fd-prons p { color: var(--fd-muted); }
.fd-prons p strong { color: var(--fd-ink); }

.fd-licence {
  display: inline-block;
  padding: var(--fd-space-1) var(--fd-space-3);
  background: var(--fd-sage-soft);
  color: var(--fd-sage);
  border: 1px solid #BCCBC0;
  border-radius: var(--fd-radius-sm);
  font-size: var(--fd-text-xs); font-weight: 700;
  margin-top: var(--fd-space-2);
  letter-spacing: 0.02em;
}
.fd-licence--medium { background: #EAECF2; color: #3B4A8A; border-color: #C7CCD7; }
.fd-licence--high   { background: var(--fd-warn-soft); color: var(--fd-caution); border-color: #F4C4BE; }

/* -- FAQ -- */
.fd-faq details { border-bottom: 1px solid var(--fd-hair); padding: var(--fd-space-4) 0; }
.fd-faq details:last-child { border-bottom: 0; }
.fd-faq summary {
  cursor: pointer;
  font-family: var(--fd-font-display);
  font-size: var(--fd-text-base);
  font-weight: 700;
  color: var(--fd-ink);
  list-style: none;
  padding-right: var(--fd-space-7);
  position: relative;
}
.fd-faq summary::after {
  content: '+'; position: absolute; right: 0; top: 0;
  font-size: var(--fd-text-xl); color: var(--fd-link); font-weight: 400;
  transition: transform var(--fd-t-base);
}
.fd-faq details[open] summary::after { content: '−'; }
.fd-faq summary::-webkit-details-marker { display: none; }
.fd-faq details > *:not(summary) { margin-top: var(--fd-space-3); color: var(--fd-muted); }

/* -- Responsible-gambling callout (left-border accent, no tinted-box muddle) -- */
.fd-rg-callout {
  background: var(--fd-card);
  border: 1px solid var(--fd-hair);
  border-left: 4px solid var(--fd-sage);
  padding: var(--fd-space-5) var(--fd-space-6);
  border-radius: var(--fd-radius-sm);
  margin: var(--fd-space-6) 0;
  box-shadow: var(--fd-shadow-sm);
}
.fd-rg-callout h3 { margin: 0 0 var(--fd-space-2); color: var(--fd-sage); font-size: var(--fd-text-lg); }
.fd-rg-callout p:last-child { margin-bottom: 0; }

.fd-note {
  background: var(--fd-card);
  border: 1px solid var(--fd-hair);
  border-left: 4px solid var(--fd-accent);
  padding: var(--fd-space-4) var(--fd-space-5);
  margin: var(--fd-space-5) 0;
  font-size: var(--fd-text-sm);
  border-radius: var(--fd-radius-sm);
}

/* -- Footer (deep navy ink bg — Forbes authoritative foot pattern) -- */
.fd-foot {
  background: var(--fd-ink);
  color: #D4DCEC;
  padding: var(--fd-space-8) 0 var(--fd-space-5);
  margin-top: var(--fd-space-11);
  font-size: var(--fd-text-sm);
}
.fd-foot a { color: #F6F7FA; text-decoration: none; }
.fd-foot a:hover { color: var(--fd-accent); text-decoration: underline; }
.fd-foot__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: var(--fd-space-7);
  padding-bottom: var(--fd-space-6);
  border-bottom: 1px solid #2D3F6A;
}
.fd-foot__brand { font-family: var(--fd-font-display); font-size: var(--fd-text-xl); font-weight: 700; color: #fff; margin: 0 0 var(--fd-space-2); letter-spacing: var(--fd-ls-display); }
.fd-foot h4 { color: #F6F7FA; font-size: var(--fd-text-xs); letter-spacing: var(--fd-ls-eyebrow); text-transform: uppercase; margin: 0 0 var(--fd-space-3); font-family: var(--fd-font-body); font-weight: 700; }
.fd-foot ul { list-style: none; padding: 0; margin: 0; }
.fd-foot ul li { margin: var(--fd-space-1) 0; }
.fd-foot__helpline {
  background: #243E70;
  padding: var(--fd-space-3) var(--fd-space-4);
  border-radius: var(--fd-radius-sm);
  margin-top: var(--fd-space-4);
  font-size: var(--fd-text-sm);
  color: #E1E8F3;
  border-left: 3px solid var(--fd-sage);
}
.fd-foot__helpline strong { color: #fff; }

.fd-foot__bottom {
  padding-top: var(--fd-space-5);
  display: flex; flex-wrap: wrap; justify-content: space-between;
  gap: var(--fd-space-3);
  font-size: var(--fd-text-xs);
  color: #8A98B8;
}

/* -- Hidden accordion (user spec) -- */
.fd-hidden-accord { display: inline-block; position: relative; }
.fd-hidden-accord__btn {
  background: transparent; border: 1px solid #2D3F6A;
  color: #8A98B8; width: 28px; height: 28px; border-radius: var(--fd-radius-pill);
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0;
}
.fd-hidden-accord__btn:hover { border-color: var(--fd-accent); color: var(--fd-accent); }
.fd-hidden-accord__body { display: none; margin-top: var(--fd-space-2); font-size: var(--fd-text-xs); line-height: 1.3; }
.fd-hidden-accord.is-open .fd-hidden-accord__body { display: block; }

/* Invisible address (matches footer bg) */
.fd-foot .fd-addr-invis,
.fd-foot a.fd-addr-invis { color: var(--fd-ink); background: transparent; text-decoration: none; font-size: 0.7rem; }
.fd-foot a.fd-addr-invis:hover { color: var(--fd-ink); text-decoration: none; }

/* -- Author cards -- */
.fd-authors {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--fd-space-6);
  margin: var(--fd-space-7) 0;
}
.fd-author {
  background: var(--fd-card);
  border: 1px solid var(--fd-hair);
  padding: var(--fd-space-6);
  border-radius: var(--fd-radius-md);
  box-shadow: var(--fd-shadow-sm);
}
.fd-author h3 { margin: 0 0 var(--fd-space-1); font-size: var(--fd-text-xl); }
.fd-author__role {
  font-size: var(--fd-text-xs); letter-spacing: var(--fd-ls-eyebrow); text-transform: uppercase;
  color: var(--fd-accent); font-weight: 700; margin-bottom: var(--fd-space-3);
  font-family: var(--fd-font-body);
}
.fd-author__quote {
  font-family: var(--fd-font-display);
  font-style: italic;
  color: var(--fd-ink);
  border-left: 3px solid var(--fd-sage);
  padding: var(--fd-space-1) var(--fd-space-4);
  margin: var(--fd-space-4) 0 0;
  font-size: var(--fd-text-base);
}

.fd-dot { color: var(--fd-hair); margin: 0 var(--fd-space-2); }

/* -- Responsive -- */
@media (max-width: 900px) {
  .fd-rank-card {
    grid-template-columns: 1fr;
    gap: var(--fd-space-3);
  }
  .fd-rank-card__cta .fd-cta { width: 100%; }
}
@media (max-width: 820px) {
  body { font-size: 15px; }
  .fd-hero { padding: var(--fd-space-8) 0 var(--fd-space-6); }
  .fd-nav { display: none; position: absolute; top: 64px; left: 0; right: 0;
            background: var(--fd-paper); flex-direction: column; gap: 0;
            padding: var(--fd-space-3) var(--fd-space-5); border-bottom: 1px solid var(--fd-hair); z-index: 49; }
  .fd-nav.is-open { display: flex; }
  .fd-nav a { padding: var(--fd-space-3) 0; border-bottom: 1px solid var(--fd-hair); }
  .fd-nav a:last-child { border-bottom: 0; }
  .fd-burger { display: inline-flex; align-items: center; justify-content: center; }

  .fd-foot__grid { grid-template-columns: 1fr; gap: var(--fd-space-6); }
  .fd-review { padding: var(--fd-space-5); }
  .fd-editors-pick { padding: var(--fd-space-4) var(--fd-space-5); }
  .fd-editors-pick__body { flex-direction: column; align-items: stretch; gap: var(--fd-space-4); }
  .fd-editors-pick__cta { align-self: flex-start; }
}
