:root {
  --whr-ink: #111827;
  --whr-paper: #eef2ff;
  --whr-accent: #8b5cf6;
  --whr-second: #14b8a6;
  --whr-muted: color-mix(in srgb, #111827 68%, white);
  --whr-line: color-mix(in srgb, #111827 16%, transparent);
  --whr-glow: 0 24px 80px color-mix(in srgb, #8b5cf6 28%, transparent);
  --whr-radius: 20px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--whr-ink); background: radial-gradient(circle at top left, color-mix(in srgb, var(--whr-accent) 22%, transparent), transparent 34rem), var(--whr-paper); font-family: "Source Sans 3", system-ui, sans-serif; line-height: 1.65; }
a { color: inherit; }
.whr-topbar { position: sticky; top: 0; z-index: 20; display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 18px clamp(18px, 4vw, 56px); background: color-mix(in srgb, var(--whr-paper) 82%, transparent); backdrop-filter: blur(18px); border-bottom: 1px solid var(--whr-line); }
.whr-mark { font-family: "Cormorant Garamond", serif; font-size: clamp(20px, 2vw, 30px); font-weight: 700; text-decoration: none; }
.whr-navflow { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; font-size: 14px; }
.whr-navflow a { text-decoration: none; opacity: .78; }
.whr-navflow a:hover { opacity: 1; }
.whr-navpin { display: none; border: 1px solid var(--whr-line); background: white; border-radius: 999px; padding: 10px 16px; }
.whr-hero { min-height: 78vh; padding: clamp(56px, 8vw, 118px) clamp(18px, 5vw, 72px); display: grid; gap: 34px; align-items: center; }
.whr-hero-split { grid-template-columns: 1.08fr .92fr; }
.whr-hero-center { text-align: center; max-width: 1050px; margin: auto; }
.whr-hero-cards { grid-template-columns: 1fr 420px; }
.whr-hero-panel { grid-template-columns: 360px 1fr; }
.whr-eyebrow, .whr-sectionhead p, .whr-contactnote > p, .whr-articlelong > p:first-of-type, .whr-aboutpage > p, .whr-contactpage > p { color: var(--whr-second); text-transform: uppercase; letter-spacing: .16em; font-size: 12px; font-weight: 700; }
h1, h2, h3 { font-family: "Cormorant Garamond", serif; line-height: 1.08; margin: 0 0 16px; }
h1 { font-size: clamp(42px, 7vw, 84px); letter-spacing: -.04em; }
h2 { font-size: clamp(30px, 4vw, 52px); }
h3 { font-size: 22px; }
.whr-lead, .whr-lede { font-size: clamp(18px, 2vw, 23px); color: var(--whr-muted); max-width: 760px; }
.whr-disclaimer { margin: 22px 0; padding: 16px 18px; border: 1px solid color-mix(in srgb, var(--whr-accent) 38%, transparent); border-radius: var(--whr-radius); background: color-mix(in srgb, white 72%, var(--whr-accent)); box-shadow: var(--whr-glow); font-weight: 700; }
.whr-hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 24px; }
.whr-mainlink, .whr-ghostlink, .whr-plancard a, .whr-cta a, .whr-articlecard a, .whr-form button, .whr-cookie button { border-radius: 999px; padding: 13px 20px; text-decoration: none; font-weight: 800; display: inline-flex; align-items: center; justify-content: center; }
.whr-mainlink, .whr-plancard a, .whr-form button, .whr-cookie button { background: var(--whr-ink); color: var(--whr-paper); border: 0; }
.whr-ghostlink { border: 1px solid var(--whr-line); background: color-mix(in srgb, white 72%, transparent); }
.whr-visual, .whr-cardorbit, .whr-glassnote { min-height: 330px; border: 1px solid var(--whr-line); border-radius: calc(var(--whr-radius) * 1.2); background: linear-gradient(145deg, color-mix(in srgb, white 74%, var(--whr-accent)), color-mix(in srgb, var(--whr-paper) 70%, var(--whr-second))); box-shadow: var(--whr-glow); padding: 30px; }
.whr-visual { display: grid; place-items: center; grid-template-columns: repeat(2, 1fr); font-size: 52px; }
.whr-visual strong { grid-column: 1 / -1; font-size: 74px; font-family: "Cormorant Garamond", serif; }
.whr-cardorbit { display: grid; gap: 16px; }
.whr-cardorbit article { background: color-mix(in srgb, white 76%, transparent); border-radius: 22px; padding: 22px; font-family: "Cormorant Garamond", serif; font-size: 34px; }
.whr-cardorbit span { display: block; font-family: "Source Sans 3", sans-serif; font-size: 14px; }
.whr-glassnote { display: flex; flex-direction: column; justify-content: end; }
.whr-halo { margin: auto; width: 170px; height: 170px; display: grid; place-items: center; border-radius: 50%; background: var(--whr-ink); color: var(--whr-paper); font-family: "Cormorant Garamond", serif; font-size: 44px; box-shadow: var(--whr-glow); }
.whr-signal-row { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; }
.whr-signal-row span { border: 1px solid var(--whr-line); border-radius: 999px; padding: 8px 14px; background: color-mix(in srgb, white 68%, transparent); }
.whr-slice { padding: clamp(54px, 8vw, 104px) clamp(18px, 5vw, 72px); }
.whr-sectionhead { max-width: 780px; margin-bottom: 30px; }
.whr-featuregrid, .whr-plangrid, .whr-reviewgrid, .whr-articlegrid, .whr-contactcards { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.whr-featuretile, .whr-plancard, .whr-review, .whr-articlecard, .whr-contactcards article, .whr-legalcard, .whr-aboutpage, .whr-contactpage, .whr-articlelong { border: 1px solid var(--whr-line); border-radius: var(--whr-radius); background: color-mix(in srgb, white 78%, transparent); padding: clamp(22px, 3vw, 34px); box-shadow: 0 16px 50px color-mix(in srgb, var(--whr-ink) 9%, transparent); }
.whr-featuretile span, .whr-plancard span { color: var(--whr-second); font-weight: 900; }
.whr-plancard { display: flex; flex-direction: column; justify-content: space-between; gap: 18px; }
.whr-recommended { outline: 2px solid var(--whr-accent); transform: translateY(-8px); }
.whr-plancard ul { padding-left: 20px; }
.whr-review { margin: 0; }
.whr-review blockquote { margin: 0 0 20px; font-size: 18px; }
.whr-review figcaption { display: flex; justify-content: space-between; gap: 12px; color: var(--whr-muted); }
.whr-contactblock { display: grid; grid-template-columns: .9fr 1.1fr; gap: 22px; align-items: start; }
.whr-contactnote, .whr-form { border-radius: var(--whr-radius); padding: clamp(24px, 4vw, 42px); background: var(--whr-ink); color: var(--whr-paper); }
.whr-contactnote strong { display: block; margin: 18px 0; }
.whr-form { background: color-mix(in srgb, white 86%, var(--whr-accent)); color: var(--whr-ink); border: 1px solid var(--whr-line); display: grid; gap: 14px; }
.whr-form label { display: grid; gap: 8px; font-weight: 800; }
.whr-form input, .whr-form textarea { width: 100%; border: 1px solid var(--whr-line); border-radius: 16px; padding: 13px 14px; font: inherit; background: white; }
.whr-success { font-weight: 800; color: var(--whr-second); }
.whr-faqlist { display: grid; gap: 12px; max-width: 920px; }
.whr-qa { border: 1px solid var(--whr-line); border-radius: 18px; overflow: hidden; background: color-mix(in srgb, white 80%, transparent); }
.whr-qa button { width: 100%; padding: 18px 20px; text-align: left; background: transparent; border: 0; font: inherit; font-weight: 900; color: var(--whr-ink); }
.whr-qa div { display: none; padding: 0 20px 18px; }
.whr-qa.whr-open div { display: block; }
.whr-cta { margin: clamp(34px, 6vw, 80px); padding: clamp(28px, 5vw, 56px); border-radius: calc(var(--whr-radius) * 1.3); background: linear-gradient(135deg, var(--whr-ink), color-mix(in srgb, var(--whr-ink) 72%, var(--whr-second))); color: var(--whr-paper); display: flex; justify-content: space-between; gap: 24px; align-items: center; }
.whr-cta a { background: var(--whr-paper); color: var(--whr-ink); }
.whr-footer { padding: 44px clamp(18px, 5vw, 72px); background: color-mix(in srgb, var(--whr-ink) 94%, black); color: var(--whr-paper); }
.whr-footgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin: 28px 0; }
.whr-footgrid a { display: block; color: inherit; opacity: .78; text-decoration: none; margin: 8px 0; }
.whr-footnote { opacity: .72; border-top: 1px solid color-mix(in srgb, white 18%, transparent); padding-top: 18px; }
.whr-cookie { position: fixed; left: 18px; right: 18px; bottom: 18px; z-index: 30; display: none; align-items: center; justify-content: space-between; gap: 18px; max-width: 860px; margin: auto; border: 1px solid var(--whr-line); border-radius: 22px; padding: 16px; background: white; box-shadow: 0 20px 70px rgba(0,0,0,.18); }
.whr-cookie.whr-show { display: flex; }
.whr-subpage { padding: clamp(48px, 8vw, 100px) clamp(18px, 5vw, 72px); }
.whr-legalcard, .whr-aboutpage, .whr-contactpage, .whr-articlelong { max-width: 980px; margin: auto; }
.whr-articlelong p, .whr-legalcard p, .whr-aboutpage p { font-size: 18px; }
.whr-crumbs, .whr-readmore { display: flex; flex-wrap: wrap; gap: 12px; margin: 24px 0; }
.whr-crumbs a, .whr-readmore a { border: 1px solid var(--whr-line); border-radius: 999px; padding: 9px 13px; text-decoration: none; background: color-mix(in srgb, white 72%, transparent); }
.whr-article-note { border-left: 5px solid var(--whr-accent); padding: 18px 22px; background: color-mix(in srgb, white 60%, var(--whr-accent)); border-radius: 18px; margin: 24px 0; }
@media (max-width: 900px) {
  .whr-navpin { display: inline-flex; }
  .whr-navflow { position: absolute; top: 100%; left: 16px; right: 16px; display: none; padding: 18px; border-radius: 20px; background: white; box-shadow: 0 22px 70px rgba(0,0,0,.14); }
  .whr-navflow.whr-visible { display: grid; }
  .whr-hero, .whr-hero-split, .whr-hero-cards, .whr-hero-panel, .whr-contactblock { grid-template-columns: 1fr; }
  .whr-featuregrid, .whr-plangrid, .whr-reviewgrid, .whr-articlegrid, .whr-contactcards, .whr-footgrid { grid-template-columns: 1fr; }
  .whr-cta, .whr-cookie { align-items: flex-start; flex-direction: column; }
}
