/* =========================================================
   Gladys — design system
   Custom CSS, no framework. Mobile-first.
   ========================================================= */

/* -------- 1. Tokens -------- */
:root {
  /* Brand */
  --ink-900: #0b1623;
  --ink-800: #122033;
  --ink-700: #1b2c45;
  --ink-500: #43536b;
  --ink-400: #6b7a93;
  --ink-300: #9aa6bb;
  --ink-200: #c8cfdb;
  --ink-100: #e3e7ee;
  --ink-50:  #f3f5f9;

  --ivory:   #f7f3ec;
  --ivory-2: #efe9dc;

  --teal-700: #0f7a6b;
  --teal-600: #138b7a;
  --teal-500: #1aa48f;
  --teal-300: #74d4c1;
  --teal-100: #d6f1ea;

  --gold-700: #8a6a26;
  --gold-600: #a98238;
  --gold-500: #c9a961;     /* refined champagne */
  --gold-400: #d8bd84;
  --gold-300: #e6d2a8;
  --gold-200: #efe0c1;
  --gold-100: #f5ead0;

  --risk-700: #9a2c2c;
  --risk-500: #c83a3a;
  --risk-300: #f1b1b1;
  --risk-100: #fdecec;

  --warn-600: #b06a14;
  --warn-500: #d8841d;
  --warn-300: #f0c98f;
  --warn-100: #fcecd6;

  --good-600: #1f7a55;
  --good-500: #25976a;
  --good-300: #8fd6b8;
  --good-100: #d6f1e3;

  /* Surface */
  --bg:        var(--ivory);
  --bg-alt:    #fffaf2;
  --surface:   #ffffff;
  --on-bg:     var(--ink-900);
  --on-bg-mut: var(--ink-500);

  /* Type */
  --font-sans: "Inter", "Segoe UI", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;
  --font-display: "Fraunces", "Source Serif 4", Georgia, "Times New Roman", serif;
  --font-mono: ui-monospace, "SFMono-Regular", "JetBrains Mono", Menlo, Consolas, monospace;

  --fs-12: 0.75rem;
  --fs-14: 0.875rem;
  --fs-16: 1rem;
  --fs-18: 1.125rem;
  --fs-20: 1.25rem;
  --fs-24: 1.5rem;
  --fs-30: 1.875rem;
  --fs-36: 2.25rem;
  --fs-44: 2.75rem;
  --fs-56: 3.5rem;
  --fs-72: 4.5rem;

  /* Spacing — based on 4px */
  --s-1: 0.25rem;
  --s-2: 0.5rem;
  --s-3: 0.75rem;
  --s-4: 1rem;
  --s-5: 1.25rem;
  --s-6: 1.5rem;
  --s-8: 2rem;
  --s-10: 2.5rem;
  --s-12: 3rem;
  --s-16: 4rem;
  --s-20: 5rem;
  --s-24: 6rem;

  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 22px;
  --radius-xl: 32px;
  --radius-pill: 999px;

  --shadow-sm: 0 1px 2px rgba(11, 22, 35, 0.06), 0 1px 3px rgba(11, 22, 35, 0.04);
  --shadow-md: 0 8px 24px -8px rgba(11, 22, 35, 0.18), 0 2px 6px rgba(11, 22, 35, 0.06);
  --shadow-lg: 0 24px 60px -20px rgba(11, 22, 35, 0.25), 0 8px 18px -8px rgba(11, 22, 35, 0.12);
  --shadow-glow: 0 0 0 6px rgba(26, 164, 143, 0.12);

  --container: 1180px;
  --container-narrow: 880px;
  --container-tight: 640px;

  --ease-out:  cubic-bezier(0.22, 1, 0.36, 1);
  --ease-soft: cubic-bezier(0.4, 0, 0.2, 1);
}

/* -------- 2. Reset & base -------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-16);
  line-height: 1.55;
  color: var(--on-bg);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden; /* prevent rare horizontal scroll from decorative absolute elements */
}
img, svg, video { display: block; max-width: 100%; }
a { color: var(--ink-900); text-decoration: none; }
a:hover { color: var(--teal-600); }

button { font-family: inherit; font-size: inherit; }
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 500; letter-spacing: -0.02em; line-height: 1.08; margin: 0 0 var(--s-4); color: var(--ink-900); text-wrap: balance; }
h1 { font-size: clamp(1.875rem, 4.4vw + 0.85rem, 4.5rem); letter-spacing: -0.03em; }
h2 { font-size: clamp(1.625rem, 2.6vw + 0.6rem, 3rem); }
h3 { font-size: clamp(1.1875rem, 1.4vw + 0.6rem, 1.875rem); }
h4 { font-size: var(--fs-20); font-family: var(--font-sans); font-weight: 600; letter-spacing: -0.005em; }
p { margin: 0 0 var(--s-4); }

::selection { background: var(--teal-300); color: var(--ink-900); }

/* -------- 3. Layout primitives -------- */
.container        { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 var(--s-4); }
@media (min-width: 720px) { .container { padding: 0 var(--s-6); } }
.container--narrow{ max-width: var(--container-narrow); }
.container--tight { max-width: var(--container-tight); }

