:root{
  --sage:#5B8A72; --sage-hover:#4E7A64; --sage-press:#426B57; --sage-tint:#EBF4EF; --sage-tint2:#DCEAE3;
  --amber:#D4956A; --amber-tint:#FBF1E8;
  --bg:#F8F7F4; --surface:#FFFFFF; --sunken:#F2F1EE;
  --border:#E4E3DF; --border-soft:#EEECEA;
  --fg1:#1C1B18; --fg2:#6B6A63; --fg3:#ABABA4;
  --error:#C45A45; --warning:#C49A35; --success:#4A8A6A; --info:#4A7BA8; --info-tint:#EAF1F8;
  --r-sm:4px; --r-md:8px; --r-lg:12px; --r-full:9999px;
  --sh1:0 1px 3px rgba(28,27,24,.08),0 1px 2px rgba(28,27,24,.05);
  --sh2:0 4px 12px rgba(28,27,24,.10),0 2px 4px rgba(28,27,24,.06);
  --sh3:0 8px 24px rgba(28,27,24,.12),0 4px 8px rgba(28,27,24,.06);
  --ease:cubic-bezier(.2,0,0,1);
  --sans:'DM Sans',system-ui,-apple-system,sans-serif;
  --mono:'DM Mono','Fira Code',monospace;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{font-family:var(--sans);background:var(--bg);color:var(--fg1);line-height:1.5;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{margin:0;font-weight:600;letter-spacing:-.01em;line-height:1.2}
.mono{font-family:var(--mono)}
.muted{color:var(--fg2)}
.tnum{font-variant-numeric:tabular-nums}

/* ---------- Lock screen + modal ---------- */
#lock{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}
.lockcard{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-lg);box-shadow:var(--sh2);max-width:380px;width:100%;padding:32px;text-align:center}
.locklogo{width:48px;height:48px;border-radius:var(--r-md);background:var(--sage);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.locklogo .material-symbols-rounded{color:#fff;font-size:26px}
.lockcard h2{font-size:22px;margin-bottom:6px}
.lockcard p{color:var(--fg2);font-size:14px;margin-bottom:20px}
.lockrow{display:flex;gap:8px}
.pwin{flex:1;font-family:var(--sans);font-size:14px;color:var(--fg1);background:#fff;border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 12px;outline:none;transition:border .15s,box-shadow .15s;width:100%}
.pwin:focus{border-color:var(--sage);box-shadow:0 0 0 3px rgba(91,138,114,.15)}
.pwin.err{border-color:var(--error);box-shadow:0 0 0 3px rgba(196,90,69,.15)}
.btn{font-family:var(--sans);font-size:14px;font-weight:500;border:none;border-radius:var(--r-sm);padding:10px 16px;cursor:pointer;transition:background .15s,transform .1s;display:inline-flex;align-items:center;justify-content:center;gap:6px}
.btn-primary{background:var(--sage);color:#fff}
.btn-primary:hover{background:var(--sage-hover)}
.btn-primary:active{transform:scale(.98);background:var(--sage-press)}
.btn-ghost{background:transparent;color:var(--fg2);border:1px solid var(--border)}
.btn-ghost:hover{background:var(--sunken)}
#lockerr,#amterr{color:var(--error);font-size:13px;margin-top:12px;min-height:18px;text-align:left}
.lockhint{font-size:12px;color:var(--fg3);margin-top:14px}
.modal-overlay{position:fixed;inset:0;background:rgba(28,27,24,.45);display:none;align-items:center;justify-content:center;z-index:90;padding:24px}
.modal-overlay.show{display:flex}
.modalcard{background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--sh3);max-width:360px;width:100%;padding:28px;text-align:center}
.modalcard h3{font-size:19px;margin-bottom:6px}
.modalcard p{color:var(--fg2);font-size:14px;margin-bottom:18px}
.modalcard .locklogo{width:44px;height:44px;margin-bottom:14px}
.modalcard .locklogo .material-symbols-rounded{font-size:24px}

/* ---------- App shell ---------- */
#app{display:none}
.topbar{position:sticky;top:0;z-index:30;height:56px;background:rgba(248,247,244,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;padding:0 16px}
.brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.brand .mk{width:28px;height:28px;border-radius:var(--r-sm);background:var(--sage);display:flex;align-items:center;justify-content:center}
.brand .mk .material-symbols-rounded{color:#fff;font-size:18px}
.brand .nm{font-weight:600;font-size:15px;white-space:nowrap}
.topbar .spacer{flex:1}
.nav{display:flex;align-items:center;gap:2px;margin-left:6px}
.nav a{font-size:13px;color:var(--fg2);padding:7px 9px;border-radius:var(--r-sm);text-decoration:none;white-space:nowrap;transition:background .15s,color .15s}
.nav a:hover{background:var(--sunken);color:var(--fg1)}
.toolbtn{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--fg2);background:transparent;border:1px solid var(--border);border-radius:var(--r-full);padding:7px 13px;cursor:pointer;transition:all .15s;white-space:nowrap}
.toolbtn:hover{background:var(--surface);box-shadow:var(--sh1)}
.toolbtn .material-symbols-rounded{font-size:18px}
.toolbtn.on{background:var(--sage-tint);color:var(--sage-press);border-color:var(--sage-tint2)}
.navtoggle{display:none}
.wrap{max-width:1100px;margin:0 auto;padding:28px 20px 80px}
.eyebrow{display:flex;align-items:center;gap:8px;margin:34px 0 14px;scroll-margin-top:74px}
.eyebrow .material-symbols-rounded{font-size:18px;color:var(--sage)}
.eyebrow span{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--fg2)}
#sec-status{margin-top:8px}
.card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-md);box-shadow:var(--sh1);padding:24px}

/* hero */
.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:stretch}
.statusbig{font-size:34px;font-weight:700;letter-spacing:-.02em;line-height:1.12}
.statusbig .pct{color:var(--sage)}
.fnref{font-size:13px;vertical-align:super;line-height:0}
.fnref a{color:var(--sage);text-decoration:none;font-weight:600;padding:0 1px}
.fnref a:hover{text-decoration:underline}
.statuslede{color:var(--fg2);font-size:15px;margin-top:10px;max-width:46ch}
.meter{margin-top:22px}
.meterbar{position:relative;height:14px;border-radius:var(--r-full);background:var(--sunken);overflow:hidden;border:1px solid var(--border)}
.meterfill{height:100%;background:var(--sage);border-radius:var(--r-full);transition:width .4s var(--ease)}
.meterlabels{display:flex;justify-content:space-between;margin-top:8px;font-size:12px;color:var(--fg3)}
.tiles{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.tile{background:var(--bg);border:1px solid var(--border-soft);border-radius:var(--r-md);padding:14px 16px}
.tile .t-label{font-size:11px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--fg2)}
.tile .t-val{font-size:22px;font-weight:600;margin-top:4px;letter-spacing:-.01em}
.tile .t-sub{font-size:12px;color:var(--fg3);margin-top:2px}
.tile.good .t-val{color:var(--sage)}
.tile.warn .t-val{color:var(--amber)}

/* chart */
.chartcard h3{font-size:18px;margin-bottom:2px}
.chart-sub{color:var(--fg2);font-size:13px;margin-bottom:14px}
.legend{display:flex;flex-wrap:wrap;gap:16px;margin-top:14px}
.lg{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--fg2)}
.lg .sw{width:16px;height:3px;border-radius:2px}
.lg .sw.dash{height:0;border-top:2px dashed}
svg.chart{display:block;width:100%;height:auto;touch-action:pan-y}
.cap{margin-top:12px;font-size:13px;color:var(--fg2);display:flex;gap:8px;align-items:flex-start}
.cap .material-symbols-rounded{font-size:18px;color:var(--amber);margin-top:1px;flex-shrink:0}

