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