:root {
  --bg: #f6f5f1;
  --surface: #ffffff;
  --surface-alt: #ece8df;
  --ink: #171717;
  --muted: #55524b;
  --line: #d8d2c4;
  --accent: #783244;
  --accent-dark: #532231;
  --max: min(1180px, calc(100% - 2rem));
}
*, *::before, *::after { box-sizing: border-box; }
body { margin: 0; font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif; background: var(--bg); color: var(--ink); line-height: 1.65; }
img { max-width: 100%; height: auto; vertical-align: middle; }
a { color: var(--accent-dark); }
.site-header { position: sticky; top: 0; z-index: 20; background: rgba(255,255,255,.96); border-bottom: 1px solid var(--line); }
.site-header__inner, .container { width: var(--max); margin: 0 auto; }
.site-header__inner { padding: .75rem 0; display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.brand { display: inline-flex; align-items: center; gap: .65rem; text-decoration: none; color: var(--ink); font-weight: 800; min-width: 0; }
.brand-logo { width: 44px; height: 44px; object-fit: contain; flex: 0 0 auto; }
.brand-text { display: inline-flex; flex-direction: column; line-height: 1.08; min-width: 0; }
.brand-title { color: var(--ink); font-size: .98rem; white-space: nowrap; }
.brand-subtitle { color: var(--muted); font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; }
.nav-toggle { display: none; align-items: center; justify-content: center; width: 44px; height: 44px; margin-left: auto; padding: 0; border: 1px solid var(--line); border-radius: 6px; background: #fff; color: var(--ink); flex: 0 0 auto; }
.nav-toggle__icon { width: 22px; height: 16px; display: inline-flex; flex-direction: column; justify-content: space-between; }
.nav-toggle__bar { display: block; width: 100%; height: 2px; border-radius: 999px; background: currentColor; }
.nav-toggle__label { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
.nav-menu { display: flex; flex-wrap: wrap; gap: .35rem .72rem; list-style: none; margin: 0; padding: 0; align-items: center; }
.nav-menu a { color: var(--ink); font-size: .9rem; text-decoration: none; }
.nav-menu a[aria-current="page"] { color: var(--accent-dark); font-weight: 700; }
.nav-cta, .btn { display: inline-flex; align-items: center; justify-content: center; min-height: 42px; border-radius: 6px; text-decoration: none; font-weight: 700; }
.nav-cta { padding: .4rem .8rem; background: var(--accent-dark); color: #fff !important; }
.section { padding: 2.8rem 0; }
.section:nth-child(even) { background: rgba(255,255,255,.38); }
.section.cta { background: var(--accent-dark); color: #fff; border-block: 1px solid var(--accent-dark); }
.section.cta .prose p { color: #f3dfe5; max-width: 78ch; }
.section.cta h2 { color: #fff; }
.section.cta .btn--primary { background: #fff; color: var(--accent-dark); }
.hero, .page-hero { background: #fff; border-bottom: 1px solid var(--line); }
.hero__grid { display: grid; gap: 1.75rem; align-items: center; }
@media (min-width: 900px) { .hero__grid { grid-template-columns: 1.05fr .95fr; } }
h1, h2, h3 { line-height: 1.2; letter-spacing: 0; }
h1 { font-size: clamp(2rem, 4vw, 3.4rem); margin: 0 0 1rem; }
h2 { font-size: clamp(1.45rem, 3vw, 2.05rem); margin: 0 0 .8rem; }
h3 { font-size: 1.12rem; margin: 1.35rem 0 .45rem; }
.lede { font-size: 1.06rem; color: var(--muted); max-width: 66ch; }
.prose p { margin: 0 0 .95rem; color: var(--muted); }
.hero__actions, .cta-row { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 1rem; }
.btn { padding: .65rem 1rem; border: 1px solid transparent; }
.btn--primary { background: var(--accent-dark); color: #fff; }
.btn--ghost { background: #fff; border-color: var(--line); color: var(--ink); }
.fact-grid, .card-grid { display: grid; gap: 1rem; grid-template-columns: repeat(auto-fit, minmax(235px, 1fr)); align-items: stretch; }
.fact, .card, .note-card { background: var(--surface); border: 1px solid var(--line); border-radius: 8px; padding: 1rem; }
.fact b { display: block; color: var(--ink); margin-bottom: .25rem; }
.card { overflow: hidden; padding: 0; display: flex; flex-direction: column; height: 100%; }
.card img { width: 100%; aspect-ratio: 16 / 10; object-fit: cover; }
.card__body { padding: 1rem; flex: 1; }
.section-media { margin: 1.2rem 0; }
.section-media img { width: 100%; aspect-ratio: 16 / 7; object-fit: cover; border-radius: 8px; border: 1px solid var(--line); background: var(--surface); }
.mini-plan-grid { display: grid; gap: 1rem; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); margin: 1.2rem 0; }
.mini-plan-grid img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: 8px; border: 1px solid var(--line); background: var(--surface); }
.muted { color: var(--muted); font-size: .94rem; }
.table-wrap { overflow-x: auto; margin: 1rem 0; }
table { width: 100%; border-collapse: collapse; background: #fff; }
th, td { border: 1px solid var(--line); padding: .75rem; text-align: left; vertical-align: top; }
th { background: var(--accent-dark); color: #fff; font-weight: 800; }
.inline-cta { display: inline-flex; align-items: center; justify-content: center; min-height: 34px; padding: .35rem .65rem; border-radius: 6px; background: var(--accent-dark); color: #fff; text-decoration: none; font-weight: 700; }
.check-list, .source-list { margin: .75rem 0 0; padding-left: 1.2rem; color: var(--muted); }
.faq-list { display: grid; gap: .75rem; }
.faq-item { background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: .85rem 1rem; }
.faq-item summary { cursor: pointer; font-weight: 700; color: var(--ink); }
.page-hero { padding: 2.4rem 0 1.8rem; }
.site-footer { background: #171717; color: #ececec; padding: 2.4rem 0; }
.site-footer a { color: #f4d7df; }
.footer-grid { display: grid; gap: 1.5rem; }
@media (min-width: 860px) { .footer-grid { grid-template-columns: minmax(260px, .85fr) 1.35fr; } }
.footer-heading { color: #fff; font-weight: 800; margin: 0 0 .55rem; text-transform: uppercase; font-size: .82rem; }
.footer-brand { display: inline-flex; align-items: center; gap: .75rem; color: #fff; text-decoration: none; }
.footer-brand-logo { width: 48px; height: 48px; object-fit: contain; background: #fff; border-radius: 6px; padding: .25rem; flex: 0 0 auto; }
.footer-brand-text { display: inline-flex; flex-direction: column; line-height: 1.1; }
.footer-brand-title { color: #fff; font-weight: 900; font-size: 1.02rem; }
.footer-brand-subtitle { color: #d8d8d8; font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; }
.footer-links { display: flex; flex-wrap: wrap; gap: .55rem 1rem; }
.footer-disclaimer { grid-column: 1 / -1; border-top: 1px solid rgba(255,255,255,.16); padding-top: 1rem; color: #cfcfcf; font-size: .86rem; max-width: 95ch; margin: 0; }
@media (max-width: 768px) {
  .nav-toggle { display: inline-flex; }
  .nav-menu { display: none; width: 100%; flex-direction: column; align-items: flex-start; max-height: calc(100vh - 72px); overflow-y: auto; padding: .5rem 0; }
  .nav-menu.is-open { display: flex; }
  .brand-title { white-space: normal; }
}
