:root{
  --bg:#fafaf7;
  --bg-2:#f4f4ef;
  --surface:#ffffff;
  --surface-2:#f7f6f1;
  --border:rgba(15,23,42,.08);
  --border-strong:rgba(15,23,42,.14);
  --text:#0b1220;
  --text-muted:#54607a;
  --text-subtle:#8a92a4;
  --primary:#2563eb;
  --primary-hover:color-mix(in oklab,var(--primary) 88%,black);
  --primary-soft:color-mix(in oklab,var(--primary) 10%,white);
  --primary-fg:#ffffff;
  --accent:#0f172a;
  --gold:#b48a2c;
  --gold-soft:#fff6dc;
  --success:#16a34a;
  --danger:#b91c1c;
  --ring:0 0 0 4px color-mix(in oklab,var(--primary) 22%,transparent);
  --radius-sm:8px;
  --radius:12px;
  --radius-lg:18px;
  --radius-xl:24px;
  --radius-pill:999px;
  --shadow-sm:0 1px 2px rgba(15,23,42,.05);
  --shadow:0 1px 2px rgba(15,23,42,.04),0 8px 24px -10px rgba(15,23,42,.12);
  --shadow-lg:0 24px 60px -22px rgba(15,23,42,.22),0 2px 6px rgba(15,23,42,.06);
  --ease:cubic-bezier(.32,.72,0,1);
  --font-sans:'Inter',ui-sans-serif,system-ui,-apple-system,'Segoe UI',sans-serif;
  --font-display:'Fraunces','Instrument Serif',Georgia,serif;
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font:16px/1.55 var(--font-sans);
  color:var(--text);
  background:
    radial-gradient(1100px 600px at 8% -10%,#dbeafe55,transparent 60%),
    radial-gradient(900px 500px at 100% 0%,#fff4d055,transparent 60%),
    var(--bg);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  letter-spacing:-.005em;
  min-height:100vh;
  display:flex;flex-direction:column;
}
img{max-width:100%;display:block}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:inherit}

/* ───── Header ───── */
.site-header{
  display:flex;align-items:center;justify-content:space-between;
  max-width:1120px;width:100%;margin:0 auto;
  padding:20px 28px;
}
.brand{display:inline-flex;align-items:center;gap:12px;text-decoration:none;color:var(--text);font-weight:600;letter-spacing:-.01em}
.brand img{height:30px;width:auto}
.brand-name{font-size:16px}
.header-meta{font-size:13px;color:var(--text-muted);display:inline-flex;align-items:center;gap:8px}
.header-meta .dot{width:8px;height:8px;background:var(--success);border-radius:50%;box-shadow:0 0 0 4px color-mix(in oklab,var(--success) 22%,transparent)}
@media(max-width:600px){.site-header{padding:16px 18px}.header-meta{display:none}}

/* ───── Page scaffolds ───── */
main{flex:1;width:100%}
.view{display:none;animation:fade .42s var(--ease)}
.view.is-active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@media(prefers-reduced-motion:reduce){.view{animation:none}}

/* ───── Hero (intro) ───── */
.hero{
  max-width:1080px;margin:0 auto;
  padding:40px 24px 72px;
  display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center;
}
@media(max-width:900px){.hero{grid-template-columns:1fr;gap:36px;padding:24px 20px 56px}}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:var(--radius-pill);
  background:#fff;border:1px solid var(--border);
  color:var(--text-muted);font-size:12px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  box-shadow:var(--shadow-sm);
}
.eyebrow .pulse{width:7px;height:7px;border-radius:50%;background:var(--success);box-shadow:0 0 0 4px color-mix(in oklab,var(--success) 22%,transparent);animation:pulse 1.6s ease-out infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in oklab,var(--success) 50%,transparent)}100%{box-shadow:0 0 0 9px color-mix(in oklab,var(--success) 0%,transparent)}}
h1.hero-title{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(40px,6vw,68px);line-height:1.02;letter-spacing:-.025em;
  margin:22px 0 18px;
  color:var(--text);
}
h1.hero-title em{font-style:italic;color:var(--primary);font-weight:500}
.hero-sub{font-size:18px;line-height:1.55;color:var(--text-muted);max-width:46ch;margin:0 0 32px}
.hero-stats{display:flex;gap:28px;margin:8px 0 24px;flex-wrap:wrap}
.hero-stat{display:flex;flex-direction:column;gap:2px}
.hero-stat b{font-family:var(--font-display);font-weight:500;font-size:30px;letter-spacing:-.02em;color:var(--text)}
.hero-stat span{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-subtle);font-weight:600}