/* levers */
.levers{display:grid;grid-template-columns:1fr 1fr;gap:18px 32px}
.lever{display:flex;flex-direction:column;gap:7px}
.lever .lhead{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.lever .lname{font-size:14px;font-weight:500}
.lever .lval{font-family:var(--mono);font-size:14px;font-weight:500;color:var(--sage-press);background:var(--sage-tint);padding:1px 8px;border-radius:var(--r-sm);white-space:nowrap}
input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:4px;border-radius:var(--r-full);background:var(--border);outline:none;margin:6px 0}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--sage);cursor:pointer;border:3px solid #fff;box-shadow:var(--sh1)}
input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--sage);cursor:pointer;border:3px solid #fff;box-shadow:var(--sh1)}
.lrange{display:flex;justify-content:space-between;font-size:11px;color:var(--fg3)}
.leverfoot{display:flex;justify-content:space-between;align-items:center;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-soft);flex-wrap:wrap;gap:12px}
.outcome{font-size:14px;color:var(--fg1);max-width:62ch}
.outcome b{font-weight:600}

/* breakdown */
.two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.acct{display:flex;align-items:center;gap:12px;padding:9px 0;border-bottom:1px solid var(--border-soft)}
.acct:last-child{border-bottom:none}
.acct .who{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.acct .nm{flex:1;min-width:0}
.acct .nm .n1{font-size:13.5px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.acct .nm .n2{font-size:11px;color:var(--fg3)}
.acct .v{font-family:var(--mono);font-size:13.5px;font-weight:500;text-align:right;white-space:nowrap}
.bar{height:6px;border-radius:var(--r-full);background:var(--sunken);overflow:hidden;margin-top:3px}
.bar>div{height:100%;background:var(--sage);opacity:.55}
.subtotal{display:flex;justify-content:space-between;margin-top:12px;padding-top:12px;border-top:1px solid var(--border);font-weight:600;font-size:14px}
.note{font-size:12.5px;color:var(--fg2);background:var(--sage-tint);border-radius:var(--r-sm);padding:10px 12px;margin-top:14px;display:flex;gap:8px}
.note .material-symbols-rounded{font-size:17px;color:var(--sage);margin-top:1px;flex-shrink:0}
.conc{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
.concbox{background:var(--bg);border:1px solid var(--border-soft);border-radius:var(--r-md);padding:14px}
.concbox .big{font-size:26px;font-weight:700;color:var(--amber);letter-spacing:-.02em}
.concbox .cl{font-size:12px;color:var(--fg2);margin-top:2px}

/* pension */
.pengrid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:4px}
.penscn{background:var(--bg);border:1px solid var(--border-soft);border-radius:var(--r-md);padding:14px;cursor:pointer;transition:border .15s}
.penscn:hover{border-color:var(--sage)}
.penscn.active{border-color:var(--sage);background:var(--sage-tint)}
.penscn .pt{font-size:12px;color:var(--fg2);font-weight:500}
.penscn .pv{font-family:var(--mono);font-size:18px;font-weight:500;margin-top:4px}
.penscn .pd{font-size:11px;color:var(--fg3);margin-top:2px}
.kv{display:grid;grid-template-columns:1fr auto;gap:6px 16px;margin-top:6px;font-size:13px}
.kv .k{color:var(--fg2)}
.kv .vv{text-align:right;font-weight:500}

/* caveats */
.cav{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.cavcol h4{font-size:14px;margin-bottom:10px;display:flex;align-items:center;gap:7px}
.cavcol h4 .material-symbols-rounded{font-size:18px}
.cavcol.up h4{color:var(--success)}
.cavcol.down h4{color:var(--error)}
.cavlist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.cavlist li{font-size:13px;color:var(--fg2);line-height:1.5;padding-left:18px;position:relative}
.cavlist li::before{content:"";position:absolute;left:0;top:7px;width:6px;height:6px;border-radius:50%}
.cavcol.up .cavlist li::before{background:var(--success)}
.cavcol.down .cavlist li::before{background:var(--error)}
.cavlist li b{color:var(--fg1);font-weight:600}

.foot{margin-top:40px;padding-top:20px;border-top:1px solid var(--border);font-size:12px;color:var(--fg3);display:flex;flex-direction:column;gap:8px}
.footnote{scroll-margin-top:80px;padding:12px 14px;border-radius:var(--r-md);transition:background .5s;font-size:12.5px;color:var(--fg2);line-height:1.55;background:var(--surface);border:1px solid var(--border-soft)}
.footnote sup{color:var(--sage);font-weight:700;margin-right:2px}
.footnote b{color:var(--fg1)}
.footnote:target{background:var(--sage-tint);border-color:var(--sage-tint2)}
.vibed{display:flex;align-items:center;gap:6px;margin-top:4px;color:var(--fg3);font-size:12px}
.vibed .material-symbols-rounded{font-size:15px;color:var(--sage)}
.masked{letter-spacing:.05em}

/* ---------- responsive ---------- */
@media(max-width:940px){
  .nav{position:absolute;top:56px;left:0;right:0;flex-direction:column;align-items:stretch;gap:2px;margin:0;padding:8px;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--sh2);display:none;z-index:25}
  .nav.open{display:flex}
  .nav a{padding:13px 14px;font-size:15px}
  .navtoggle{display:inline-flex}
}
@media(max-width:780px){.hero{grid-template-columns:1fr}.two{grid-template-columns:1fr}.cav{grid-template-columns:1fr;gap:20px}}
@media(max-width:680px){.levers{grid-template-columns:1fr}.pengrid{grid-template-columns:1fr}}
@media(max-width:560px){
  .toolbtn .tlbl{display:none}
  .toolbtn{padding:7px 9px}
  .wrap{padding:20px 14px 70px}
  .card{padding:18px}
  .statusbig{font-size:28px}
  .conc{grid-template-columns:1fr}
}
@media(max-width:380px){.tiles{grid-template-columns:1fr}}