.section { padding: clamp(2.75rem, 7vw, 6.5rem) 0; }
.section--alt   { background: var(--bg-alt); }
.section--ink   { background: var(--ink-900); color: var(--ink-50); }
.section--ink h1, .section--ink h2, .section--ink h3 { color: #fff; }
.section--ivory { background: var(--ivory-2); }

.eyebrow {
  display: inline-flex; align-items: center; gap: var(--s-3);
  font-size: 0.6875rem; font-weight: 600; letter-spacing: 0.24em;
  text-transform: uppercase; color: var(--gold-700);
}
.eyebrow::before {
  content: ""; width: 32px; height: 1px; background: currentColor; opacity: 0.55;
}
.eyebrow--teal { color: var(--teal-700); }
.eyebrow--ivory { color: var(--gold-300); }
.eyebrow--center::before, .eyebrow--center::after {
  content: ""; width: 32px; height: 1px; background: currentColor; opacity: 0.55;
}

/* Editorial section number — large display digit used as section ornament */
.section-num {
  display: inline-block;
  font-family: var(--font-display); font-style: italic; font-weight: 400;
  color: var(--gold-500);
  font-size: clamp(2.5rem, 4vw, 3.75rem);
  line-height: 1; letter-spacing: -0.02em;
  margin-bottom: var(--s-4);
  opacity: 0.92;
}

/* Hairline gold divider */
.rule-gold {
  display: block; width: 56px; height: 1px;
  background: linear-gradient(90deg, var(--gold-500), var(--gold-300) 60%, transparent);
  margin: var(--s-4) 0;
}
.rule-gold--center { margin-left: auto; margin-right: auto; }

/* Italic Fraunces for soft editorial emphasis */
.italic-serif {
  font-family: var(--font-display); font-style: italic; font-weight: 400;
  letter-spacing: -0.01em;
}

.lede {
  font-size: clamp(1.0625rem, 0.4vw + 1rem, 1.3125rem);
  color: var(--ink-500);
  max-width: 60ch;
  line-height: 1.55;
}
.lede--lift::first-letter {
  font-family: var(--font-display); font-weight: 500;
  font-size: 3.4em; line-height: 0.85;
  float: left; padding: 0.05em 0.18em 0 0;
  color: var(--gold-600);
}

/* -------- 4. Buttons -------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--s-2);
  padding: 0.95rem 1.6rem;
  font-weight: 600; font-size: var(--fs-16); line-height: 1;
  border: 1px solid transparent;
  border-radius: var(--radius-pill);
  cursor: pointer; transition: transform 0.18s var(--ease-out), background 0.18s var(--ease-out), color 0.18s var(--ease-out), box-shadow 0.18s var(--ease-out), border-color 0.18s var(--ease-out);
  text-align: center; white-space: nowrap;
}
.btn:focus-visible { outline: 2px solid var(--teal-500); outline-offset: 3px; }

.btn-primary {
  background: var(--ink-900); color: #fff;
  border-color: var(--ink-900);
  box-shadow: 0 14px 28px -14px rgba(11, 22, 35, 0.55), inset 0 0 0 1px rgba(201, 169, 97, 0.08);
}
.btn-primary:hover { background: var(--ink-700); color: #fff; transform: translateY(-1px); box-shadow: 0 18px 36px -16px rgba(11, 22, 35, 0.65), inset 0 0 0 1px rgba(201, 169, 97, 0.18); }

.btn-accent {
  background: var(--teal-600); color: #fff;
  box-shadow: 0 14px 28px -14px rgba(15, 122, 107, 0.55);
}
.btn-accent:hover { background: var(--teal-700); transform: translateY(-1px); }

.btn-gold {
  background: var(--gold-500); color: var(--ink-900);
  border-color: var(--gold-500);
  box-shadow: 0 14px 28px -14px rgba(138, 106, 38, 0.45);
}
.btn-gold:hover { background: var(--gold-600); border-color: var(--gold-600); color: #fff; transform: translateY(-1px); }

.btn-ghost {
  background: transparent; color: var(--ink-900);
  border-color: rgba(11, 22, 35, 0.16);
}
.btn-ghost:hover { border-color: var(--ink-900); background: rgba(11, 22, 35, 0.04); }

.btn-outline-gold {
  background: transparent; color: var(--gold-700);
  border-color: var(--gold-500);
}
.btn-outline-gold:hover { background: var(--gold-100); color: var(--gold-700); }

.btn-light {
  background: rgba(255, 255, 255, 0.08); color: #fff;
  border-color: rgba(255, 255, 255, 0.22);
}
.btn-light:hover { background: rgba(255, 255, 255, 0.14); }

.btn-lg { padding: 1.05rem 1.9rem; font-size: var(--fs-18); }
.btn-sm { padding: 0.6rem 1.05rem; font-size: var(--fs-14); }
.btn-block { width: 100%; }

.btn .arrow {
  display: inline-block; transition: transform 0.25s var(--ease-out);
}
.btn:hover .arrow { transform: translateX(4px); }

/* -------- 5. Forms -------- */
.field { display: block; margin-bottom: var(--s-4); }
.field label, .label {
  display: block; font-size: var(--fs-14); font-weight: 600; color: var(--ink-700); margin-bottom: var(--s-2);
}
.input, .textarea, .select {
  width: 100%; padding: 0.85rem 1rem;
  font: inherit; color: var(--ink-900);
  background: #fff;
  border: 1.5px solid var(--ink-100);
  border-radius: var(--radius-md);
  transition: border-color 0.15s, box-shadow 0.15s;
}
.textarea { min-height: 110px; resize: vertical; }
.input:focus, .textarea:focus, .select:focus {
  outline: none; border-color: var(--teal-500);
  box-shadow: var(--shadow-glow);
}
.input::placeholder, .textarea::placeholder { color: var(--ink-300); }

.help { display: block; font-size: var(--fs-12); color: var(--ink-400); margin-top: var(--s-2); }
.error-msg { display: block; font-size: var(--fs-12); color: var(--risk-700); margin-top: var(--s-2); min-height: 1em; }

/* -------- 6. Header -------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: saturate(160%) blur(14px);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
  background: rgba(247, 243, 236, 0.78);
  border-bottom: 1px solid rgba(11, 22, 35, 0.06);
}
.site-header.is-ink {
  background: rgba(11, 22, 35, 0.65);
  border-bottom-color: rgba(255, 255, 255, 0.06);
  color: #fff;
}
.site-header.is-ink .nav a:not(.btn) { color: var(--ink-100); }
.site-header.is-ink .brand-mark { color: #fff; }

.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 64px;
}
@media (min-width: 720px) { .header-inner { height: 76px; } }
.brand {
  display: flex; align-items: center; gap: 0.7rem;
  font-family: var(--font-display);
  font-size: 1.375rem; font-weight: 500; letter-spacing: -0.015em;
  color: var(--ink-900);
}
.brand sup {
  font-family: var(--font-sans); font-size: 0.55em; font-weight: 600;
  letter-spacing: 0.18em; color: var(--gold-700);
  margin-left: 0.4em; text-transform: uppercase;
  position: relative; top: -0.4em;
}
.brand-mark {
  width: 38px; height: 38px;
  display: grid; place-items: center;
  border-radius: 12px;
  background: linear-gradient(160deg, var(--ink-700), var(--ink-900));
  color: var(--gold-300);
  border: 1px solid rgba(201, 169, 97, 0.25);
  box-shadow: 0 6px 14px -8px rgba(11, 22, 35, 0.35);
  font-family: var(--font-display); font-weight: 600;
  letter-spacing: -0.04em;
}
.brand-mark svg { width: 20px; height: 20px; }

.nav { display: none; gap: var(--s-8); align-items: center; }
.nav a:not(.btn) { font-size: var(--fs-14); font-weight: 500; color: var(--ink-700); }
.nav a:not(.btn):hover { color: var(--teal-700); }
.nav .btn { padding: 0.65rem 1.1rem; font-size: var(--fs-14); }
/* Ensure button text colors always win against any ancestor link styles */
.nav a.btn-primary, .nav a.btn-primary:hover { color: #fff; }
.nav a.btn-accent,  .nav a.btn-accent:hover  { color: #fff; }
.nav a.btn-ghost { color: var(--ink-900); }

.hamburger {
  display: inline-grid; place-items: center;
  width: 44px; height: 44px;
  background: transparent; border: 1px solid rgba(11, 22, 35, 0.14);
  border-radius: 12px; cursor: pointer;
}
.hamburger span { display: block; width: 18px; height: 2px; background: currentColor; position: relative; }
.hamburger span::before, .hamburger span::after {
  content: ""; position: absolute; left: 0; width: 18px; height: 2px; background: currentColor; transition: transform 0.2s;
}
.hamburger span::before { top: -6px; }
.hamburger span::after  { top: 6px; }

@media (min-width: 880px) {
  .nav { display: flex; }
  .hamburger { display: none; }
}

.mobile-menu {
  display: none;
  border-top: 1px solid rgba(11, 22, 35, 0.06);
  padding: var(--s-4) var(--s-4) var(--s-5);
  background: var(--bg);
}
.mobile-menu.open { display: block; }
.mobile-menu a { display: block; padding: var(--s-3) 0; font-weight: 500; color: var(--ink-900); }
.mobile-menu a.btn { padding: 0.95rem 1.6rem; }
.mobile-menu a.btn-primary { color: #fff; }

/* -------- 7. Hero -------- */
.hero {
  position: relative;
  padding: clamp(2rem, 6vw, 7rem) 0 clamp(2.5rem, 7vw, 6rem);
  overflow: hidden;
}
.hero::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(1100px 600px at 85% 0%, rgba(26, 164, 143, 0.10), transparent 60%),
    radial-gradient(800px 500px at 0% 100%, rgba(211, 162, 83, 0.08), transparent 60%);
}
.hero-grid {
  position: relative; z-index: 1;
  display: grid; gap: clamp(2rem, 4vw, 3.5rem);
  align-items: center;
}
@media (min-width: 920px) {
  .hero-grid { grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr); gap: clamp(2.5rem, 4vw, 4rem); }
}
.hero h1 .underline {
  position: relative;
  background: linear-gradient(180deg, transparent 70%, var(--gold-300) 70%);
  padding: 0 0.05em;
  /* break-inside: avoid prevents the highlight cutting awkwardly mid-word */
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}
.hero .lede { margin-top: var(--s-5); }
.hero-cta { display: flex; flex-wrap: wrap; gap: var(--s-3); margin-top: var(--s-6); }
@media (max-width: 479px) {
  .hero-cta .btn { flex: 1 1 100%; }
}
.hero-meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--s-2) var(--s-4);
  margin-top: var(--s-5); font-size: var(--fs-14); color: var(--ink-500);
}
.hero-meta strong { color: var(--ink-900); font-weight: 600; }
@media (max-width: 479px) {
  .hero-meta [aria-hidden="true"] { display: none; }
}

