:root{
  --ink:#0f1115; --surface-dark:#1c2230; --green:#15d191; --green-ink:#06694a;
  --paper:#ffffff; --paper-2:#f4f6f8; --muted:#5b6b82; --muted-dark:#9aa7b8;
  --line:#e6e9ee; --line-dark:#2a3242; --warn:#9a6700; --good:#06694a;
  --display:'Space Grotesk',-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --body:'Inter',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --maxw:1040px;
  --s-1:8px; --s-2:12px; --s-3:16px; --s-4:24px; --s-5:32px; --s-6:48px; --s-7:72px;
  --r-sm:10px; --r-md:14px; --r-lg:18px;
  --green-tint:rgba(21,209,145,.12); --green-line:rgba(21,209,145,.4); --btn-ink:#04241a;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body);font-size:17px;line-height:1.6;color:var(--ink);background:var(--paper)}
a{color:var(--green-ink)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
h1,h2,h3{font-family:var(--display);letter-spacing:-.02em;line-height:1.1;margin:0 0 12px}
h1{font-size:clamp(36px,6vw,64px);font-weight:700}
h2{font-size:clamp(26px,4vw,40px);font-weight:700;margin-bottom:20px}
h3{font-size:19px;font-weight:500;letter-spacing:-.01em}
p{margin:0 0 16px}
.muted{color:var(--muted)}
.green{color:var(--green-ink)}
.center{text-align:center}

/* sections */
section{padding:var(--s-7) 0}
section[id]{scroll-margin-top:84px}
.dark{background-color:var(--ink);background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1.3px);background-size:26px 26px;color:#eef2f7}
.dark h1,.dark h2,.dark h3{color:#fff}
.dark .muted{color:var(--muted-dark)}
.dark .green{color:var(--green)}
.alt{background:var(--paper-2)}
.eyebrow{display:inline-block;font-family:var(--display);font-size:13px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--green-ink);margin-bottom:18px}
.dark .eyebrow{color:var(--green)}

/* header */
.site-head{position:sticky;top:0;z-index:30;background:rgba(15,17,21,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line-dark)}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:500;font-size:16px;color:#fff;text-decoration:none}
.brand svg{display:block}
.nav a{margin-left:24px;font-size:15px;color:var(--muted-dark);text-decoration:none}
.nav a:hover{color:#fff}
@media(max-width:680px){.nav{display:none}}

/* hero */
.hero{padding:96px 0 84px;position:relative;overflow:hidden}
.hero .wrap{position:relative;z-index:1}
.hero-art{position:absolute;right:-40px;top:50%;transform:translateY(-50%);width:520px;max-width:52%;opacity:.6;pointer-events:none}
@media(max-width:820px){.hero-art{display:none}}
.step-num{display:block;font-family:var(--display);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.dark .step-num{color:var(--muted-dark)}
.step .n svg{width:24px;height:24px}
.hero h1{max-width:840px}
.hero p.sub{font-size:clamp(18px,2.3vw,22px);color:var(--muted-dark);max-width:600px;margin:18px 0 30px}

/* buttons */
.btn{display:inline-block;font-family:var(--display);background:var(--green);color:var(--btn-ink);border:1.5px solid transparent;border-radius:var(--r-sm);padding:15px 28px;font-size:16px;font-weight:500;cursor:pointer;text-decoration:none}
.btn:hover{filter:brightness(1.06)}
.btn.ghost{background:transparent;color:#fff;border:1.5px solid #3a4253}
.btn.ghost:hover{border-color:var(--green);color:var(--green)}
.btn.ghost-light{background:transparent;color:var(--green-ink);border:1.5px solid var(--green-line)}
.btn.ghost-light:hover{border-color:var(--green);background:var(--green-tint)}
.btn.secondary{background:#fff;color:var(--ink);border:1.5px solid var(--line)}

/* cards + calculator */
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:0 1px 3px rgba(15,17,21,.05),0 14px 40px rgba(15,17,21,.06);padding:28px}
.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:start}
.calc-grid h3{margin:0 0 14px}
.result-panel{background:var(--paper-2);border-radius:var(--r-md);padding:20px 22px}
.breakdown-rows{margin-top:16px;border-top:1px solid var(--line);padding-top:4px}
@media(max-width:780px){.calc-grid{grid-template-columns:1fr}}
label{display:block;font-weight:500;font-size:15px;margin:14px 0 6px}
label .hint{font-weight:400;color:var(--muted);font-size:13px;display:block}
input,select{width:100%;padding:13px 14px;border:1px solid var(--line);border-radius:var(--r-sm);font-size:16px;font-family:var(--body);background:#fff;color:var(--ink)}
input:focus,select:focus{outline:3px solid rgba(21,209,145,.35);border-color:var(--green)}
.toggle{margin-top:14px;font-size:14px;color:var(--green-ink);background:none;border:0;cursor:pointer;padding:0;text-decoration:underline}
#advanced{display:none} #advanced.open{display:block}
.result-cash{font-family:var(--display);font-size:clamp(40px,7vw,56px);font-weight:700;letter-spacing:-.03em;line-height:1.02;color:var(--green-ink);margin:2px 0 0}
.apr-box{margin-top:14px;background:var(--ink);color:#fff;border-radius:var(--r-md);padding:14px 16px}
.apr-box .lbl{font-size:12px;color:var(--green);font-weight:500;text-transform:uppercase;letter-spacing:.1em}
.apr-box .val{font-family:var(--display);font-size:30px;font-weight:700;margin-top:3px}
.row{display:flex;justify-content:space-between;align-items:baseline;padding:10px 0;border-bottom:1px solid var(--line);font-size:15px;gap:10px;flex-wrap:nowrap}
.row .k{flex:1;min-width:0}
.row .v{flex-shrink:0;white-space:nowrap}
.row:last-child{border-bottom:0}
.row .k{color:var(--muted)} .row .v{font-variant-numeric:tabular-nums;font-weight:500}
.row.total .k,.row.total .v{font-weight:700;color:var(--ink);font-size:17px}
table.cmp{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums;margin-top:8px;min-width:460px}
table.cmp th,table.cmp td{text-align:right;padding:12px 8px;border-bottom:1px solid var(--line);font-size:15px}
table.cmp th{font-family:var(--display);font-weight:500;color:var(--muted)}
table.cmp th:first-child,table.cmp td:first-child{text-align:left}
table.cmp tr.us td{background:var(--green-tint);font-weight:700}
.delta{color:var(--green-ink);font-weight:500}
.inline-capture{margin-top:18px;display:flex;gap:8px;flex-wrap:wrap}
.inline-capture input{flex:1;min-width:180px}

/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:30px}
@media(max-width:780px){.steps{grid-template-columns:1fr 1fr}}
.step .n{font-family:var(--display);width:40px;height:40px;border-radius:11px;background:rgba(21,209,145,.16);color:var(--green-ink);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;margin-bottom:12px}
.dark .step .n{color:var(--green);background:rgba(21,209,145,.14)}
.step h3{margin-bottom:6px;min-height:42px}
.step p{font-size:14px;color:var(--muted)}
.dark .step p{color:var(--muted-dark)}

/* pricing breakdown */
.breakdown{max-width:560px}

/* two-col */
.two{display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:start;margin-top:30px}
@media(max-width:780px){.two{grid-template-columns:1fr}}
.pledge{list-style:none;padding:0;margin:0}
.pledge li{position:relative;padding-left:30px;margin-bottom:12px}
.pledge li::before{content:"";position:absolute;left:0;top:8px;width:14px;height:14px;border-radius:4px;background:var(--green)}

/* faq */
.faq details{border:1px solid var(--line);border-radius:var(--r-md);background:#fff;padding:2px 20px;margin-bottom:12px}
.faq summary{cursor:pointer;font-family:var(--display);font-weight:500;padding:16px 0;font-size:16px;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--green-ink);font-size:20px}
.faq details[open] summary::after{content:"−"}
.faq p{padding-bottom:10px;color:var(--muted)}

/* notes */
.note{font-size:14px;color:var(--muted)}
.disclaimer{background:#fff8ec;border:1px solid #f0ddb4;border-radius:14px;padding:18px 20px;font-size:13px;color:#6b5618}
.draft-banner{background:#fff4e0;border-bottom:1px solid #f0d49a;color:#7a4d00;padding:11px 16px;font-size:14px;text-align:center}

/* footer */
footer{background-color:var(--ink);background-image:radial-gradient(rgba(255,255,255,.04) 1px,transparent 1.3px);background-size:26px 26px;color:var(--muted-dark);padding:48px 0;font-size:14px;border-top:1px solid var(--line-dark)}
footer a{color:var(--green)}
footer .wrap{display:flex;flex-direction:column;gap:14px}

/* article */
.article{max-width:680px;margin:0 auto;padding:56px 22px 24px}
.article h1{font-size:clamp(32px,5vw,44px)}
.article h2{font-size:24px;margin:40px 0 18px}
.article ul{padding-left:22px} .article li{margin-bottom:9px}
.callout{background:rgba(21,209,145,.08);border:1px solid var(--green-line);border-radius:var(--r-md);padding:18px 20px;margin:22px 0}
.verify{color:#785000;font-style:italic}

/* polish pass — alignment & mobile */
.calc-capture{margin-top:22px;padding-top:18px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;align-items:center;gap:12px}
.calc-capture .cap-label{font-weight:500;font-size:15px}
.calc-capture .inline-capture{margin-top:0;flex:1;min-width:240px;max-width:440px}
.calc-capture .note{width:100%;margin:0}
.cmp-wrap{overflow-x:auto}
.navmenu{display:none;position:relative}
.navmenu>summary{list-style:none;cursor:pointer;color:#fff;display:flex;align-items:center;padding:6px;border-radius:var(--r-sm)}
.navmenu>summary::-webkit-details-marker{display:none}
.navmenu-panel{position:absolute;right:0;top:calc(100% + 10px);background:var(--ink);border:1px solid var(--line-dark);border-radius:var(--r-md);padding:8px;min-width:190px;display:flex;flex-direction:column;box-shadow:0 12px 34px rgba(0,0,0,.45)}
.navmenu-panel a{color:#eef2f7;text-decoration:none;padding:10px 12px;border-radius:var(--r-sm);font-size:15px}
.navmenu-panel a:hover{background:var(--surface-dark);color:#fff}
@media(max-width:680px){.navmenu{display:block}}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px}
.tag-us{display:inline-block;background:var(--green);color:var(--btn-ink);font-weight:500;font-size:13px;padding:3px 10px;border-radius:999px}
.breadcrumb{font-size:14px;color:var(--muted);margin-bottom:16px}
.breadcrumb a{color:var(--green-ink);text-decoration:none}
.toc{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-md);padding:16px 20px;margin:24px 0}
.toc strong{display:block;font-family:var(--display);font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.toc ul{margin:0;padding-left:18px}
.toc li{margin-bottom:6px}
@media(max-width:680px){.hero{padding:56px 0 48px}.article{padding-top:32px}}

/* savings bar chart */
.savings-chart{margin:8px 0 18px}
.bar-row{margin-bottom:16px}
.bar-row:last-child{margin-bottom:0}
.bar-top{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:6px;flex-wrap:nowrap}
.bar-name{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1}
.bar-val{font-variant-numeric:tabular-nums;font-weight:700;font-family:var(--display);white-space:nowrap;flex-shrink:0}
.bar-track{height:16px;background:var(--paper-2);border-radius:999px;overflow:hidden}
.bar-fill{height:100%;width:0;background:var(--muted-dark);border-radius:999px;transition:width .35s ease}
.bar-fill.us{background:var(--green)}
.bar-sub{font-size:12px;color:var(--muted);margin-top:5px;min-height:18px}
@media(max-width:480px){.bar-name{font-size:13px}.bar-val{font-size:14px}}

/* court-approval timeline */
.timeline{display:flex;position:relative;margin:26px 0 8px}
.timeline::before{content:"";position:absolute;top:7px;left:12.5%;right:12.5%;height:2px;background:var(--line)}
.tl-step{flex:1;text-align:center;position:relative;padding-top:26px}
.tl-dot{position:absolute;top:0;left:50%;transform:translateX(-50%);width:16px;height:16px;border-radius:50%;background:var(--green);border:3px solid var(--paper);box-shadow:0 0 0 1px var(--line)}
.tl-title{font-weight:500;font-size:14px}
.tl-sub{font-size:13px;color:var(--muted)}
@media(max-width:560px){
  .timeline{flex-direction:column;gap:16px;margin-left:4px}
  .timeline::before{left:7px;right:auto;top:8px;bottom:8px;width:2px;height:auto}
  .tl-step{text-align:left;padding:0 0 0 28px}
  .tl-dot{left:0;top:2px;transform:none}
}

/* WHY-WE-EXIST page components */
.why-hero{padding:88px 0 64px;position:relative;overflow:hidden}
.why-hero .wrap{display:grid;grid-template-columns:1.35fr 1fr;gap:48px;align-items:center}
@media(max-width:880px){.why-hero .wrap{grid-template-columns:1fr;gap:34px}}
.why-hero h1{font-size:clamp(36px,5.4vw,58px);line-height:1.04;letter-spacing:-.02em;margin:14px 0 22px;max-width:680px}
.why-hero p.sub{font-size:clamp(17px,1.9vw,20px);color:var(--muted-dark);max-width:620px;margin:0 0 28px;line-height:1.55}
.stat-card{background:rgba(255,255,255,.04);border:1px solid var(--line-dark);border-radius:var(--r-lg);padding:30px 28px;position:relative}
.stat-card .stat-eyebrow{font-family:var(--display);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--green);margin-bottom:10px;font-weight:500}
.stat-card .stat-num{font-family:var(--display);font-size:clamp(72px,9.5vw,118px);line-height:.92;font-weight:700;color:#fff;letter-spacing:-.045em}
.stat-card .stat-num .unit{color:var(--green);font-size:.55em;font-weight:500;margin-left:4px}
.stat-card .stat-desc{font-size:15px;color:var(--muted-dark);margin-top:14px;line-height:1.5}
.stat-card .stat-src{font-size:12px;color:var(--muted-dark);opacity:.72;margin-top:14px;border-top:1px solid var(--line-dark);padding-top:12px}

/* Receipts — citation timeline cards */
.receipts{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin:28px 0 10px}
.receipt{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:20px 20px 18px;transition:transform .15s,box-shadow .15s}
.receipt:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(15,17,21,.07)}
.receipt .yr{font-family:var(--display);font-size:12px;font-weight:700;color:var(--green-ink);letter-spacing:.08em}
.receipt .src{font-family:var(--display);font-weight:500;font-size:15px;margin:4px 0 8px;color:var(--ink);line-height:1.3}
.receipt .head{font-size:13.5px;color:var(--muted);line-height:1.5}
.receipt .tag{display:inline-block;font-size:11px;background:var(--green-tint);color:var(--green-ink);padding:3px 9px;border-radius:999px;margin-top:12px;font-weight:500;letter-spacing:.02em}

/* Them vs Us comparison */
.vs-grid{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin:24px 0}
.vs-head{font-family:var(--display);font-size:12px;letter-spacing:.12em;text-transform:uppercase;padding:14px 22px;font-weight:500}
.vs-head.them{background:#fdf0e8;color:#8a3a0e;border-bottom:1px solid var(--line)}
.vs-head.us{background:rgba(21,209,145,.14);color:var(--green-ink);border-bottom:1px solid var(--line);border-left:1px solid var(--line)}
.vs-cell{padding:18px 22px;border-top:1px solid var(--line)}
.vs-cell.them{background:#fffaf6}
.vs-cell.us{background:#fff;border-left:1px solid var(--line)}
.vs-cell h3{margin:0 0 6px;font-size:16px;font-family:var(--display);font-weight:500}
.vs-cell p{margin:0;font-size:14px;color:var(--muted);line-height:1.55}
@media(max-width:680px){
  .vs-grid{grid-template-columns:1fr}
  .vs-head{display:none}
  .vs-cell{position:relative;padding-top:46px}
  .vs-cell.us{border-left:0;border-top:1px solid var(--line)}
  .vs-cell.them::before,.vs-cell.us::before{
    position:absolute;top:0;left:0;right:0;padding:11px 22px;
    font-family:var(--display);font-size:11px;letter-spacing:.12em;
    text-transform:uppercase;font-weight:500;border-bottom:1px solid var(--line)
  }
  .vs-cell.them::before{content:"What the worst actors do";background:#fdf0e8;color:#8a3a0e}
  .vs-cell.us::before{content:"What we do, structurally";background:rgba(21,209,145,.14);color:var(--green-ink)}
}

/* Checklist card (saveable / shareable) — explicit ink colors so dark-section cascade doesn't bleed onto white card */
.checklist{background:var(--paper);border:1px solid var(--green-line);border-radius:var(--r-lg);padding:34px 32px;box-shadow:0 1px 3px rgba(15,17,21,.05),0 22px 60px rgba(15,17,21,.18);max-width:580px;margin:0 auto;color:var(--ink);text-align:left}
.checklist .ck-eyebrow{font-family:var(--display);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--green-ink);font-weight:500;margin-bottom:8px}
.checklist h3{margin:0 0 20px;font-size:22px;line-height:1.25;color:var(--ink)}
.checklist ol{list-style:none;counter-reset:ck;padding:0;margin:0}
.checklist li{counter-increment:ck;padding-left:40px;position:relative;margin-bottom:14px;font-size:15px;line-height:1.5;color:var(--ink)}
.checklist li:last-child{margin-bottom:0}
.checklist li strong{color:var(--ink)}
.checklist li::before{content:counter(ck);position:absolute;left:0;top:-1px;width:28px;height:28px;border-radius:8px;background:var(--green-tint);color:var(--green-ink);font-family:var(--display);font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center}
.checklist .foot{margin-top:22px;padding-top:16px;border-top:1px solid var(--line);font-size:13px;color:var(--muted)}
.dark .checklist h3,.dark .checklist li,.dark .checklist li strong{color:var(--ink)}

/* Tight section helper */
.section-tight{padding:68px 0}
.section-tight .wrap>.eyebrow{margin-bottom:14px}
.section-tight h2{font-size:clamp(28px,3.6vw,38px);line-height:1.15;margin:0 0 14px;letter-spacing:-.01em;max-width:720px}
.section-tight .lede{font-size:18px;color:var(--muted);max-width:680px;margin:0 0 22px;line-height:1.55}
.dark .section-tight .lede{color:var(--muted-dark)}

/* Pull quote */
.pull{border-left:3px solid var(--green);padding:6px 0 6px 22px;margin:22px 0 6px;font-size:clamp(19px,2.1vw,22px);line-height:1.4;font-family:var(--display);font-weight:500;color:var(--ink);max-width:720px}
.dark .pull{color:#fff}
.pull cite{display:block;margin-top:12px;font-size:13px;color:var(--muted);font-style:normal;font-weight:400;font-family:var(--body)}
.dark .pull cite{color:var(--muted-dark)}

/* Sources block */
.sources{margin-top:36px;padding:22px 26px;background:var(--paper-2);border-radius:var(--r-md);font-size:13px;color:var(--muted);line-height:1.65}
.sources strong{display:block;font-family:var(--display);text-transform:uppercase;letter-spacing:.1em;font-size:12px;color:var(--ink);margin-bottom:10px;font-weight:500}
.sources ol{margin:0;padding-left:18px}
.sources li{margin-bottom:8px}
.sources a{color:var(--green-ink);text-decoration:none;border-bottom:1px solid var(--green-line)}
.sources a:hover{border-bottom-color:var(--green)}

/* Clickable receipts + external-link affordance */
a.receipt{text-decoration:none;color:inherit;display:block;position:relative}
.receipt{position:relative}
.receipt .ext-arrow{position:absolute;top:18px;right:18px;color:var(--muted);opacity:.5;transition:opacity .15s,transform .15s,color .15s}
.receipt:hover .ext-arrow{opacity:1;color:var(--green-ink);transform:translate(2px,-2px)}

/* Hero stat as a link */
a.stat-card{text-decoration:none;color:inherit;display:block;transition:border-color .15s,background .15s}
a.stat-card:hover{border-color:var(--green-line);background:rgba(255,255,255,.06)}
a.stat-card .stat-src{color:var(--green);opacity:.85}

/* Video CTA card */
.video-cta{display:grid;grid-template-columns:auto 1fr auto;gap:22px;align-items:center;background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:22px 26px;margin:24px 0 4px;box-shadow:0 18px 50px rgba(15,17,21,.16);text-decoration:none}
.video-cta:hover{filter:brightness(1.05)}
.video-cta .play{width:58px;height:58px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 14px rgba(21,209,145,.4)}
.video-cta .play svg{margin-left:3px}
.video-cta .video-eyebrow{font-family:var(--display);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--green);font-weight:500;margin-bottom:4px;display:block}
.video-cta h3{margin:0;font-size:18px;line-height:1.3;color:#fff;font-family:var(--display);font-weight:500}
.video-cta .meta{font-size:13px;color:var(--muted-dark);margin-top:6px}
.video-cta .go{font-family:var(--display);font-size:14px;font-weight:500;color:var(--green);white-space:nowrap;display:inline-flex;align-items:center;gap:4px}
@media(max-width:680px){
  .video-cta{grid-template-columns:1fr;text-align:left;padding:22px;gap:14px}
  .video-cta .go{justify-self:start}
}
