:root { --green:#00A24D; --green-d:#008A41; --blue:#1E68A3; --ink:#0D1B2A; --muted:#5A6B7B; --line:#E6EBF0; --bg:#FBFCFD; --gold:#F5C842; }
* { box-sizing:border-box; }
body { margin:0; font-family:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif; color:var(--ink); background:#fff; line-height:1.6; -webkit-font-smoothing:antialiased; }
a { text-decoration:none; }
.wrap { max-width:1120px; margin:0 auto; padding:0 24px; }
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; font-weight:700; font-size:15px; padding:14px 26px; border-radius:12px; transition:.18s; cursor:pointer; border:0; }
.btn-green { background:var(--green); color:#fff; } .btn-green:hover { background:var(--green-d); }
.btn-ghost { background:#fff; color:var(--ink); border:1px solid var(--line); } .btn-ghost:hover { border-color:#c8d2dc; }
.eyebrow { font-size:11px; font-weight:800; letter-spacing:.18em; text-transform:uppercase; color:var(--green); margin:0; }
h1,h2,h3 { letter-spacing:-0.02em; }
/* Display headlines use Fraunces (serif) to match the kache. brand family.
   WONK 0 + pinned opsz keeps the 'f'/'g' standard (no swashy descenders). Body stays Montserrat. */
h1,h2,.lead,.quote .q { font-family:'Fraunces',Georgia,'Times New Roman',serif; font-optical-sizing:none; font-variation-settings:"opsz" 40,"WONK" 0; letter-spacing:-0.015em; }
em.em { font-style:italic; font-weight:600; color:var(--green); }
.gold-dot { color:var(--gold); font-style:normal; }
/* Header */
header { position:sticky; top:0; z-index:50; background:rgba(255,255,255,.86); backdrop-filter:saturate(180%) blur(10px); border-bottom:1px solid var(--line); }
.nav { display:flex; align-items:center; justify-content:space-between; height:86px; }
.nav img { height:62px; width:auto; display:block; }
.nav-links { display:flex; gap:30px; align-items:center; }
.nav-links a { color:var(--ink); font-weight:600; font-size:14px; opacity:.8; } .nav-links a:hover { opacity:1; }
@media (max-width:720px){ .nav-links a:not(.btn){ display:none; } }
/* Hero — clean, no color bleed */
.hero { background:var(--bg); border-bottom:1px solid var(--line); }
.hero-inner { max-width:760px; margin:0 auto; text-align:center; padding:64px 0 72px; }
@media (max-width:880px){ .hero-inner{ padding:48px 0 52px; } }
.hero h1 { font-size:clamp(32px,4.6vw,48px); font-weight:600; line-height:1.1; margin:18px auto 0; max-width:17ch; font-variation-settings:"opsz" 48,"WONK" 0; }
.hero p.sub { font-size:18px; color:var(--muted); margin:20px auto 0; max-width:560px; }
.hero .cta { margin-top:32px; display:flex; gap:12px; flex-wrap:wrap; justify-content:center; }
.trust { margin-top:20px; font-size:13px; color:var(--muted); }
/* Calculator card */
.calc { background:#fff; border:1px solid var(--line); border-radius:20px; box-shadow:0 24px 60px -28px rgba(13,27,42,.22); padding:30px; }
.calc h3 { margin:0; font-size:20px; font-weight:800; }
.calc .hint { font-size:13px; color:var(--muted); margin:4px 0 20px; }
.field { margin-bottom:14px; } .field label { display:block; font-size:12px; font-weight:700; color:var(--ink); margin-bottom:6px; }
.field .inp { display:flex; align-items:center; border:1px solid var(--line); border-radius:12px; padding:0 14px; background:#fff; }
.field .inp:focus-within { border-color:var(--green); }
.field .inp span { color:var(--muted); font-weight:600; font-size:15px; }
.field input { border:0; outline:0; font:inherit; font-size:16px; font-weight:600; padding:13px 8px; width:100%; background:transparent; color:var(--ink); }
.result { margin-top:6px; background:linear-gradient(135deg,var(--green),var(--green-d)); color:#fff; border-radius:14px; padding:22px; text-align:center; }
.result .big { font-size:40px; font-weight:800; line-height:1; letter-spacing:-.02em; }
.result .lbl { font-size:12px; opacity:.85; margin-top:8px; }
.result .yr { font-size:13px; opacity:.9; margin-top:10px; font-weight:600; }
.calc .fine { font-size:11px; color:var(--muted); margin-top:14px; text-align:center; }
/* Savings page layout */
.savings-wrap { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; padding:72px 0 88px; }
@media (max-width:880px){ .savings-wrap{ grid-template-columns:1fr; gap:36px; padding:48px 0 60px; } }
.savings-copy h1 { font-size:clamp(30px,4.4vw,46px); font-weight:800; line-height:1.08; margin:16px 0 0; }
.savings-copy p { font-size:16px; color:var(--muted); margin:18px 0 0; max-width:480px; }
.savings-copy .pts { margin:26px 0 0; padding:0; list-style:none; }
.savings-copy .pts li { position:relative; padding-left:26px; margin:12px 0; font-size:14.5px; font-weight:600; }
.savings-copy .pts li::before { content:"✓"; position:absolute; left:0; top:0; color:var(--green); font-weight:800; }
/* Sections */
section.pad { padding:84px 0; } section.pad.tight { padding:64px 0; }
.lead { font-size:clamp(26px,3.4vw,36px); font-weight:600; margin:12px 0 0; max-width:740px; }
.grid3 { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:44px; }
.grid4 { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:40px; }
@media (max-width:860px){ .grid3{ grid-template-columns:1fr; } .grid4{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .grid4{ grid-template-columns:1fr; } }
.card { border:1px solid var(--line); border-radius:16px; padding:26px; background:#fff; transition:.18s; }
.card:hover { box-shadow:0 16px 40px -24px rgba(13,27,42,.2); transform:translateY(-2px); }
.card .tag { width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.card .tag svg { width:22px; height:22px; fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.card h3 { margin:0; font-size:17px; font-weight:800; } .card p { margin:9px 0 0; font-size:13.5px; color:var(--muted); }
/* Featured (B2B) card — the deepest focus, visually dominant over the supporting three */
.feat { border:1.5px solid var(--blue); background:linear-gradient(180deg,#F4F9FD,#fff); border-radius:18px; padding:30px 32px; margin-top:40px; }
.feat h3 { margin:8px 0 0; font-size:22px; font-weight:800; }
.feat p { margin:10px 0 0; font-size:14.5px; color:var(--muted); max-width:680px; }
/* Proof band */
.proof { background:var(--ink); color:#fff; border-radius:22px; padding:46px 32px; display:grid; grid-template-columns:1fr 1fr; gap:32px; text-align:center; }
@media (max-width:620px){ .proof{ grid-template-columns:1fr; gap:28px; } }
.proof .n { font-size:52px; font-weight:800; line-height:1; letter-spacing:-.02em; }
.proof .n.g { color:#7BE5A8; } .proof .n.b { color:#7CC4EF; }
.proof .d { font-size:13px; color:rgba(255,255,255,.72); margin-top:12px; max-width:300px; margin-inline:auto; }
/* Kache band */
.kache { border:1px solid var(--line); border-radius:20px; padding:36px; display:flex; flex-wrap:wrap; gap:24px; align-items:center; justify-content:space-between; background:linear-gradient(180deg,#fff,#FBFCFD); }
/* Screenshot frame (shared) */
.shot { border-radius:14px; border:1px solid var(--line); box-shadow:0 40px 90px -40px rgba(13,27,42,.45); overflow:hidden; background:#fff; }
.shot .bar { height:34px; background:#F1F4F7; border-bottom:1px solid var(--line); display:flex; align-items:center; gap:7px; padding:0 14px; }
.shot .bar i { width:10px; height:10px; border-radius:50%; background:#cdd6df; display:block; }
.shot img { display:block; width:100%; height:auto; }
.shot-pair { display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:24px; }
@media (max-width:760px){ .shot-pair{ grid-template-columns:1fr; } }
/* Quote */
.quote { background:var(--blue); color:#fff; }
.quote .q { font-size:clamp(22px,2.8vw,28px); font-weight:600; line-height:1.45; }
/* Contact */
.contact { background:linear-gradient(135deg,var(--green),var(--blue)); color:#fff; }
footer { background:#fff; border-top:1px solid var(--line); }
.foot { display:flex; flex-wrap:wrap; gap:18px; align-items:center; justify-content:space-between; padding:28px 0; font-size:12.5px; color:var(--muted); }
.foot img { height:26px; opacity:.9; }