.hero-card {
  position: relative;
  border-radius: var(--radius-xl);
  background: linear-gradient(160deg, var(--ink-800), var(--ink-900));
  color: #fff;
  padding: clamp(1.5rem, 3.5vw, 2.5rem);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  /* Center on mobile, full-width on desktop column */
  max-width: 460px; margin: 0 auto; width: 100%;
}
@media (min-width: 920px) { .hero-card { max-width: none; margin: 0; } }

.hero-card::after {
  content: ""; position: absolute; inset: 0; background:
    radial-gradient(420px 240px at 110% -10%, rgba(26, 164, 143, 0.45), transparent 60%),
    radial-gradient(420px 320px at -10% 110%, rgba(211, 162, 83, 0.18), transparent 60%);
  pointer-events: none;
}

/* Subtle floating "background" card behind the main one — desktop only, decorative */
.hero-card-deco {
  display: none;
}
@media (min-width: 920px) {
  .hero-card-deco {
    display: block;
    position: absolute; inset: -16px -16px auto auto;
    width: 86%; height: 70%;
    background: linear-gradient(160deg, rgba(116, 212, 193, 0.12), rgba(116, 212, 193, 0));
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-xl);
    transform: rotate(2.5deg);
    z-index: 0;
  }
}

/* Editorial family portrait pinned beside the live-preview card (desktop only) */
.hero-portrait {
  display: none;
}
@media (min-width: 1100px) {
  .hero-portrait {
    display: block;
    position: absolute; left: -54px; bottom: -36px;
    width: 168px; height: 220px;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: 0 24px 48px -16px rgba(11, 22, 35, 0.45);
    border: 4px solid #fff;
    transform: rotate(-5deg);
    z-index: 2;
    transition: transform 0.4s var(--ease-out);
  }
  .hero-portrait:hover { transform: rotate(-3deg) translateY(-4px); }
  .hero-portrait img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .hero-portrait::after {
    content: "Real families. Real plans.";
    position: absolute; bottom: -14px; left: 50%; transform: translateX(-50%) rotate(5deg);
    background: var(--gold-500); color: var(--ink-900);
    padding: 0.35rem 0.7rem; border-radius: var(--radius-pill);
    font-size: 0.625rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase;
    white-space: nowrap;
    box-shadow: 0 6px 14px -6px rgba(138, 106, 38, 0.5);
  }
}

.hero-card > *:not(.hero-card-deco) { position: relative; z-index: 1; }

.hero-card-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-3);
  margin-bottom: clamp(1.25rem, 2.5vw, 1.75rem);
}
.hero-card .pscore-tag {
  display: inline-flex; gap: var(--s-2); align-items: center;
  font-size: var(--fs-12); font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase;
  padding: 0.4rem 0.8rem; border-radius: var(--radius-pill);
  background: rgba(116, 212, 193, 0.16); color: var(--teal-300);
  margin: 0;
}
.live-dot {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.6875rem; font-weight: 700; letter-spacing: 0.2em; color: rgba(255, 255, 255, 0.65);
}
.live-dot i {
  width: 7px; height: 7px; border-radius: 50%;
  background: #ff6b6b;
  box-shadow: 0 0 0 0 rgba(255, 107, 107, 0.7);
  animation: pulse 1.6s var(--ease-out) infinite;
}
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 rgba(255, 107, 107, 0.55); }
  70%  { box-shadow: 0 0 0 10px rgba(255, 107, 107, 0); }
  100% { box-shadow: 0 0 0 0 rgba(255, 107, 107, 0); }
}

.hero-card .pscore-ring {
  --size: clamp(180px, 36vw, 240px);
  margin: 0 auto var(--s-6);
}
@media (min-width: 920px) {
  .hero-card .pscore-ring { --size: clamp(200px, 18vw, 240px); }
}

.hero-card .pscore-caption {
  text-align: center;
  color: rgba(255, 255, 255, 0.7);
  font-size: var(--fs-14);
  margin: var(--s-5) 0 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding-top: var(--s-5);
}

/* Mini-gap rows — make the card feel like the real result UI */
.mini-gaps {
  display: grid; gap: var(--s-3);
  margin-top: var(--s-4);
}
.mini-gap {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: var(--radius-md);
  padding: 0.75rem 0.95rem;
}
.mini-gap-row {
  display: flex; justify-content: space-between; align-items: baseline; gap: var(--s-3);
  margin-bottom: 0.5rem;
}
.mini-gap-label {
  font-size: var(--fs-14); color: rgba(255, 255, 255, 0.85); font-weight: 500;
}
.mini-gap-val {
  font-size: var(--fs-12); color: rgba(255, 255, 255, 0.55); font-variant-numeric: tabular-nums;
}
.mini-gap-val b { color: #fff; font-weight: 600; font-size: var(--fs-14); }
.mini-gap-bar {
  height: 4px; border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.08); overflow: hidden;
}
.mini-gap-bar > span {
  display: block; height: 100%; border-radius: inherit;
  background: linear-gradient(90deg, var(--teal-300), var(--teal-500));
  width: 0%;
  transition: width 1s var(--ease-out);
}