.zip-form{
  display:flex;align-items:stretch;gap:10px;
  background:#fff;border:1px solid var(--border-strong);
  padding:8px;border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  max-width:520px;
}
.zip-form input{
  flex:1;min-width:0;
  border:0;outline:0;background:transparent;
  padding:14px 16px;
  font:600 18px/1.2 var(--font-sans);letter-spacing:.04em;
  color:var(--text);
}
.zip-form input::placeholder{color:var(--text-subtle);font-weight:500;letter-spacing:.02em}
.zip-form .err{display:none}
.zip-error{margin:10px 0 0;color:var(--danger);font-size:13.5px;display:none}
.zip-error.is-shown{display:block}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font:600 15.5px/1 var(--font-sans);letter-spacing:-.005em;
  padding:0 22px;height:52px;border-radius:var(--radius);
  background:var(--primary);color:var(--primary-fg);
  box-shadow:0 1px 0 rgba(255,255,255,.18) inset,0 6px 18px -8px color-mix(in oklab,var(--primary) 70%,transparent);
  transition:transform .16s var(--ease),background .16s ease,box-shadow .16s ease;
  cursor:pointer;text-decoration:none;
}
.btn:hover{background:var(--primary-hover);transform:translateY(-1px)}
.btn:active{transform:translateY(1px)}
.btn:focus-visible{outline:none;box-shadow:var(--ring),0 6px 18px -8px color-mix(in oklab,var(--primary) 70%,transparent)}
.btn[disabled]{opacity:.55;cursor:not-allowed;transform:none}
.btn svg{width:18px;height:18px}
.btn.btn-lg{height:60px;font-size:17px;padding:0 28px;border-radius:14px}
.btn.btn-full{width:100%}
.btn.btn-ghost{background:#fff;color:var(--text);border:1px solid var(--border-strong);box-shadow:none}
.btn.btn-ghost:hover{background:var(--surface-2)}

.trust-row{display:flex;gap:18px;flex-wrap:wrap;align-items:center;margin-top:18px;color:var(--text-subtle);font-size:12.5px;letter-spacing:.04em}
.trust-row li{display:inline-flex;align-items:center;gap:6px;list-style:none}
.trust-row svg{width:14px;height:14px;color:var(--text-muted)}
ul.trust-row{padding:0;margin:18px 0 0}

/* Hero visual: coupon stack */
.coupon-stack{position:relative;height:440px;perspective:1200px}
@media(max-width:900px){.coupon-stack{height:340px;max-width:420px;margin:0 auto}}
.coupon{
  position:absolute;left:50%;top:50%;
  width:300px;height:170px;
  background:linear-gradient(135deg,#fff 0%,#fff 60%,#fbf3da 100%);
  border:1px solid var(--border-strong);
  border-radius:18px;
  box-shadow:0 20px 50px -22px rgba(15,23,42,.28),0 2px 4px rgba(15,23,42,.06);
  padding:18px 22px;
  display:flex;flex-direction:column;justify-content:space-between;
  transform-origin:center;
  transition:transform .6s var(--ease);
}
.coupon::before,.coupon::after{
  content:"";position:absolute;top:50%;width:18px;height:18px;border-radius:50%;
  background:var(--bg);border:1px solid var(--border-strong);transform:translateY(-50%);
}
.coupon::before{left:-10px}
.coupon::after{right:-10px}
.coupon-head{display:flex;align-items:center;justify-content:space-between;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-subtle);font-weight:700}
.coupon-head .seal{display:inline-flex;align-items:center;gap:5px;color:var(--gold);background:var(--gold-soft);padding:3px 8px;border-radius:99px;font-size:10px;letter-spacing:.1em}
.coupon-amt{font-family:var(--font-display);font-weight:500;font-size:48px;letter-spacing:-.03em;color:var(--text);line-height:1}
.coupon-amt small{font-size:18px;color:var(--text-muted);margin-right:4px;vertical-align:6px}
.coupon-foot{font-size:12px;color:var(--text-muted);display:flex;justify-content:space-between;align-items:flex-end;gap:8px}
.coupon-foot b{color:var(--text);font-weight:600}
.coupon.c1{transform:translate(-50%,-50%) rotate(-9deg) translate(-90px,-40px);background:linear-gradient(135deg,#eef4ff,#fff 60%)}
.coupon.c2{transform:translate(-50%,-50%) rotate(5deg) translate(60px,-10px);background:linear-gradient(135deg,#fff,#fff7e0)}
.coupon.c3{transform:translate(-50%,-50%) rotate(-3deg) translate(-30px,90px)}
.coupon-stack:hover .coupon.c1{transform:translate(-50%,-50%) rotate(-12deg) translate(-110px,-50px)}
.coupon-stack:hover .coupon.c2{transform:translate(-50%,-50%) rotate(8deg) translate(80px,-20px)}
.coupon-stack:hover .coupon.c3{transform:translate(-50%,-50%) rotate(-5deg) translate(-30px,110px)}

/* ───── Sub-hero / value row ───── */
.value-row{
  max-width:1080px;margin:0 auto;padding:24px 24px 60px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
}
@media(max-width:780px){.value-row{grid-template-columns:repeat(2,1fr);padding-bottom:40px}}
.value-card{
  background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px;
  display:flex;flex-direction:column;gap:8px;
  box-shadow:var(--shadow-sm);
}
.value-card svg{width:22px;height:22px;color:var(--primary)}
.value-card b{font-size:15px;font-weight:600;letter-spacing:-.005em}
.value-card p{font-size:13.5px;color:var(--text-muted);margin:0;line-height:1.5}

/* ───── Quiz shell ───── */
.quiz-wrap{max-width:640px;margin:0 auto;padding:24px 20px 80px}
.progress{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.progress-track{flex:1;height:6px;background:#e9e7df;border-radius:99px;overflow:hidden}
.progress-fill{height:100%;width:0;background:linear-gradient(90deg,var(--primary),color-mix(in oklab,var(--primary) 60%,#22d3ee));border-radius:99px;transition:width .42s cubic-bezier(.22,1,.36,1)}
.progress-text{font-size:12px;font-weight:600;color:var(--text-muted);letter-spacing:.04em;font-variant-numeric:tabular-nums}
.quiz-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius-xl);
  box-shadow:var(--shadow-lg);
  padding:40px 36px;
}
@media(max-width:600px){.quiz-card{padding:28px 22px;border-radius:18px}}
.step{display:none;animation:fade .32s var(--ease)}
.step.is-active{display:block}
.step h2{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(24px,3.6vw,32px);line-height:1.15;letter-spacing:-.015em;
  margin:0 0 8px;color:var(--text);
}
.step h2 em{font-style:italic;color:var(--primary);font-weight:500}
.step .help{color:var(--text-muted);font-size:15px;line-height:1.55;margin:0 0 24px;max-width:50ch}

.cards{display:grid;gap:10px}
.cards.cards-2{grid-template-columns:1fr 1fr}
.cards.cards-1{grid-template-columns:1fr}
.cards.cards-grid{grid-template-columns:1fr 1fr}
.cards.cards-grid .option-wide{grid-column:1 / -1}
@media(max-width:480px){.cards.cards-grid{grid-template-columns:1fr}}
.cards.cards-linkout{grid-template-columns:1.6fr 1fr;gap:12px}
@media(max-width:480px){.cards.cards-linkout{grid-template-columns:1fr}}

.step-tag{
  display:inline-block;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;font-weight:700;
  color:var(--primary);background:var(--primary-soft);
  padding:5px 10px;border-radius:99px;margin-bottom:14px;
}
.option-yes{
  text-decoration:none;
  background:var(--primary);color:var(--primary-fg);
  border-color:var(--primary);
  box-shadow:0 1px 0 rgba(255,255,255,.18) inset,0 10px 24px -12px color-mix(in oklab,var(--primary) 70%,transparent);
}
.option-yes:hover{
  background:var(--primary-hover);border-color:var(--primary-hover);
  color:var(--primary-fg);transform:translateY(-1px);
}
.option-yes .arrow{
  width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.18);color:#fff;flex:none;
  display:flex;align-items:center;justify-content:center;
  transition:transform .16s var(--ease),background .16s ease;
}
.option-yes .arrow svg{width:16px;height:16px}
.option-yes:hover .arrow{transform:translateX(3px);background:rgba(255,255,255,.28)}
.option-no{
  background:#fff;color:var(--text-muted);
  border-color:var(--border-strong);font-weight:600;
  justify-content:center;
}
.option-no:hover{background:var(--surface-2);color:var(--text);border-color:var(--border-strong);transform:none}

.quiz-foot{
  display:flex;align-items:center;justify-content:center;gap:6px;
  margin:18px 0 0;font-size:12.5px;color:var(--text-subtle);
}
.quiz-foot svg{width:13px;height:13px}
.finish-eyebrow{margin-bottom:18px;display:inline-flex}
.option{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  text-align:left;width:100%;
  background:#fff;border:1.5px solid var(--border-strong);
  border-radius:14px;padding:18px 20px;min-height:64px;
  font:600 16px/1.2 var(--font-sans);color:var(--text);
  cursor:pointer;transition:all .16s var(--ease);
}
.option:hover{border-color:var(--primary);background:var(--primary-soft);transform:translateY(-1px)}
.option .sub{font-weight:500;color:var(--text-muted);font-size:13px;margin-top:3px;display:block}
.option .opt-main{display:flex;flex-direction:column;gap:0}
.option .check{
  width:24px;height:24px;border-radius:50%;
  border:1.5px solid var(--border-strong);
  flex:none;display:flex;align-items:center;justify-content:center;color:#fff;
  transition:all .16s var(--ease);
}
.option .check svg{width:14px;height:14px;opacity:0}
.option.is-selected{border-color:var(--primary);background:var(--primary-soft);box-shadow:0 0 0 3px color-mix(in oklab,var(--primary) 14%,transparent)}
.option.is-selected .check{background:var(--primary);border-color:var(--primary)}
.option.is-selected .check svg{opacity:1}
.option:focus-visible{outline:none;box-shadow:var(--ring)}

.field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.field label{font-size:13px;font-weight:600;color:var(--text-muted);letter-spacing:.02em}
.field input{
  height:56px;border:1.5px solid var(--border-strong);border-radius:12px;
  padding:0 18px;font:500 17px/1 var(--font-sans);color:var(--text);background:#fff;
  transition:border-color .16s ease,box-shadow .16s ease;
}
.field input::placeholder{color:var(--text-subtle);font-weight:400}
.field input:focus{outline:none;border-color:var(--primary);box-shadow:var(--ring)}
.field-error{color:var(--danger);font-size:13px;margin:6px 0 0;display:none}
.field-error.is-shown{display:block}

.step-actions{display:flex;gap:12px;margin-top:24px;align-items:center}
.step-actions .back{color:var(--text-muted);font-size:14px;font-weight:600;padding:10px 14px;border-radius:10px;background:transparent;border:0;cursor:pointer}
.step-actions .back:hover{background:var(--surface-2);color:var(--text)}
.step-actions .spacer{flex:1}

/* ───── Offers list ───── */
.offers-wrap{max-width:760px;margin:0 auto;padding:32px 20px 80px}
.offers-head{text-align:center;margin-bottom:28px}
.offers-head .eyebrow{margin-bottom:18px}
.offers-head h2{font-family:var(--font-display);font-weight:500;font-size:clamp(30px,4.6vw,44px);line-height:1.08;letter-spacing:-.02em;margin:0 0 10px}
.offers-head h2 em{font-style:italic;color:var(--primary);font-weight:500}
.offers-head p{color:var(--text-muted);max-width:50ch;margin:0 auto;font-size:16px}
.offer-stack{display:grid;gap:14px;margin-top:8px}
.offer{
  display:flex;gap:18px;align-items:center;
  background:#fff;border:1px solid var(--border);border-radius:18px;
  padding:20px 22px;text-decoration:none;color:var(--text);
  box-shadow:var(--shadow-sm);
  transition:transform .16s var(--ease),border-color .16s ease,box-shadow .16s ease;
  position:relative;overflow:hidden;
}
.offer:hover{transform:translateY(-2px);border-color:color-mix(in oklab,var(--primary) 35%,var(--border));box-shadow:var(--shadow)}
.offer:focus-visible{outline:none;box-shadow:var(--ring);border-color:var(--primary)}
.offer-icon{
  width:54px;height:54px;border-radius:14px;flex:none;
  display:flex;align-items:center;justify-content:center;
  background:var(--primary-soft);color:var(--primary);
}
.offer-icon svg{width:26px;height:26px}
.offer-body{flex:1;min-width:0}
.offer-tag{display:inline-block;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--primary);font-weight:700;margin-bottom:4px}
.offer-title{font-family:var(--font-display);font-weight:500;font-size:21px;line-height:1.2;letter-spacing:-.01em;margin:0 0 4px}
.offer-desc{color:var(--text-muted);font-size:14px;line-height:1.5;margin:0}
.offer-cta{flex:none;display:inline-flex;align-items:center;gap:6px;color:var(--primary);font-weight:600;font-size:14px}
.offer-cta svg{width:16px;height:16px;transition:transform .16s ease}
.offer:hover .offer-cta svg{transform:translateX(3px)}
@media(max-width:560px){
  .offer{padding:18px;gap:14px;flex-wrap:wrap}
  .offer-cta{flex-basis:100%;order:3;justify-content:flex-end}
}

.offer.offer-call{
  background:linear-gradient(180deg,#fff,#fffaf0);
  border-color:color-mix(in oklab,var(--gold) 30%,var(--border));
}
.offer.offer-call .offer-icon{background:var(--gold-soft);color:var(--gold)}
.offer.offer-call .offer-tag{color:var(--gold)}
.offer-skip{text-align:center;margin-top:22px}
.offer-skip button{font-size:14px;color:var(--text-muted);font-weight:600;padding:10px 16px;border-radius:10px}
.offer-skip button:hover{color:var(--text);background:var(--surface-2)}

/* ───── Finish (capture) ───── */
.finish-wrap{max-width:520px;margin:0 auto;padding:32px 20px 80px}
.finish-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:36px 32px}
@media(max-width:560px){.finish-card{padding:28px 22px}}
.finish-card h2{font-family:var(--font-display);font-weight:500;font-size:clamp(26px,4vw,34px);line-height:1.12;letter-spacing:-.015em;margin:0 0 8px}
.finish-card .sub{color:var(--text-muted);font-size:15.5px;margin:0 0 24px;line-height:1.55}
.tcpa{font-size:11.5px;line-height:1.55;color:var(--text-subtle);margin:14px 0 0}
.tcpa a{color:var(--text-muted);text-decoration:underline}

/* ───── Confirmation ───── */
.confirm-wrap{max-width:560px;margin:0 auto;padding:48px 20px 80px;text-align:center}
.confirm-icon{
  width:84px;height:84px;border-radius:50%;
  background:color-mix(in oklab,var(--success) 14%,white);
  color:var(--success);
  display:inline-flex;align-items:center;justify-content:center;
  margin:0 auto 24px;border:2px solid color-mix(in oklab,var(--success) 35%,white);
  animation:pop .5s var(--ease);
}
.confirm-icon svg{width:44px;height:44px}
@keyframes pop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
.confirm-wrap h2{font-family:var(--font-display);font-weight:500;font-size:clamp(32px,5vw,46px);line-height:1.05;letter-spacing:-.02em;margin:0 0 12px}
.confirm-wrap h2 em{font-style:italic;color:var(--primary);font-weight:500}
.confirm-wrap p{color:var(--text-muted);font-size:17px;line-height:1.55;max-width:42ch;margin:0 auto 28px}
.confirm-mail{
  display:inline-flex;align-items:center;gap:10px;
  background:#fff;border:1px solid var(--border);border-radius:12px;
  padding:14px 18px;font-size:14.5px;color:var(--text-muted);
  box-shadow:var(--shadow-sm);margin-bottom:24px;
}
.confirm-mail b{color:var(--text);font-weight:600}
.confirm-list{list-style:none;padding:0;margin:32px auto 0;max-width:380px;text-align:left;display:grid;gap:10px}
.confirm-list li{display:flex;gap:12px;align-items:center;font-size:14.5px;color:var(--text-muted)}
.confirm-list svg{width:18px;height:18px;color:var(--success);flex:none}

/* ───── Footer ───── */
.site-footer{
  border-top:1px solid var(--border);
  background:rgba(255,255,255,.6);
  padding:24px;margin-top:auto;
}
.site-footer .inner{max-width:1080px;margin:0 auto;font-size:12.5px;color:var(--text-subtle);line-height:1.6}
.site-footer a{color:var(--text-muted);text-decoration:underline}
.site-footer p{margin:0 0 8px}

/* ───── Toast on link open ───── */
.toast{
  position:fixed;left:50%;bottom:24px;transform:translateX(-50%);
  background:var(--text);color:#fff;
  padding:12px 18px;border-radius:12px;font-size:14px;font-weight:500;
  box-shadow:var(--shadow-lg);
  opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease;
  z-index:50;display:inline-flex;align-items:center;gap:8px;
}
.toast.is-shown{opacity:1;transform:translateX(-50%) translateY(-4px)}
.toast svg{width:16px;height:16px;color:#86efac}