/* -------- 8. Logo / trust strip -------- */
.trust-strip {
  display: grid; grid-template-columns: 1fr; gap: var(--s-3); align-items: center;
  padding: var(--s-5) 0;
  border-top: 1px solid rgba(11, 22, 35, 0.06);
  border-bottom: 1px solid rgba(11, 22, 35, 0.06);
}
.hero-trust { margin-top: clamp(2.5rem, 5vw, 4rem); }
@media (min-width: 720px) {
  .trust-strip { grid-template-columns: auto 1fr; gap: var(--s-8); }
}
.trust-strip .label { font-size: var(--fs-12); letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-400); margin: 0; }
.trust-logos { display: flex; flex-wrap: wrap; gap: var(--s-4) var(--s-6); align-items: center; opacity: 0.78; }
@media (min-width: 720px) { .trust-logos { gap: var(--s-6) var(--s-10); } }
.trust-logos span {
  font-family: var(--font-display); font-size: var(--fs-18); color: var(--ink-700); letter-spacing: -0.01em;
}

/* -------- 9. Stat row -------- */
.stat-row {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-5) var(--s-4);
  margin-top: clamp(2rem, 5vw, 3rem);
}
@media (min-width: 720px) { .stat-row { grid-template-columns: repeat(4, 1fr); gap: var(--s-6); } }
.stat .num { font-family: var(--font-display); font-size: clamp(1.5rem, 2.4vw + 0.4rem, 2.75rem); color: var(--ink-900); letter-spacing: -0.02em; }
.stat .lbl { display: block; color: var(--ink-500); font-size: var(--fs-14); margin-top: var(--s-1); line-height: 1.4; }

/* -------- 10. How it works -------- */
.steps {
  display: grid; gap: var(--s-6);
  margin-top: var(--s-10);
}
@media (min-width: 880px) { .steps { grid-template-columns: repeat(3, 1fr); gap: var(--s-8); } }
.step {
  position: relative;
  background: var(--surface);
  border: 1px solid rgba(11, 22, 35, 0.06);
  border-radius: var(--radius-lg);
  padding: var(--s-8);
  box-shadow: var(--shadow-sm);
  transition: transform 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out), border-color 0.25s var(--ease-out);
}
.step::before {
  content: ""; position: absolute; top: 0; left: var(--s-8); right: var(--s-8);
  height: 1px; background: linear-gradient(90deg, var(--gold-500), transparent);
  opacity: 0; transition: opacity 0.3s var(--ease-out);
}
.step:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: rgba(201, 169, 97, 0.25); }
.step:hover::before { opacity: 0.7; }
.step .num {
  display: inline-flex; align-items: baseline; gap: 6px;
  font-family: var(--font-display); font-style: italic; font-weight: 400;
  color: var(--gold-600);
  font-size: var(--fs-44);
  line-height: 0.9;
  margin-bottom: var(--s-5);
  letter-spacing: -0.02em;
  background: none; width: auto; height: auto; border-radius: 0;
}
.step .num::before {
  content: "№";
  font-family: var(--font-sans); font-style: normal;
  font-size: var(--fs-12); font-weight: 600; letter-spacing: 0.18em;
  color: var(--gold-700); text-transform: uppercase;
  margin-right: 4px; align-self: flex-start; padding-top: 0.3em;
}
.step h3 { margin-bottom: var(--s-3); }
.step p { color: var(--ink-500); margin: 0; }

/* -------- 10b. Themed visual grid (family / work / health / wealth) -------- */
.theme-grid {
  display: grid; gap: var(--s-4);
  margin-top: clamp(2rem, 5vw, 3rem);
  grid-template-columns: 1fr 1fr;
}
@media (min-width: 880px) { .theme-grid { grid-template-columns: repeat(4, 1fr); } }

.theme-card {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 3 / 4;
  isolation: isolate;
  box-shadow: var(--shadow-sm);
  transition: transform 0.4s var(--ease-out), box-shadow 0.4s var(--ease-out);
}
.theme-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.theme-card img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.7s var(--ease-out);
}
.theme-card:hover img { transform: scale(1.05); }
.theme-card::after {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(11, 22, 35, 0) 35%, rgba(11, 22, 35, 0.85) 100%);
  pointer-events: none;
}
.theme-card .label {
  position: absolute; left: var(--s-5); right: var(--s-5); bottom: var(--s-5);
  z-index: 2; color: #fff;
}
.theme-card .eyebrow {
  color: var(--gold-300);
  font-size: 0.625rem; letter-spacing: 0.24em; margin-bottom: 0.4rem;
}
.theme-card .eyebrow::before { background: var(--gold-300); width: 22px; }
.theme-card h3 {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(1.1875rem, 1.4vw + 0.6rem, 1.5rem);
  color: #fff; margin: 0 0 0.3em;
  letter-spacing: -0.01em;
}
.theme-card p {
  font-size: var(--fs-14); color: rgba(255, 255, 255, 0.78); margin: 0;
  line-height: 1.45;
}

/* -------- 11. Value prop / problem -------- */
.split {
  display: grid; gap: clamp(2rem, 4vw, 3rem);
}
@media (min-width: 880px) { .split { grid-template-columns: 1fr 1fr; align-items: center; } }
.split-art {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  min-height: 420px;
  isolation: isolate;
  box-shadow: var(--shadow-lg);
}
.split-art img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  z-index: 0;
}
.split-art::after {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(160deg, rgba(11, 22, 35, 0.15) 20%, rgba(11, 22, 35, 0.78) 100%),
    radial-gradient(420px 320px at 30% 30%, rgba(26, 164, 143, 0.18), transparent 60%);
}
.split-art .ribbon {
  position: absolute; top: 24px; left: -40px; transform: rotate(-8deg);
  background: var(--gold-500); color: var(--ink-900);
  padding: 0.4rem 3rem; font-weight: 600;
  font-size: 0.6875rem; letter-spacing: 0.2em; text-transform: uppercase;
  z-index: 3; box-shadow: 0 8px 18px -8px rgba(11, 22, 35, 0.4);
}
.split-art .callout {
  position: absolute; left: 0; right: 0; bottom: 0; padding: var(--s-8);
  z-index: 2; color: #fff;
}
.split-art .callout-num {
  font-family: var(--font-display); font-style: italic; font-weight: 500;
  font-size: clamp(2.5rem, 4.5vw, 3.75rem);
  letter-spacing: -0.02em; line-height: 1; color: #fff;
  display: block; margin-bottom: var(--s-3);
}
.split-art .callout-num small { font-style: normal; font-size: 0.55em; color: var(--gold-300); margin-right: 6px; }
.split-art .callout p { color: rgba(255, 255, 255, 0.85); margin: 0; max-width: 36ch; }

.checklist { list-style: none; padding: 0; margin: var(--s-6) 0 0; display: grid; gap: var(--s-3); }
.checklist li { display: flex; gap: var(--s-3); align-items: flex-start; color: var(--ink-700); }
.checklist .tick {
  flex: 0 0 22px; width: 22px; height: 22px; border-radius: 50%;
  background: var(--teal-100); color: var(--teal-700);
  display: grid; place-items: center; font-weight: 700; font-size: var(--fs-12); margin-top: 0.15rem;
}

/* -------- 12. Testimonials -------- */
.testimonial-grid {
  display: grid; gap: var(--s-6); margin-top: var(--s-10);
}
@media (min-width: 880px) { .testimonial-grid { grid-template-columns: repeat(3, 1fr); } }
.tcard {
  position: relative;
  background: var(--surface);
  border-radius: var(--radius-lg);
  padding: var(--s-8);
  border: 1px solid rgba(11, 22, 35, 0.06);
  box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column;
  transition: transform 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out), border-color 0.25s var(--ease-out);
}
.tcard::before {
  content: "\201C"; /* left double quote */
  position: absolute; top: -0.15em; left: 0.35em;
  font-family: var(--font-display); font-style: italic; font-weight: 500;
  font-size: 5.5rem; line-height: 1;
  color: var(--gold-300); opacity: 0.85;
  pointer-events: none;
}
.tcard:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: rgba(201, 169, 97, 0.25); }
.tcard .quote {
  position: relative; z-index: 1;
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(1.1875rem, 1.4vw + 0.7rem, 1.4375rem);
  line-height: 1.4;
  color: var(--ink-900); margin: var(--s-3) 0 var(--s-6);
  letter-spacing: -0.005em;
}
.tcard .who { display: flex; align-items: center; gap: var(--s-3); margin-top: auto; padding-top: var(--s-5); border-top: 1px solid rgba(11, 22, 35, 0.06); }
.tcard .avatar {
  width: 48px; height: 48px; border-radius: 50%;
  display: grid; place-items: center;
  overflow: hidden; flex-shrink: 0;
  background: linear-gradient(140deg, var(--ink-700), var(--ink-900));
  color: var(--gold-300); font-family: var(--font-display); font-weight: 500;
  border: 1px solid rgba(201, 169, 97, 0.25);
  font-size: var(--fs-14); position: relative;
}
.tcard .avatar img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.tcard .meta { font-size: var(--fs-14); color: var(--ink-500); line-height: 1.4; }
.tcard .meta strong { display: block; color: var(--ink-900); font-weight: 600; font-family: var(--font-sans); }

/* -------- 12b. Planners (single-strategist feature card) -------- */
.planner-feature {
  display: grid; gap: clamp(2rem, 4vw, 3rem);
  margin-top: clamp(2rem, 5vw, 3rem);
  align-items: start;
  background: var(--surface);
  border: 1px solid rgba(11, 22, 35, 0.06);
  border-radius: var(--radius-xl);
  padding: clamp(2rem, 4vw, 3rem);
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
}
.planner-feature::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--gold-500), var(--gold-300) 50%, var(--teal-500));
}
@media (min-width: 880px) {
  .planner-feature { grid-template-columns: minmax(0, 280px) minmax(0, 1fr); gap: clamp(2.5rem, 5vw, 4rem); align-items: center; }
}

.planner-feature-portrait {
  width: clamp(180px, 28vw, 260px); height: clamp(180px, 28vw, 260px);
  border-radius: 50%;
  margin: 0 auto;
  display: grid; place-items: center;
  background: linear-gradient(140deg, var(--ink-700), var(--ink-900));
  color: var(--gold-300);
  border: 1px solid rgba(201, 169, 97, 0.35);
  box-shadow: 0 24px 48px -16px rgba(11, 22, 35, 0.4), inset 0 0 0 6px rgba(255, 255, 255, 0.06);
  position: relative;
  overflow: hidden;
}
.planner-feature-portrait .initials {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(3.25rem, 7vw, 4.5rem); letter-spacing: -0.04em;
  color: var(--gold-300);
}
.planner-feature-portrait img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block;
}

.planner-feature-body { min-width: 0; }
.planner-feature-body .eyebrow { color: var(--teal-700); }
.planner-feature-body h3 {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(1.75rem, 2.4vw + 0.6rem, 2.5rem);
  margin: var(--s-3) 0 var(--s-2);
  letter-spacing: -0.02em;
  color: var(--ink-900);
}
.planner-feature-affiliation {
  font-size: var(--fs-14); color: var(--ink-500);
  margin: 0; font-style: italic;
}
.planner-feature-bio {
  margin: var(--s-5) 0 0;
  color: var(--ink-700);
  font-size: clamp(0.9375rem, 0.3vw + 0.85rem, 1.0625rem);
  line-height: 1.65;
  max-width: 56ch;
}

.planner-credentials {
  list-style: none; padding: 0; margin: var(--s-5) 0 0;
  display: grid; gap: var(--s-3);
}
.planner-credentials li {
  display: flex; gap: var(--s-3); align-items: flex-start;
  font-size: var(--fs-14); color: var(--ink-700);
}
.planner-credentials .bullet {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--gold-500); margin-top: 0.55em; flex-shrink: 0;
  box-shadow: 0 0 0 4px rgba(201, 169, 97, 0.15);
}
.planner-credentials strong { color: var(--ink-900); font-weight: 600; }

.planner-feature-cta {
  display: flex; flex-wrap: wrap; gap: var(--s-3);
  margin-top: var(--s-6); padding-top: var(--s-6);
  border-top: 1px solid rgba(11, 22, 35, 0.06);
}
@media (max-width: 479px) {
  .planner-feature-cta .btn { flex: 1 1 100%; }
}

/* Legacy 3-up grid retained in case future planners are added */
.planner-grid {
  display: grid; gap: var(--s-6);
  margin-top: var(--s-10);
}
@media (min-width: 720px) { .planner-grid { grid-template-columns: repeat(3, 1fr); } }

.planner {
  position: relative;
  background: var(--surface);
  border: 1px solid rgba(11, 22, 35, 0.06);
  border-radius: var(--radius-lg);
  padding: var(--s-8) var(--s-6) var(--s-6);
  text-align: center;
  transition: transform 0.25s var(--ease-out), border-color 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out);
}
.planner:hover { transform: translateY(-4px); border-color: rgba(201, 169, 97, 0.3); box-shadow: var(--shadow-md); }

.planner-portrait {
  width: 96px; height: 96px; margin: 0 auto var(--s-4);
  border-radius: 50%;
  display: grid; place-items: center;
  overflow: hidden;
  background: linear-gradient(140deg, var(--ink-700), var(--ink-900));
  color: var(--gold-300);
  border: 1px solid rgba(201, 169, 97, 0.3);
  box-shadow: 0 14px 28px -12px rgba(11, 22, 35, 0.4), inset 0 0 0 4px rgba(255, 255, 255, 0.08);
  font-family: var(--font-display); font-weight: 500; font-size: 1.75rem; letter-spacing: -0.03em;
  position: relative;
}
.planner-portrait img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  display: block;
}
.planner-name {
  font-family: var(--font-display); font-weight: 500; font-size: var(--fs-20);
  color: var(--ink-900); margin: 0 0 4px; letter-spacing: -0.01em;
}
.planner-role {
  font-size: var(--fs-14); color: var(--ink-500); margin: 0 0 var(--s-3);
}
.planner-license {
  display: inline-flex; align-items: center; gap: var(--s-2);
  padding: 0.3rem 0.7rem; border-radius: var(--radius-pill);
  font-size: 0.6875rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase;
  background: var(--gold-100); color: var(--gold-700);
  margin-bottom: var(--s-4);
}
.planner-license::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--gold-600);
}
.planner-bio {
  font-size: var(--fs-14); color: var(--ink-500); margin: 0; line-height: 1.55;
}
.planner-divider {
  display: block; width: 32px; height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold-400), transparent);
  margin: var(--s-3) auto;
}

/* -------- 13. FAQ -------- */
.faq { display: grid; gap: 0; margin-top: var(--s-8); border-top: 1px solid rgba(11, 22, 35, 0.08); }
.faq-item {
  background: transparent; border-bottom: 1px solid rgba(11, 22, 35, 0.08);
  border-radius: 0;
  transition: background 0.2s;
}
.faq-item[open] { background: rgba(201, 169, 97, 0.04); }
.faq-item summary {
  list-style: none; cursor: pointer;
  padding: var(--s-6) var(--s-2);
  display: flex; align-items: center; justify-content: space-between; gap: var(--s-4);
  font-weight: 500; color: var(--ink-900);
  font-family: var(--font-display); font-size: var(--fs-20); letter-spacing: -0.01em;
  transition: color 0.2s;
}
.faq-item summary:hover { color: var(--gold-700); }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: ""; flex-shrink: 0;
  width: 28px; height: 28px; border-radius: 50%;
  border: 1px solid var(--ink-200);
  background:
    linear-gradient(currentColor, currentColor) center/12px 1px no-repeat,
    linear-gradient(currentColor, currentColor) center/1px 12px no-repeat;
  color: var(--ink-500);
  transition: transform 0.25s var(--ease-out), border-color 0.2s, color 0.2s;
}
.faq-item[open] summary::after {
  transform: rotate(45deg);
  border-color: var(--gold-500); color: var(--gold-700);
}
.faq-item .body { padding: 0 var(--s-2) var(--s-6); color: var(--ink-500); max-width: 64ch; }

/* -------- 13b. Contact section -------- */
.contact-section {
  position: relative;
  background:
    radial-gradient(700px 380px at 100% 0%, rgba(201, 169, 97, 0.08), transparent 60%),
    radial-gradient(600px 360px at 0% 100%, rgba(26, 164, 143, 0.06), transparent 60%),
    var(--bg-alt);
  border-top: 1px solid rgba(11, 22, 35, 0.06);
  border-bottom: 1px solid rgba(11, 22, 35, 0.06);
}
.contact-grid {
  display: grid; gap: clamp(2rem, 4vw, 3.5rem);
  align-items: start;
}
@media (min-width: 880px) { .contact-grid { grid-template-columns: 1fr 1.05fr; } }

.contact-pitch h2 { margin-top: var(--s-3); }
.contact-pitch .lede { color: var(--ink-700); margin-top: var(--s-3); }

.contact-portrait {
  position: relative;
  margin-top: var(--s-8);
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 16 / 9;
  box-shadow: var(--shadow-md);
}
.contact-portrait img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
}
.contact-portrait::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(170deg, rgba(11, 22, 35, 0) 40%, rgba(11, 22, 35, 0.6) 100%);
}
.contact-portrait .stamp {
  position: absolute; bottom: var(--s-4); left: var(--s-5); right: var(--s-5);
  color: #fff; z-index: 1;
}
.contact-portrait .stamp em {
  font-family: var(--font-display); font-style: italic; font-weight: 400;
  font-size: var(--fs-18); display: block; margin-bottom: 2px;
}
.contact-portrait .stamp small {
  font-size: 0.6875rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold-300);
}
.contact-promises {
  list-style: none; padding: 0; margin: var(--s-6) 0 0;
  display: grid; gap: var(--s-3);
}
.contact-promises li {
  display: flex; gap: var(--s-3); align-items: flex-start;
  font-size: var(--fs-14); color: var(--ink-700);
}
.contact-promises .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--gold-500); margin-top: 0.55em; flex: 0 0 8px;
  box-shadow: 0 0 0 4px rgba(201, 169, 97, 0.15);
}

.contact-direct {
  margin-top: var(--s-8); padding-top: var(--s-6);
  border-top: 1px solid rgba(11, 22, 35, 0.08);
  display: grid; gap: var(--s-4);
  font-size: var(--fs-14);
}
.contact-direct .row {
  display: flex; gap: var(--s-3); align-items: center; color: var(--ink-700);
}
.contact-direct .row strong { color: var(--ink-900); display: block; font-size: var(--fs-16); }
.contact-direct .icon {
  flex: 0 0 38px; width: 38px; height: 38px; border-radius: 12px;
  display: grid; place-items: center;
  background: rgba(201, 169, 97, 0.12); color: var(--gold-700);
}

.contact-card {
  position: relative;
  background: var(--surface);
  border-radius: var(--radius-xl);
  padding: clamp(1.5rem, 3.5vw, 2.5rem);
  border: 1px solid rgba(11, 22, 35, 0.06);
  box-shadow: var(--shadow-md);
}
.contact-card::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0;
  height: 3px; border-radius: var(--radius-xl) var(--radius-xl) 0 0;
  background: linear-gradient(90deg, var(--gold-500) 0%, var(--gold-300) 50%, var(--teal-500) 100%);
}
.contact-card h3 {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(1.25rem, 1.4vw + 0.6rem, 1.625rem);
  margin: 0 0 var(--s-2);
}
.contact-card .sub { color: var(--ink-500); margin: 0 0 var(--s-6); font-size: var(--fs-14); }

.contact-form .row { display: grid; gap: var(--s-4); }
@media (min-width: 600px) { .contact-form .row--two { grid-template-columns: 1fr 1fr; } }
.contact-form .field { margin-bottom: var(--s-4); }
.contact-form .input,
.contact-form .textarea {
  background: var(--bg-alt);
  border-color: transparent;
}
.contact-form .input:focus,
.contact-form .textarea:focus {
  background: #fff;
  border-color: var(--teal-500);
}
.contact-form .submit-row {
  display: flex; flex-wrap: wrap; gap: var(--s-3); align-items: center;
  justify-content: space-between; margin-top: var(--s-4);
}
.contact-form .privacy-note {
  font-size: var(--fs-12); color: var(--ink-400); max-width: 32ch;
}

.contact-success {
  display: none; text-align: center; padding: var(--s-6) 0;
}
.contact-card.is-success .contact-form { display: none; }
.contact-card.is-success .contact-success { display: block; }
.contact-success .check {
  display: inline-grid; place-items: center;
  width: 64px; height: 64px; border-radius: 50%;
  background: var(--good-100); color: var(--good-600); font-size: 1.75rem;
  margin-bottom: var(--s-4);
}
.contact-success h3 { margin-bottom: var(--s-2); }
.contact-success p { color: var(--ink-500); margin: 0; }

/* -------- 14. CTA band -------- */
.cta-band {
  border-radius: var(--radius-xl);
  background: linear-gradient(140deg, var(--ink-800) 0%, var(--ink-900) 100%);
  color: #fff; padding: clamp(2rem, 4vw, 3.5rem);
  display: grid; gap: var(--s-6); align-items: center;
  position: relative; overflow: hidden;
  box-shadow: 0 30px 70px -30px rgba(11, 22, 35, 0.45), inset 0 0 0 1px rgba(201, 169, 97, 0.18);
}
.cta-band::before {
  content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  width: clamp(120px, 30%, 320px); height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold-400), transparent);
  pointer-events: none;
}
.cta-band::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(600px 320px at 110% -10%, rgba(26, 164, 143, 0.32), transparent 60%),
    radial-gradient(500px 280px at -10% 110%, rgba(201, 169, 97, 0.18), transparent 60%);
}
.cta-band > * { position: relative; z-index: 1; }
@media (min-width: 880px) { .cta-band { grid-template-columns: 1.4fr 1fr; } }
.cta-band h2 { color: #fff; margin: 0 0 var(--s-3); }
.cta-band p { color: rgba(255, 255, 255, 0.78); max-width: 52ch; }
.cta-band .actions { display: flex; flex-wrap: wrap; gap: var(--s-3); justify-content: flex-start; }
@media (min-width: 880px) { .cta-band .actions { justify-content: flex-end; } }
@media (max-width: 479px) {
  .cta-band .actions .btn { flex: 1 1 100%; }
}

/* -------- 15. Footer -------- */
.site-footer {
  background: var(--ink-900); color: var(--ink-200);
  padding: var(--s-16) 0 var(--s-8);
}
.site-footer h4 { color: #fff; margin-bottom: var(--s-4); font-size: var(--fs-14); letter-spacing: 0.14em; text-transform: uppercase; }
.site-footer a { color: var(--ink-200); }
.site-footer a:hover { color: #fff; }
.footer-grid {
  display: grid; gap: var(--s-10) var(--s-8);
  grid-template-columns: 1fr;
}
@media (min-width: 720px) { .footer-grid { grid-template-columns: 1.5fr 1fr 1fr 1fr; } }
.footer-bottom {
  margin-top: var(--s-12);
  padding-top: var(--s-6);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  display: flex; flex-wrap: wrap; gap: var(--s-4); justify-content: space-between;
  font-size: var(--fs-12); color: var(--ink-300);
}

/* -------- 16. Quiz -------- */
.quiz-shell {
  max-width: 720px; margin: 0 auto;
  padding: clamp(2rem, 5vw, 4rem) 0;
}
.quiz-progress {
  display: flex; align-items: center; gap: var(--s-4);
  margin-bottom: var(--s-8);
}
.progress-track {
  flex: 1; height: 6px; border-radius: var(--radius-pill);
  background: rgba(11, 22, 35, 0.08); overflow: hidden;
}
.progress-bar {
  height: 100%; width: 0%; background: linear-gradient(90deg, var(--teal-500), var(--teal-700));
  transition: width 0.45s var(--ease-out);
  border-radius: inherit;
}
.progress-step { font-size: var(--fs-14); color: var(--ink-500); font-variant-numeric: tabular-nums; }

.quiz-card {
  background: var(--surface);
  border-radius: var(--radius-xl);
  border: 1px solid rgba(11, 22, 35, 0.06);
  box-shadow: var(--shadow-md);
  padding: clamp(1.75rem, 3.5vw, 2.75rem);
}

.quiz-step { display: none; }
.quiz-step.is-active { display: block; animation: stepIn 0.45s var(--ease-out) both; }
@keyframes stepIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: none; }
}

.quiz-step .q-num {
  font-size: var(--fs-12); letter-spacing: 0.18em; color: var(--teal-700); font-weight: 600; text-transform: uppercase;
}
.quiz-step h2 {
  font-size: clamp(1.5rem, 1.8vw + 0.6rem, 2.125rem);
  margin: var(--s-3) 0 var(--s-2);
}
.quiz-step .sub { color: var(--ink-500); margin-bottom: var(--s-6); }

.options {
  display: grid; gap: var(--s-3);
  margin-bottom: var(--s-6);
}
.option {
  position: relative; display: flex; align-items: center; gap: var(--s-4);
  padding: var(--s-5) var(--s-5);
  border: 1.5px solid var(--ink-100);
  border-radius: var(--radius-md);
  background: #fff;
  cursor: pointer;
  transition: border-color 0.18s, background 0.18s, transform 0.18s var(--ease-out);
}
.option:hover { border-color: var(--ink-300); }
.option input { position: absolute; opacity: 0; pointer-events: none; }
.option .dot {
  width: 22px; height: 22px; border-radius: 50%;
  border: 2px solid var(--ink-200); background: #fff;
  flex: 0 0 22px;
  position: relative; transition: border-color 0.15s, background 0.15s;
}
.option .dot::after {
  content: ""; position: absolute; inset: 4px; border-radius: 50%;
  background: var(--teal-500); transform: scale(0); transition: transform 0.18s var(--ease-out);
}
.option .label-main { font-weight: 600; color: var(--ink-900); }
.option .label-sub  { display: block; font-size: var(--fs-14); color: var(--ink-500); margin-top: 2px; }
.option:has(input:checked), .option.is-checked {
  border-color: var(--teal-600); background: var(--teal-100);
}
.option:has(input:checked) .dot, .option.is-checked .dot {
  border-color: var(--teal-600); background: #fff;
}
.option:has(input:checked) .dot::after, .option.is-checked .dot::after { transform: scale(1); }

.quiz-actions {
  display: flex; gap: var(--s-3); align-items: center; justify-content: space-between;
  margin-top: var(--s-6); padding-top: var(--s-6);
  border-top: 1px solid rgba(11, 22, 35, 0.06);
  flex-wrap: wrap;
}
.quiz-actions .btn { flex: 0 0 auto; }
@media (max-width: 479px) {
  .quiz-actions { gap: var(--s-2); }
  .quiz-actions .btn { white-space: normal; padding: 0.85rem 1.1rem; font-size: var(--fs-14); }
  .quiz-actions .text-mut { display: none; }
}
.quiz-actions .left { display: flex; gap: var(--s-3); }

.contact-step .row { display: grid; gap: var(--s-4); }
@media (min-width: 640px) { .contact-step .row { grid-template-columns: 1fr 1fr; } }
.consent {
  display: flex; gap: var(--s-3); align-items: flex-start;
  font-size: var(--fs-14); color: var(--ink-500); margin: var(--s-4) 0;
}
.consent input { margin-top: 0.2rem; accent-color: var(--teal-600); }

.quiz-foot {
  text-align: center; margin-top: var(--s-6);
  font-size: var(--fs-12); color: var(--ink-400);
}

/* -------- 17. Result -------- */
.score-hero {
  display: grid; gap: clamp(2rem, 4vw, 3rem);
  align-items: center;
}
@media (min-width: 880px) { .score-hero { grid-template-columns: minmax(220px, 320px) 1fr; } }
.score-hero .visual { display: grid; place-items: center; }

.pscore-ring {
  --size: 240px;
  --thickness: 14px;
  width: var(--size); height: var(--size);
  position: relative;
}
.pscore-ring svg { width: 100%; height: 100%; transform: rotate(-90deg); }
.pscore-ring .track { fill: none; stroke: rgba(11, 22, 35, 0.08); stroke-width: var(--thickness); }
.pscore-ring .meter {
  fill: none; stroke: url(#scoreGradient); stroke-width: var(--thickness); stroke-linecap: round;
  transition: stroke-dashoffset 1.6s var(--ease-out);
}
.pscore-ring .center {
  position: absolute; inset: 0; display: grid; place-items: center; text-align: center;
}
.pscore-ring .num {
  font-family: var(--font-display); font-size: clamp(3rem, 6vw, 4.5rem);
  letter-spacing: -0.04em; color: var(--ink-900); line-height: 1;
}
.pscore-ring.is-dark .num { color: #fff; }
.pscore-ring .pct { font-size: var(--fs-16); color: var(--ink-400); margin-top: 4px; }
.pscore-ring.is-dark .pct { color: rgba(255, 255, 255, 0.7); }

.band-pill {
  display: inline-flex; align-items: center; gap: var(--s-2);
  padding: 0.4rem 0.9rem; border-radius: var(--radius-pill);
  font-size: var(--fs-12); font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase;
  margin-bottom: var(--s-4);
}
.band-pill.tone-good { background: var(--good-100); color: var(--good-600); }
.band-pill.tone-warn { background: var(--warn-100); color: var(--warn-600); }
.band-pill.tone-risk { background: var(--risk-100); color: var(--risk-700); }

.gap-grid {
  display: grid; gap: var(--s-4);
  margin-top: var(--s-8);
}
@media (min-width: 720px) { .gap-grid { grid-template-columns: repeat(2, 1fr); } }
.gap {
  background: var(--surface); border: 1px solid rgba(11, 22, 35, 0.06);
  border-radius: var(--radius-md); padding: var(--s-6);
}
.gap-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--s-3); }
.gap-head .name { font-weight: 600; color: var(--ink-900); }
.gap-head .pts { font-family: var(--font-display); font-size: var(--fs-18); color: var(--ink-500); }
.gap-bar { height: 6px; border-radius: var(--radius-pill); background: rgba(11, 22, 35, 0.06); overflow: hidden; margin-bottom: var(--s-3); }
.gap-bar > span { display: block; height: 100%; border-radius: inherit; transition: width 1.2s var(--ease-out); }
.gap.sev-good .gap-bar > span { background: var(--good-500); }
.gap.sev-warn .gap-bar > span { background: var(--warn-500); }
.gap.sev-risk .gap-bar > span { background: var(--risk-500); }
.gap .note { color: var(--ink-500); margin: 0; font-size: var(--fs-14); }

.insight-card {
  margin-top: var(--s-10);
  background: linear-gradient(140deg, var(--ivory-2), #fff);
  border: 1px solid rgba(11, 22, 35, 0.06);
  border-radius: var(--radius-lg);
  padding: clamp(1.5rem, 3vw, 2.25rem);
}
.insight-card h3 { font-family: var(--font-display); margin: 0 0 var(--s-3); }
.insight-card p { color: var(--ink-700); margin: 0; }

/* -------- 18. Booking -------- */
.book-grid { display: grid; gap: var(--s-10); }
@media (min-width: 980px) { .book-grid { grid-template-columns: 1.15fr 0.85fr; align-items: start; } }

.day-rail { display: grid; grid-template-columns: repeat(auto-fill, minmax(96px, 1fr)); gap: var(--s-2); margin-bottom: var(--s-6); }
@media (min-width: 720px) { .day-rail { grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: var(--s-3); } }
.day-chip {
  border: 1.5px solid var(--ink-100); background: #fff; border-radius: var(--radius-md);
  padding: var(--s-3); text-align: center; cursor: pointer;
  transition: border-color 0.18s, background 0.18s;
}
.day-chip:hover { border-color: var(--ink-300); }
.day-chip.is-active { border-color: var(--ink-900); background: var(--ink-900); color: #fff; }
.day-chip .dow { font-size: var(--fs-12); color: var(--ink-400); letter-spacing: 0.14em; text-transform: uppercase; }
.day-chip.is-active .dow { color: rgba(255, 255, 255, 0.7); }
.day-chip .date { font-family: var(--font-display); font-size: var(--fs-20); margin-top: 2px; }

.time-grid { display: grid; gap: var(--s-2); grid-template-columns: repeat(auto-fill, minmax(96px, 1fr)); }
@media (min-width: 720px) { .time-grid { gap: var(--s-3); grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); } }
.time-chip {
  display: flex; align-items: center; justify-content: center; gap: var(--s-2);
  padding: var(--s-3); border-radius: var(--radius-md);
  border: 1.5px solid var(--ink-100); background: #fff; cursor: pointer; font-weight: 500;
  transition: border-color 0.18s, background 0.18s, color 0.18s;
}
.time-chip:hover:not(.is-taken) { border-color: var(--ink-300); }
.time-chip.is-active { border-color: var(--teal-600); background: var(--teal-600); color: #fff; }
.time-chip.is-taken { color: var(--ink-300); cursor: not-allowed; text-decoration: line-through; background: rgba(11, 22, 35, 0.03); }

.booking-side {
  background: #fff; border: 1px solid rgba(11, 22, 35, 0.06);
  border-radius: var(--radius-lg); padding: var(--s-8);
  box-shadow: var(--shadow-sm);
}

.channel-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-2); margin-bottom: var(--s-4); }
.channel-chip {
  display: flex; align-items: center; justify-content: center;
  border: 1.5px solid var(--ink-100); background: #fff;
  padding: var(--s-3); border-radius: var(--radius-md);
  font-size: var(--fs-14); cursor: pointer;
  transition: border-color 0.18s, background 0.18s, color 0.18s;
}
.channel-chip.is-active { border-color: var(--ink-900); background: var(--ink-900); color: #fff; }

.scarcity {
  display: inline-flex; align-items: center; gap: var(--s-2);
  padding: 0.35rem 0.8rem; border-radius: var(--radius-pill);
  font-size: var(--fs-12); font-weight: 600;
  background: var(--warn-100); color: var(--warn-600);
  white-space: nowrap;
}

/* -------- 19. Animations -------- */
.reveal { opacity: 0; transform: translateY(16px); transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out); }
.reveal.is-visible { opacity: 1; transform: none; }
.reveal[data-delay="1"] { transition-delay: 80ms; }
.reveal[data-delay="2"] { transition-delay: 160ms; }
.reveal[data-delay="3"] { transition-delay: 240ms; }
.reveal[data-delay="4"] { transition-delay: 320ms; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
  html { scroll-behavior: auto; }
}

/* -------- 20. Utilities -------- */
.text-center { text-align: center; }
.text-mut { color: var(--ink-500); }
.flex { display: flex; }
.hide-mobile { display: none; }
@media (min-width: 720px) { .hide-mobile { display: initial; } }
.show-mobile { display: initial; }
@media (min-width: 720px) { .show-mobile { display: none; } }
.mt-0 { margin-top: 0; }
.mt-2 { margin-top: var(--s-2); }
.mt-4 { margin-top: var(--s-4); }
.mt-6 { margin-top: var(--s-6); }
.mt-8 { margin-top: var(--s-8); }
.mb-0 { margin-bottom: 0; }
.gap-2 { gap: var(--s-2); }
.gap-3 { gap: var(--s-3); }
.gap-4 { gap: var(--s-4); }

/* -------- 21. Doc-like pages -------- */
.doc { max-width: var(--container-narrow); margin: 0 auto; padding: var(--s-12) 0; }
.doc h1 { font-size: clamp(2rem, 3vw + 1rem, 3rem); margin-bottom: var(--s-6); }
.doc h2 { font-family: var(--font-sans); font-weight: 600; font-size: var(--fs-20); margin-top: var(--s-8); }
.doc p, .doc li { color: var(--ink-700); }
.doc ul { padding-left: 1.25rem; }
