*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --ink:#1b1a17;--ink-soft:#494842;--ink-muted:#83837c;
  --paper:#faf6ee;--card:#fff;--sidebar:#fcfaf3;
  --accent:#2d5a3d;--accent-deep:#234a31;--accent-light:#e4f0e8;--accent-tint:#eff5f1;
  --gold:#e8a93c;--gold-deep:#d2922a;--gold-soft:#fbeecf;--on-gold:#3a2d0a;
  --cta:#11857a;--cta-deep:#0c6f66;--cta-tint:#e3f1ef;--cta-line:#bfe0db;
  --pos:#1aa89a;
  --rule:#e7e2d6;--rule-soft:#f0ece3;--over:#c2410c;--over-light:#fbeadb;
  --serif:'Noto Serif',Georgia,serif;--sans:'Noto Sans',system-ui,sans-serif;
  --shadow:0 1px 3px rgba(26,26,24,.05);
  --shadow-md:0 4px 16px rgba(26,26,24,.08);
  --shadow-lg:0 18px 48px rgba(26,26,24,.16);
  --ease-calm:cubic-bezier(.32,.72,0,1);
  --ease-soft:cubic-bezier(.22,.61,.36,1);
}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-weight:300;line-height:1.6;-webkit-font-smoothing:antialiased;}
button{cursor:pointer;color:inherit;font-family:inherit;}
select,input{font-family:inherit;}
em{font-style:italic;color:var(--accent);}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;letter-spacing:-.01em;line-height:1.15;}
.icon{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;}
.layout{display:flex;min-height:100vh;}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}
.cat-pick:focus-visible,.dr-sel:focus-visible,.mini:focus-visible,.goal-input:focus-visible,.field input:focus-visible,.field select:focus-visible,.wl-form input:focus-visible,.opt-in-fields input:focus-visible,.pro-restore input:focus-visible,.tx-search input:focus-visible{outline:none;}
/* sidebar */
.sidebar{width:236px;flex-shrink:0;background:var(--sidebar);border-right:1px solid var(--rule);display:flex;flex-direction:column;padding:1.1rem .85rem 1rem;position:sticky;top:0;height:100vh;transition:width .26s ease,padding .26s ease;}
.sb-brand{display:flex;align-items:center;gap:11px;padding:.4rem .6rem 1.3rem;}
.sb-mark{width:30px;height:30px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;}
.sb-mark span{font-family:var(--serif);font-style:italic;font-size:16px;color:#fff;}
.sb-words b{font-size:15px;font-weight:500;line-height:1;display:block;}
.sb-words small{font-size:10px;font-weight:300;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted);line-height:1;margin-top:1px;display:block;}
.sb-nav{display:flex;flex-direction:column;gap:2px;}
.sb-item{display:flex;align-items:center;gap:11px;width:100%;padding:9px 11px;border:none;background:none;border-radius:10px;font-size:14px;color:var(--ink-soft);text-align:left;}
.sb-item:hover{background:var(--accent-tint);color:var(--ink);}
.sb-item.active{background:var(--accent-light);color:var(--accent);font-weight:500;}
.sb-item.locked{opacity:.5;cursor:not-allowed;}
.sb-item.locked:hover{background:none;color:var(--ink-soft);}
.sb-item .icon{width:19px;height:19px;}
.sb-label{flex:1;}
.sb-pro{font-size:9px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:#fff;border:1px solid #d2e2d7;padding:1px 6px;border-radius:100px;}
.sb-soon{font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-muted);background:var(--rule-soft);padding:2px 8px;border-radius:100px;};}
.sb-ct{font-size:11px;font-weight:600;color:#fff;background:var(--over);border-radius:100px;padding:0 7px;}
.sb-spacer{flex:1;}
.sb-foot{background:var(--accent-tint);border:1px solid #d6e4da;border-radius:11px;padding:1rem;color:var(--ink);}
.sb-foot-row{display:flex;align-items:center;gap:9px;margin-bottom:.7rem;}
.sb-avatar{width:34px;height:34px;border-radius:50%;background:#cfe2d5;color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;flex-shrink:0;overflow:hidden;}
.sb-avatar img{width:100%;height:100%;object-fit:cover;}
.sb-foot-row b{font-size:13px;font-weight:500;line-height:1.2;display:block;}
.sb-foot-row small{font-size:11px;color:var(--ink-muted);}
.sb-foot p{font-size:12px;color:var(--ink-soft);line-height:1.45;margin-bottom:.8rem;}
.sb-cta{display:block;text-align:center;background:var(--cta);color:#fff;border:none;border-radius:8px;padding:9px;font-size:13px;font-weight:600;width:100%;text-decoration:none;}
.sb-cta:hover{background:var(--cta-deep);}
.sb-cta-sec{display:block;text-align:center;margin-top:7px;font-size:11.5px;font-weight:500;color:var(--ink-muted);text-decoration:none;}
.sb-cta-sec:hover{color:var(--accent);}
/* main */
.main{flex:1;min-width:0;display:flex;flex-direction:column;}
.topbar{position:sticky;top:0;z-index:20;background:rgba(250,246,238,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--rule);padding:.55rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.daterange{display:inline-flex;align-items:flex-end;gap:5px;flex-wrap:nowrap;background:var(--card);border:1px solid var(--rule);border-radius:7px;padding:4px 7px;box-shadow:var(--shadow);flex-shrink:0;}
.dr-field{display:flex;flex-direction:column;gap:2px;}
.dr-lab{font-size:8px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-muted);}
.dr-sel{border:1px solid var(--rule);background:var(--paper);border-radius:5px;padding:3px 5px;font-size:10px;font-weight:500;color:var(--ink);min-width:80px;}
.dr-sel:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-tint);}
.dr-arrow{color:var(--ink-muted);font-size:11px;padding-bottom:3px;}
.dr-presets{display:flex;gap:6px;margin-left:auto;flex-wrap:wrap;align-self:flex-end;}
.dr-presets button{border:1px solid var(--rule);background:var(--card);border-radius:100px;padding:6px 12px;font-size:12px;font-weight:500;color:var(--ink-soft);}
.dr-presets button:hover{background:var(--accent-tint);color:var(--accent);}
@media(max-width:600px){.dr-presets{margin-left:0;width:100%;}}
.bud-metrics{margin-bottom:1.1rem;}
.metrics.bud-metrics{grid-template-columns:repeat(3,1fr);}
@media(max-width:860px){.metrics.bud-metrics{grid-template-columns:1fr;}}
.rep-metrics{margin-bottom:1.4rem;}
.exp-report{display:flex;flex-direction:column;}
.exp-filters{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:1.2rem;}
.exp-fl{display:flex;flex-direction:column;gap:5px;}
.exp-fl .dr-lab{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-muted);}
.exp-fl .dr-sel{min-width:150px;}
.cal-field{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--rule);background:var(--card);border-radius:8px;padding:9px 13px;font-size:13.5px;font-weight:500;color:var(--ink);cursor:pointer;min-width:150px;box-shadow:var(--shadow);transition:border-color .12s;}
.cal-field:hover{border-color:var(--accent);}
.cal-field .icon{width:15px;height:15px;stroke:var(--accent);flex-shrink:0;}
.exp-fl{position:relative;}
.daycal{position:absolute;top:calc(100% + 6px);left:0;z-index:45;background:var(--card);border:1px solid var(--rule);border-radius:14px;box-shadow:0 12px 32px rgba(26,26,24,.18);padding:14px;width:266px;animation:periodpop .18s ease;}
.daycal-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.daycal-mon{font-size:13.5px;font-weight:600;color:var(--ink);}
.daycal-nav{width:30px;height:30px;border:1px solid var(--rule);background:var(--card);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);}
.daycal-nav:hover:not(:disabled){border-color:var(--accent);color:var(--accent);}
.daycal-nav:disabled{opacity:.35;}
.daycal-nav .icon{width:15px;height:15px;}
.daycal-dows{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px;}
.daycal-dows span{text-align:center;font-size:10px;font-weight:600;color:var(--ink-muted);}
.daycal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;}
.daycal-day{height:32px;border:none;background:none;border-radius:8px;font-size:12.5px;color:var(--ink);cursor:pointer;}
.daycal-day:hover:not(:disabled){background:var(--accent-tint);color:var(--accent);}
.daycal-day.sel{background:var(--accent);color:#fff;font-weight:600;}
.daycal-day:disabled{color:var(--rule);cursor:default;}
.daycal-empty{height:32px;}
@media(max-width:680px){.exp-filters .exp-fl:nth-child(1) .daycal{left:0;right:auto;}.exp-filters .exp-fl:nth-child(2) .daycal{left:auto;right:0;}}
.exp-fl-cat{flex:1;min-width:180px;}
.exp-fl-cat .dr-sel{width:100%;}
.exp-sumcard{margin-bottom:1.2rem;}
.exp-sum{display:flex;gap:2.4rem;flex-wrap:wrap;padding-bottom:1.1rem;border-bottom:1px solid var(--rule-soft);margin-bottom:1.1rem;}
.exp-sum-lab{font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-muted);}
.exp-sum-val{font-family:var(--serif);font-size:1.6rem;line-height:1.1;font-variant-numeric:tabular-nums;margin-top:2px;}
.exp-sum-sub{font-size:1rem;font-weight:500;margin-top:8px;color:var(--ink-soft);}
.exp-catbars{display:flex;flex-direction:column;gap:11px;}
.exp-catbar-top{display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:13px;margin-bottom:4px;}
.exp-catbar-nm{display:inline-flex;align-items:center;gap:8px;color:var(--ink);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.exp-catbar-nm .ld{width:9px;height:9px;border-radius:3px;flex-shrink:0;}
.exp-catbar-amt{color:var(--ink-muted);font-variant-numeric:tabular-nums;white-space:nowrap;}
.exp-catbar-track{display:block;height:6px;border-radius:100px;background:var(--rule-soft);overflow:hidden;}
.exp-catbar-fill{display:block;height:100%;border-radius:100px;transition:width .3s ease;}
.exp-list{display:flex;flex-direction:column;}
.exp-row{display:grid;grid-template-columns:54px 1fr 150px 100px;gap:1rem;align-items:center;padding:11px 0;border-top:1px solid var(--rule-soft);}
.exp-row:first-child{border-top:none;}
.exp-row-date{font-size:12px;color:var(--ink-muted);white-space:nowrap;}
.exp-row-desc{font-size:13.5px;color:var(--ink);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.exp-row-desc small{display:block;font-size:11px;color:var(--ink-muted);}
.exp-row-cat{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--ink-soft);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.exp-row-cat .ld{width:8px;height:8px;border-radius:2px;flex-shrink:0;}
.exp-row-amt{text-align:right;font-size:14px;font-weight:500;font-variant-numeric:tabular-nums;color:var(--over);}
.inc-report .exp-row-amt{color:var(--accent);}
.inc-report .exp-total b{color:var(--accent);}
.exp-viewtoggle{display:inline-flex;gap:2px;background:var(--rule-soft);border-radius:100px;padding:3px;margin-bottom:1.2rem;}
.exp-viewtoggle button{display:inline-flex;align-items:center;gap:6px;border:none;background:none;padding:8px 18px;border-radius:100px;font-size:13px;font-weight:500;color:var(--ink-muted);}
.exp-viewtoggle button.on{background:var(--card);color:var(--accent);box-shadow:var(--shadow);}
.exp-viewtoggle button .icon{width:14px;height:14px;}
.expbars{display:flex;align-items:flex-end;gap:10px;padding-top:.5rem;overflow-x:auto;}
.expbar{flex:1;min-width:38px;display:flex;flex-direction:column;align-items:center;gap:6px;}
.expbar-track{display:flex;align-items:flex-end;justify-content:center;width:100%;height:150px;background:var(--rule-soft);border-radius:8px;overflow:hidden;}
.expbar-fill{display:block;width:100%;border-radius:8px 8px 0 0;min-height:2px;transition:height .35s cubic-bezier(.4,0,.2,1);}
.expbar-val{font-size:11px;font-weight:600;color:var(--ink-soft);font-variant-numeric:tabular-nums;white-space:nowrap;}
.expbar-lab{font-size:11px;color:var(--ink-muted);}
.bubbles-head{flex-wrap:wrap;gap:14px;align-items:flex-start;}
.bub-eyebrow{display:block;font-size:10.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:4px;}
.bub-toggle{display:inline-flex;gap:2px;background:var(--rule-soft);border-radius:100px;padding:3px;flex-shrink:0;}
.bub-toggle button{border:none;background:none;padding:7px 14px;border-radius:100px;font-size:12.5px;font-weight:500;color:var(--ink-muted);}
.bub-toggle button.on{background:var(--card);color:var(--accent);box-shadow:var(--shadow);}
.bubbles-stage{margin-top:1rem;width:100%;height:400px;border-radius:12px;background:linear-gradient(180deg,var(--paper),var(--card));overflow:hidden;touch-action:none;cursor:grab;}
.bubbles-stage:active{cursor:grabbing;}
.bubbles-stage canvas{display:block;}
.bub-legend{display:flex;gap:1.1rem;flex-wrap:wrap;margin-top:.9rem;}
.bub-legend span{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-soft);}
.bub-legend i{width:11px;height:11px;border-radius:50%;display:inline-block;}
.cmp-wrap{display:flex;gap:24px;align-items:center;flex-wrap:wrap;justify-content:center;}
.cmp-svg{width:300px;max-width:100%;flex-shrink:0;}
.cmp-side{flex:1;min-width:200px;}
.cmp-sum{background:var(--accent-tint);border-radius:14px;padding:14px 16px;margin-bottom:12px;display:flex;flex-direction:column;}
.cmp-sum-lab{font-size:12px;color:var(--ink-muted);}
.cmp-sum-val{font-family:var(--serif);font-size:1.7rem;color:var(--accent);line-height:1.1;margin-top:2px;font-variant-numeric:tabular-nums;}
.cmp-sum-sub{font-size:12px;color:var(--ink-soft);margin-top:4px;line-height:1.4;}
.cmp-legend{display:flex;flex-direction:column;gap:1px;}
.cmp-leg{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:9px;border:none;background:none;cursor:pointer;width:100%;text-align:left;transition:background .12s;}
.cmp-leg:hover{background:var(--rule-soft);}
.cmp-leg.on{background:var(--accent-tint);}
.cmp-box{width:16px;height:16px;border-radius:5px;border:2px solid;flex-shrink:0;transition:background .15s;}
.cmp-nm{font-size:13px;font-weight:500;color:var(--ink);}
.cmp-amt{margin-left:auto;font-size:12.5px;color:var(--ink-muted);font-variant-numeric:tabular-nums;}
.cmp-clear{margin-top:10px;background:none;border:none;color:var(--accent);font-size:12.5px;font-weight:600;cursor:pointer;padding:4px 2px;}
.cmp-clear:hover{text-decoration:underline;}
.bva-controls{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap;margin-bottom:1rem;}
.bva-seg{display:inline-flex;gap:2px;background:var(--rule-soft);border-radius:100px;padding:3px;}
.bva-seg button{border:none;background:none;padding:8px 18px;border-radius:100px;font-size:13px;font-weight:500;color:var(--ink-muted);cursor:pointer;}
.bva-seg button.on{background:var(--card);color:var(--accent);box-shadow:var(--shadow);}
.bva-catwrap{display:flex;flex-direction:column;gap:4px;}
.bva-sum{display:flex;gap:2.2rem;flex-wrap:wrap;padding-bottom:1.1rem;border-bottom:1px solid var(--rule-soft);}
.bva-sumcard .net-note{font-size:13px;color:var(--ink-soft);margin:1rem 0 0;line-height:1.5;}
.bva-chart{position:relative;margin-top:.4rem;}
.bva-chart svg{width:100%;height:auto;display:block;}
.bva-planline{stroke:var(--ink-muted);stroke-width:1.4;stroke-dasharray:4 4;opacity:.55;}
.bva-tip{position:absolute;top:0;transform:translateX(-50%);background:var(--ink);color:#fff;border-radius:10px;padding:9px 12px;min-width:160px;box-shadow:0 8px 24px rgba(26,26,24,.22);pointer-events:none;z-index:5;}
.bva-tip-m{font-weight:600;font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:#9eccae;margin-bottom:6px;}
.bva-tip-r{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:2px 0;font-size:12.5px;}
.bva-tip-r span{display:inline-flex;align-items:center;gap:7px;color:#d6e6db;}
.bva-tip-r i{width:8px;height:8px;border-radius:2px;display:inline-block;}
.bva-tip-r b{font-variant-numeric:tabular-nums;font-weight:600;color:#fff;}
.bva-tip-r.net{border-top:1px solid rgba(255,255,255,.16);margin-top:4px;padding-top:6px;}
.bva-legend{display:flex;gap:1.3rem;flex-wrap:wrap;margin-top:.9rem;}
.bva-legend span{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--ink-soft);}
.bva-legend i{width:11px;height:11px;border-radius:3px;display:inline-block;}
.bva-listhead{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.bva-grp{display:inline-flex;gap:2px;background:var(--rule-soft);border-radius:100px;padding:3px;flex-shrink:0;}
.bva-grp button{border:none;background:none;padding:6px 13px;border-radius:100px;font-size:12px;font-weight:500;color:var(--ink-muted);cursor:pointer;}
.bva-grp button.on{background:var(--card);color:var(--accent);box-shadow:var(--shadow);}
.bva-list{margin-top:1rem;}
.bva-lrow{display:grid;grid-template-columns:1.5fr .9fr .9fr 1fr 1.3fr;align-items:center;gap:.6rem 1rem;padding:.62rem 0;border-bottom:1px solid var(--rule-soft);}
.bva-lrow.head{padding:0 0 .55rem;border-bottom:1px solid var(--rule);}
.bva-lrow.head span{font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-muted);font-weight:600;}
.bva-lrow.head span:not(:first-child):not(.bva-lbarcol){text-align:right;}
.bva-lname{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:500;color:var(--ink);}
.bva-lname .ld{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
.bva-lnum{text-align:right;font-size:13px;font-variant-numeric:tabular-nums;color:var(--ink-soft);}
.bva-lvar{font-weight:600;}
.bva-lvar.bad{color:var(--over);}
.bva-lvar.good{color:var(--accent);}
.bva-lbar{height:8px;border-radius:100px;background:var(--rule-soft);overflow:hidden;}
.bva-lbar i{display:block;height:100%;border-radius:100px;transition:width .3s;}
.bva-lrow.tot{border-bottom:none;border-top:2px solid var(--rule);margin-top:.2rem;padding-top:.7rem;}
.bva-lrow.tot>span:first-child{font-weight:600;color:var(--ink);font-size:13px;}
.bva-lrow.tot .bva-lnum{color:var(--ink);font-weight:600;}
@media(max-width:560px){
  .bva-lrow{grid-template-columns:1.3fr .8fr .8fr .9fr;}
  .bva-lbar,.bva-lbarcol{display:none;}
}
.pnl-card{overflow:hidden;}
.pnl-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-top:1rem;border:1px solid var(--rule-soft);border-radius:12px;}
.pnl-table{border-collapse:collapse;width:max-content;min-width:100%;font-size:12.5px;}
.pnl-table th,.pnl-table td{padding:8px 12px;white-space:nowrap;text-align:right;}
.pnl-rowhead{position:sticky;left:0;z-index:2;background:var(--card);text-align:left;font-weight:500;color:var(--ink);box-shadow:1px 0 0 var(--rule-soft);}
.pnl-catname{display:flex;align-items:center;gap:8px;font-weight:400;color:var(--ink-soft);}
.pnl-catname .ld{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
.pnl-mhead{text-align:center;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-muted);font-weight:600;border-bottom:1px solid var(--rule);background:var(--paper);}
.pnl-sub{font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-muted);font-weight:600;background:var(--paper);border-bottom:1px solid var(--rule);}
.pnl-num{font-variant-numeric:tabular-nums;color:var(--ink);}
.pnl-plan{color:var(--ink-muted);}
.pnl-over{color:var(--over);font-weight:600;}
.pnl-good{color:var(--accent);font-weight:600;}
.pnl-grand{background:var(--accent-tint);}
.pnl-section td{text-align:left;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:700;background:var(--paper);padding-top:11px;padding-bottom:6px;}
.pnl-section .pnl-rowhead{background:var(--paper);}
.pnl-subtot th,.pnl-subtot td{font-weight:600;color:var(--ink);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);}
.pnl-subtot .pnl-rowhead{font-weight:600;}
.pnl-net th,.pnl-net td{font-weight:700;color:var(--ink);border-top:2px solid var(--ink);padding-top:10px;padding-bottom:10px;}
.pnl-net .pnl-rowhead{font-weight:700;}
.pnl-table tbody tr:not(.pnl-section):not(.pnl-subtot):not(.pnl-net):hover td,.pnl-table tbody tr:not(.pnl-section):not(.pnl-subtot):not(.pnl-net):hover th{background:var(--rule-soft);}
.pnl-hint{font-size:11.5px;color:var(--ink-muted);margin:.7rem 0 0;text-align:right;}
@media(min-width:900px){.pnl-hint{display:none;}}
.net-sum{display:flex;gap:2.2rem;flex-wrap:wrap;padding-bottom:1.1rem;border-bottom:1px solid var(--rule-soft);}
.net-sumcard .net-note{font-size:13px;color:var(--ink-soft);margin:1rem 0 0;line-height:1.5;}
.netbars{padding-top:.5rem;overflow-x:auto;}
.netbars-row{display:flex;align-items:stretch;gap:10px;min-width:min-content;}
.netbar{flex:1;min-width:42px;display:flex;flex-direction:column;align-items:center;gap:6px;}
.netbar-area{width:100%;height:170px;display:flex;flex-direction:column;}
.netbar-half{flex:1;display:flex;}
.netbar-half.top{align-items:flex-end;}
.netbar-half.bot{align-items:flex-start;}
.netbar-zero{height:1px;background:var(--rule);}
.netbar-fill{width:100%;display:block;}
.netbar-fill.pos{background:var(--accent);border-radius:6px 6px 0 0;}
.netbar-fill.neg{background:var(--over);border-radius:0 0 6px 6px;}
.netbar-val{font-size:10.5px;font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap;}
.netbar-val.pos{color:var(--accent);}.netbar-val.neg{color:var(--over);}
.netbar-lab{font-size:11px;color:var(--ink-muted);}
.exp-total{display:flex;align-items:center;justify-content:space-between;margin-top:.6rem;padding-top:1rem;border-top:2px solid var(--rule);}
.exp-total span{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-muted);}
.exp-total b{font-family:var(--serif);font-size:1.5rem;font-variant-numeric:tabular-nums;color:var(--over);}
@media(max-width:680px){
  .exp-row{grid-template-columns:1fr auto;grid-template-areas:'desc amt' 'cat date';gap:.3rem .8rem;}
  .exp-row-date{grid-area:date;}
  .exp-row-desc{grid-area:desc;}
  .exp-row-cat{grid-area:cat;}
  .exp-row-amt{grid-area:amt;}
  .exp-fl{flex:1;}
  .exp-fl .dr-sel{min-width:0;width:100%;}
}
.bud-subbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:1.1rem;flex-wrap:wrap;}
.tb-cal{position:relative;display:flex;}
.cal-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--rule);background:var(--card);border-radius:10px;box-shadow:var(--shadow);transition:border-color .12s,background .12s;}
.cal-icon-btn:hover{border-color:var(--accent);background:var(--accent-tint);}
.tb-right{display:flex;align-items:center;gap:10px;}
.cal-icon-btn .icon{width:18px;height:18px;stroke:var(--accent);}
.period-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:1.2rem;position:relative;}
.period-bar .page-h{font-family:var(--serif);font-size:1.5rem;font-weight:400;color:var(--ink);margin:0;}
.period-btn{display:inline-flex;align-items:center;gap:9px;background:var(--card);border:1px solid var(--rule);border-radius:100px;padding:9px 14px;font-size:13.5px;font-weight:600;color:var(--ink);box-shadow:var(--shadow);transition:border-color .12s,background .12s;}
.period-btn:hover{border-color:var(--accent);background:var(--accent-tint);}
.period-btn>.icon:first-child{width:16px;height:16px;stroke:var(--accent);}
.period-btn>.icon:last-child{width:13px;height:13px;stroke:var(--ink-muted);}
.period-btn-txt{letter-spacing:.01em;}
.period-ov{position:fixed;inset:0;z-index:40;}
.period-pop{position:absolute;top:calc(100% + 8px);right:0;left:auto;z-index:45;background:var(--card);border:1px solid var(--rule);border-radius:14px;box-shadow:0 12px 32px rgba(26,26,24,.18);padding:16px;width:248px;animation:periodpop .16s ease both;}
@keyframes periodpop{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:none;}}
.period-pop-hd{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:12px;}
.period-pop-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;}
.period-pop-row .dr-lab{font-size:12px;font-weight:600;letter-spacing:.02em;text-transform:none;color:var(--ink-soft);}
.period-pop-row .dr-sel{flex:1;max-width:150px;min-width:0;}
.period-pop-done{width:100%;margin-top:6px;background:var(--accent);color:#fff;border:none;border-radius:9px;padding:11px;font-size:13.5px;font-weight:600;}
.period-pop-done:hover{background:#244d33;}
.backup-pop{width:248px;}
.backup-pop-sub{font-size:12.5px;color:var(--ink-soft);line-height:1.5;margin:-4px 0 12px;}
.backup-pop-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--rule);background:var(--card);color:var(--ink);border-radius:9px;padding:11px;font-size:13.5px;font-weight:500;margin-bottom:8px;cursor:pointer;}
.backup-pop-btn:last-of-type{margin-bottom:0;}
.backup-pop-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-tint);}
.backup-pop-btn.primary{background:var(--cta);color:#fff;border-color:var(--cta);}
.backup-pop-btn.primary:hover{background:var(--cta-deep);color:#fff;}
.backup-pop-btn.primary:disabled{opacity:.45;}
.backup-pop-btn .icon{width:16px;height:16px;}
.backup-pop-btn.primary .icon{stroke:#fff;}
.backup-pop-msg{font-size:12.5px;margin:10px 0 0;display:flex;align-items:center;gap:6px;line-height:1.4;}
.backup-pop-msg .icon{width:14px;height:14px;}
.backup-pop-msg.ok{color:var(--accent);}.backup-pop-msg.ok .icon{stroke:var(--accent);}
.backup-pop-msg.err{color:var(--over);}
.bud-note{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-muted);margin:0;flex-wrap:wrap;flex:1;min-width:240px;}
.bud-note .icon{width:14px;height:14px;stroke:var(--accent);flex-shrink:0;}
.catfilter{display:flex;align-items:center;gap:9px;background:var(--accent-light);border:1px solid #d2e2d7;border-radius:100px;padding:7px 8px 7px 14px;margin-bottom:1rem;font-size:13px;color:var(--accent);width:fit-content;}
.catfilter .ld{width:9px;height:9px;border-radius:3px;}
.catfilter b{font-weight:600;}
.catfilter button{margin-left:4px;display:inline-flex;align-items:center;gap:5px;background:#fff;border:1px solid #d2e2d7;color:var(--accent);border-radius:100px;padding:4px 11px;font-size:12px;font-weight:500;}
.catfilter button:hover{background:var(--accent);color:#fff;}
.catfilter button .icon{width:12px;height:12px;}

.tb-title{font-family:var(--serif);font-size:1.2rem;}
.login-pill{display:inline-flex;align-items:center;gap:5px;white-space:nowrap;background:var(--card);border:1px solid var(--rule);border-radius:7px;padding:4px 9px;font-size:11px;font-weight:500;color:var(--ink-soft);transition:border-color .12s ease,color .12s ease;}ransition:border-color .12s ease,color .12s ease;}
.login-pill:hover{border-color:var(--accent);color:var(--accent);}
.login-pill .icon{width:12px;height:12px;}
.sb-toggle{position:absolute;top:50%;transform:translateY(-50%);right:-12px;width:24px;height:24px;border:1px solid var(--rule);background:var(--card);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink-muted);z-index:25;box-shadow:0 1px 3px rgba(26,26,24,.1);transition:background .12s ease,color .12s ease,border-color .12s ease;}
.sb-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-tint);}
.sb-toggle .icon{width:13px;height:13px;}
.layout.nav-collapsed .sidebar{width:74px;padding-left:.55rem;padding-right:.55rem;}
.layout.nav-collapsed .sb-brand{justify-content:center;padding:.4rem 0 1rem;}
.layout.nav-collapsed .sb-words,.layout.nav-collapsed .sb-label,.layout.nav-collapsed .sb-pro,.layout.nav-collapsed .sb-soon,.layout.nav-collapsed .sb-ct,.layout.nav-collapsed .sb-foot{display:none;}
.layout.nav-collapsed .sb-brand{justify-content:center;padding:.4rem 0 1rem;}
.layout.nav-collapsed .sb-item{justify-content:center;padding:11px 0;gap:0;}
.tb-left{display:flex;align-items:center;gap:14px;min-width:0;}
.month-pick{display:inline-flex;align-items:center;gap:1px;background:var(--card);border:1px solid var(--rule);border-radius:8px;padding:2px;}
.month-pick button{width:24px;height:24px;border:none;background:none;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);}
.month-pick button:hover:not(:disabled){background:var(--accent-tint);color:var(--accent);}
.month-pick button:disabled{opacity:.35;cursor:not-allowed;}
.month-pick span{font-size:12px;font-weight:500;padding:0 6px;min-width:88px;text-align:center;}
.page-monthbar{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-bottom:1.1rem;}
.tb-right{display:flex;align-items:center;gap:10px;}
.tb-monthsel{margin-bottom:0;align-items:center;padding:3px 6px 3px 9px;}
.tb-monthsel .dr-field{flex-direction:row;align-items:center;gap:6px;}
.tb-monthsel .dr-lab{font-size:8.5px;}
.tb-monthsel .dr-sel{min-width:84px;}
.content{padding:1.4rem 1.6rem 3rem;max-width:1180px;width:100%;animation:viewfade .3s ease both;}
@keyframes viewfade{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}
.dash-hero{background:var(--card);border:1px solid var(--rule);border-radius:10px;box-shadow:var(--shadow);padding:1.3rem 1.5rem;margin-bottom:1.2rem;display:flex;flex-direction:column;gap:.5rem;}
.quick-actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:1.1rem;}
.qa-btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--rule);background:var(--card);color:var(--ink);border-radius:8px;padding:9px 15px;font-size:13px;font-weight:500;box-shadow:var(--shadow);transition:border-color .12s,color .12s,background .12s;}
.qa-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-tint);}
.qa-btn .icon{width:15px;height:15px;}
.qa-btn.primary{background:var(--accent);color:#fff;border-color:var(--accent);}
.qa-btn.primary:hover{background:#244d33;color:#fff;}
.qa-btn.primary .icon{stroke:#fff;}
.dh-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1.2rem;flex-wrap:wrap;}
.dh-top .dh-main{flex:1 1 60%;min-width:0;}
.dh-ai-corner{margin-bottom:0;flex-shrink:0;align-self:flex-start;display:flex;justify-content:flex-end;}
.dh-aside-foot{flex-direction:row;align-items:center;justify-content:flex-end;gap:14px;margin-top:.3rem;}
.dh-label{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);}
.dh-label .icon{width:14px;height:14px;stroke:var(--ink-muted);}
.dh-monthsel{position:relative;display:inline-flex;align-items:center;}
.dh-monthsel select{-webkit-appearance:none;appearance:none;background:none;border:none;font:inherit;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);cursor:pointer;padding:1px 16px 1px 4px;border-radius:5px;}
.dh-monthsel select:hover{background:var(--accent-tint);}
.dh-monthsel select:focus-visible{outline:2px solid var(--accent);outline-offset:1px;}
.dh-monthsel .icon{position:absolute;right:1px;width:12px;height:12px;stroke:var(--accent);pointer-events:none;}
.dh-val{font-family:var(--serif);font-size:2.7rem;line-height:1;margin:0;color:var(--accent);font-variant-numeric:tabular-nums;}
.dh-val-row{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin:8px 0 9px;}
.dh-val.neg{color:var(--over);}
.dh-sentence{font-size:14px;color:var(--ink-soft);max-width:52ch;line-height:1.5;}
.dh-review{display:inline-flex;align-items:center;gap:7px;background:var(--over-light);border:1px solid #f0d9b8;color:var(--over);border-radius:100px;padding:8px 14px;font-size:13px;font-weight:500;white-space:nowrap;transition:background .12s ease;}
.dh-review:hover{background:#f7e7cf;}
.dh-review .icon{width:15px;height:15px;}
.dh-main{min-width:0;}
.dh-aside{display:flex;flex-direction:column;align-items:flex-end;gap:12px;flex-shrink:0;}
.dh-aside .budstat-delta{font-size:13px;}
.dh-kept{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1;}
.dh-kept b{font-family:var(--serif);font-size:1.5rem;color:var(--ink);}
.dh-kept small{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-muted);margin-top:2px;}
.month-empty{text-align:center;padding:2.4rem 1.5rem;margin-bottom:1.2rem;display:flex;flex-direction:column;align-items:center;gap:.45rem;}
.me-ic{width:48px;height:48px;border-radius:50%;background:var(--rule-soft);display:flex;align-items:center;justify-content:center;color:var(--ink-muted);margin-bottom:.3rem;}
.me-ic .icon{width:22px;height:22px;}
.month-empty h3{font-size:1.15rem;}
.month-empty p{font-size:13.5px;color:var(--ink-soft);max-width:46ch;line-height:1.5;}
.me-actions{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center;margin-top:.8rem;}
.me-btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--rule);background:var(--card);color:var(--ink);border-radius:8px;padding:9px 16px;font-size:13px;font-weight:500;}
.me-btn:hover{border-color:var(--accent);color:var(--accent);}
.me-btn.primary{background:var(--accent);color:#fff;border-color:var(--accent);}
.me-btn.primary:hover{background:#244d33;color:#fff;}
.me-btn.primary:hover .icon{stroke:#fff;}
.me-btn .icon{width:15px;height:15px;}
.dash-metrics{margin-bottom:1.2rem;}
.dash-cards{margin-bottom:1.2rem;}
.metrics.dash-cards{grid-template-columns:repeat(3,1fr);}
@media(max-width:880px){.metrics.dash-cards{grid-template-columns:1fr;}}
/* needs attention */
.attn-card{padding:0;margin-bottom:1.2rem;overflow:hidden;}
.attn-head{display:flex;align-items:center;gap:9px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);padding:14px 18px;border-bottom:1px solid var(--rule-soft);}
.attn-dot{width:8px;height:8px;border-radius:50%;background:var(--over);}
.attn-ct{display:inline-flex;align-items:center;justify-content:center;min-width:19px;height:19px;padding:0 5px;border-radius:100px;background:var(--accent-light);color:var(--accent);font-size:11px;font-weight:700;letter-spacing:0;}
.attn-list{display:flex;flex-direction:column;}
.attn-row{display:flex;align-items:center;gap:14px;padding:15px 18px;border-bottom:1px solid var(--rule-soft);}
.attn-row:last-child{border-bottom:none;}
.attn-ic{flex-shrink:0;width:38px;height:38px;border-radius:9px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;}
.attn-ic .icon{width:18px;height:18px;stroke:var(--accent);}
.attn-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px;}
.attn-body b{font-size:14.5px;font-weight:600;color:var(--ink);line-height:1.3;}
.attn-body span{font-size:13px;color:var(--ink-soft);line-height:1.4;}
.attn-cta{flex-shrink:0;display:inline-flex;align-items:center;gap:6px;border:none;background:none;border-radius:8px;padding:8px 4px;font-size:13px;font-weight:600;color:var(--accent);transition:color .12s,background .12s;white-space:nowrap;}
.attn-cta:hover{color:#244d33;}
.attn-cta-arr{font-weight:400;transition:transform .15s;}
.attn-cta:hover .attn-cta-arr{transform:translateX(2px);}
.attn-cta-review{background:var(--over-light);color:var(--over);padding:9px 15px;}
.attn-cta-review:hover{background:#f7e7cf;color:var(--over);}
.attn-cta-review .icon{width:15px;height:15px;}
.attn-cta-primary{background:var(--cta);color:#fff;padding:9px 15px;}
.attn-cta-primary:hover{background:var(--cta-deep);color:#fff;}
.attn-cta-primary .icon{width:15px;height:15px;stroke:#fff;}
@media(max-width:560px){.attn-row{flex-wrap:wrap;}.attn-body{min-width:calc(100% - 44px);}.attn-cta{margin-left:41px;margin-top:2px;}}
.dh-ai{margin-top:.9rem;}
.dash-ai-bar{margin-bottom:1.2rem;}
.dh-ai-btn{display:inline-flex;align-items:center;gap:7px;background:var(--cta-tint);border:1px solid var(--cta-line);color:var(--cta);border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;transition:background .12s ease;}
.dh-ai-btn:hover{background:#d3eae6;}
.dh-ai-btn .icon{width:15px;height:15px;stroke:var(--cta);}
.dh-ai-btn.ghost{background:none;border-color:var(--rule);color:var(--ink-soft);}
.dh-ai-btn.ghost:hover{background:var(--accent-tint);border-color:var(--accent);color:var(--accent);}
.ed-note{margin-bottom:1.2rem;}
.card.ed-note{border-left:3px solid var(--accent);}
.ed-note-head{display:flex;align-items:center;gap:11px;margin-bottom:.7rem;}
.ed-note-av{width:38px;height:38px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--accent-light);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--accent);}
.ed-note-av img{width:100%;height:100%;object-fit:cover;}
.ed-note-by{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.2;}
.ed-note-by b{font-size:14px;color:var(--ink);}
.ed-note-by small{font-size:11.5px;color:var(--ink-muted);}
.ed-note-head>.icon{width:18px;height:18px;stroke:var(--accent);flex-shrink:0;}
.ed-note-body{font-size:14px;color:var(--ink-soft);line-height:1.6;margin:0;}
.ed-note-body.muted{color:var(--ink-muted);}
.ed-note-cta{display:inline-block;margin-top:.9rem;font-size:13px;font-weight:600;color:var(--accent);text-decoration:none;}
.ed-note-cta:hover{text-decoration:underline;}
.ed-modal{max-width:460px;}
.ed-ov{animation:edOvIn .18s ease both;}
.ed-ov .ed-modal{animation:edMdlIn .24s cubic-bezier(.2,.8,.2,1) both;}
.ed-ov.closing{animation:edOvOut .2s ease forwards;}
.ed-ov.closing .ed-modal{animation:edMdlOut .2s ease forwards;}
@keyframes edOvIn{from{opacity:0;}to{opacity:1;}}
@keyframes edOvOut{from{opacity:1;}to{opacity:0;}}
@keyframes edMdlIn{from{opacity:0;transform:translateY(14px) scale(.96);}to{opacity:1;transform:none;}}
@keyframes edMdlOut{from{opacity:1;transform:none;}to{opacity:0;transform:translateY(10px) scale(.98);}}
.ed-modal{transition:none;}
.ed-body{animation:edBodyFade .3s ease both;}
@keyframes edBodyFade{from{opacity:0;transform:translateY(4px);}to{opacity:1;transform:none;}}
.ed-typing{display:inline-flex;align-items:center;gap:4px;vertical-align:middle;margin-right:5px;}
.ed-typing i{width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.4;animation:edDot 1s infinite ease-in-out;}
.ed-typing i:nth-child(2){animation-delay:.18s;}
.ed-typing i:nth-child(3){animation-delay:.36s;}
@keyframes edDot{0%,60%,100%{opacity:.3;transform:translateY(0);}30%{opacity:1;transform:translateY(-3px);}}
.ed-modal .ed-note-head{margin-bottom:1rem;padding-right:1.5rem;}
.ed-modal .ed-note-body{font-size:14.5px;}
.dh-ai-loading{font-size:13px;color:var(--ink-muted);}
.dh-ai-text{font-size:13.5px;color:var(--ink-soft);line-height:1.55;max-width:64ch;background:var(--accent-tint);border:1px solid #e0ece4;border-radius:8px;padding:11px 13px;margin:0;}
.dh-ai-text a,.dh-ai-text .linklike{color:var(--accent);font-weight:500;text-decoration:underline;text-underline-offset:2px;}
.recur-list{display:flex;flex-direction:column;}
.recur-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:8px 0;border-top:1px solid var(--rule-soft);font-size:14px;}
.recur-row:first-child{border-top:none;}
.recur-nm{color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:8px;min-width:0;}
.recur-up{flex-shrink:0;display:inline-flex;align-items:center;background:var(--over-light);color:var(--over);font-size:10px;font-weight:600;letter-spacing:.05em;border-radius:100px;padding:2px 8px;}
.recur-foot{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--over);margin:.9rem 0 0;padding-top:.8rem;border-top:1px solid var(--rule-soft);}
.recur-foot .icon{width:14px;height:14px;stroke:var(--over);flex-shrink:0;}
.recur-hero{display:flex;align-items:baseline;gap:1.1rem;flex-wrap:wrap;margin-bottom:1.1rem;}
.recur-big{font-family:var(--serif);font-size:2.2rem;line-height:1;color:var(--ink);font-variant-numeric:tabular-nums;white-space:nowrap;}
.recur-big small{font-size:1rem;color:var(--ink-muted);font-family:var(--sans);margin-left:3px;}
.recur-ctx{flex:1;min-width:240px;font-size:13.5px;color:var(--ink-soft);line-height:1.5;}
.recur-ctx b{color:var(--ink);font-weight:600;}
.recur-split{margin-bottom:1.2rem;}
.recur-bar{height:10px;border-radius:100px;background:var(--rule-soft);overflow:hidden;display:flex;}
.recur-bar-fill{height:100%;background:var(--pos);border-radius:100px;}
.recur-bar-key{display:flex;align-items:center;gap:1.1rem;flex-wrap:wrap;margin-top:.6rem;font-size:12px;color:var(--ink-soft);}
.recur-bar-key span{display:inline-flex;align-items:center;gap:6px;}
.recur-bar-key i{width:9px;height:9px;border-radius:2px;display:inline-block;}
.recur-bar-key i.fx{background:var(--pos);}
.recur-bar-key i.vr{background:var(--rule-soft);border:1px solid var(--rule);}
.recur-bar-note{color:var(--ink-muted);margin-left:auto;}
.recur-amt{font-weight:500;font-variant-numeric:tabular-nums;white-space:nowrap;color:var(--ink);}
.ins-list{display:flex;flex-direction:column;gap:.8rem;}
.ins-row{display:flex;align-items:flex-start;gap:11px;font-size:13.5px;color:var(--ink-soft);line-height:1.45;}
.ins-txt{flex:1;min-width:0;}
.ins-link{flex-shrink:0;align-self:center;background:none;border:none;color:var(--accent);font-size:12.5px;font-weight:600;white-space:nowrap;padding:4px 2px;}
.ins-link:hover{text-decoration:underline;}
.ins-row b{color:var(--ink);font-weight:600;}
.ins-ic{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.ins-ic.ok{background:var(--accent-light);}
.ins-ic.ok .icon{width:16px;height:16px;stroke:var(--accent);}
.ins-ic.warn{background:var(--over-light);}
.ins-ic.warn .icon{width:16px;height:16px;stroke:var(--over);}
.taxq-list{display:flex;flex-direction:column;}
.taxq-row{display:grid;grid-template-columns:1fr auto auto;gap:.9rem;align-items:center;padding:9px 0;border-top:1px solid var(--rule-soft);font-size:13.5px;}
.taxq-row:first-child{border-top:none;}
.taxq-row.next{background:var(--accent-tint);border-top:none;border-radius:7px;margin:2px -.6rem;padding:9px .6rem;}
.taxq-q{color:var(--ink);}
.taxq-q small{color:var(--ink-muted);font-size:11px;}
.taxq-due{font-size:11.5px;color:var(--ink-muted);white-space:nowrap;}
.taxq-row.next .taxq-due{color:var(--accent);font-weight:600;}
.taxq-amt{font-weight:600;font-variant-numeric:tabular-nums;color:var(--ink);white-space:nowrap;}
.section-title{font-family:var(--serif);font-size:1.1rem;margin-bottom:.3rem;}
.section-sub{font-size:13px;color:var(--ink-muted);margin-bottom:1.3rem;}
.card{background:var(--card);border:1px solid var(--rule);border-radius:12px;padding:1.15rem 1.25rem;box-shadow:var(--shadow);transition:box-shadow .2s ease,transform .2s ease,border-color .2s ease;}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.9rem;gap:1rem;}
.card-head h3{font-size:1.05rem;}.card-head .ch-sub{font-size:12px;color:var(--ink-muted);}
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.2rem;}
.metric{background:var(--card);border:1px solid var(--rule);border-radius:12px;padding:.9rem 1rem;box-shadow:var(--shadow);transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease;}
.sb-item,.stab,.subtab,.cf-toggle button,.tx-sort button,.achip,.pill,.iconbtn{transition:background .12s ease,color .12s ease,border-color .12s ease;}
.metric.primary{background:var(--accent-tint);border-color:#d6e4da;}
.metric .m-label{font-size:11px;font-weight:500;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-muted);display:flex;align-items:center;gap:7px;margin-bottom:6px;white-space:nowrap;}
.metric .m-label .icon{width:14px;height:14px;stroke:var(--ink-muted);}
.metric .m-val{font-family:var(--serif);font-size:1.5rem;line-height:1;display:block;font-variant-numeric:tabular-nums;}
.metric .m-val.neg{color:var(--over);}
.metric .m-delta{font-size:12px;margin-top:5px;display:flex;align-items:center;gap:4px;color:var(--ink-muted);}
.metric .m-delta.up{color:var(--accent);}
.grid-2{display:grid;grid-template-columns:1.5fr 1fr;gap:1.2rem;align-items:stretch;}
.grid-2>.card{min-height:236px;}
.grid-2.even{grid-template-columns:1fr 1fr;}
.uncat-chip{display:inline-flex;align-items:center;gap:7px;background:var(--over-light);border:1px solid #f0d9b8;color:var(--over);border-radius:100px;padding:7px 14px;font-size:13px;font-weight:500;margin-bottom:1.2rem;cursor:pointer;}
.uncat-chip .icon{width:15px;height:15px;}
.donut-wrap{display:flex;align-items:center;gap:1.8rem;flex-wrap:wrap;}
.donut-total{font-family:var(--serif);font-size:1.2rem;fill:var(--ink);}
.donut-sub{font-size:11px;fill:var(--ink-muted);text-transform:uppercase;letter-spacing:.06em;}
.donut-pct{font-family:var(--serif);font-size:1.7rem;fill:var(--ink);}
.donut-cat{font-size:11px;fill:var(--ink-soft);font-weight:500;}
.donut-sub2{font-size:11.5px;fill:var(--ink-soft);font-weight:500;}
.donut-only{display:flex;flex-direction:column;align-items:center;gap:.7rem;padding:.6rem 0 .2rem;}
.donut-only svg circle{stroke-linecap:butt;}
.donut-total{font-family:var(--serif);}
.donut-hint{font-size:12px;color:var(--ink-muted);}
.legend{display:grid;grid-template-columns:1fr 1fr;gap:.55rem 1.4rem;flex:1;min-width:230px;}
.leg{display:flex;align-items:flex-start;gap:9px;font-size:13px;}
.leg .ld{width:9px;height:9px;border-radius:3px;margin-top:5px;flex-shrink:0;}
.leg-name{color:var(--ink-soft);}.leg-amt{display:block;font-weight:500;color:var(--ink);font-size:12.5px;}
.leg-amt small{color:var(--ink-muted);font-weight:400;margin-left:4px;}
.area-svg{width:100%;height:auto;display:block;}
.area-fill{fill:rgba(45,90,61,.09);}.area-line{fill:none;stroke:var(--accent);stroke-width:2;}.area-dot{fill:var(--accent);}.area-ax{font-size:10px;fill:var(--ink-muted);}
/* income vs expenses */
.ie-card{margin-bottom:1.2rem;}
.dash-charts{display:grid;grid-template-columns:1.55fr 1fr;gap:1.2rem;margin-bottom:1.2rem;align-items:start;}
.dash-charts .ie-card,.dash-charts .dash-donut{margin-bottom:0;height:100%;}
.dash-charts .donut-wrap{gap:1.3rem;}
@media(max-width:900px){.dash-charts{grid-template-columns:1fr;}}
.dash-chart-swap{display:none;}
.ie-head{align-items:flex-start;}
.ie-titles h3{font-size:1.15rem;}
.ie-toggle{display:inline-flex;gap:2px;background:var(--rule-soft);border-radius:100px;padding:3px;flex-shrink:0;}
.ie-toggle button{border:none;background:none;padding:5px 16px;border-radius:100px;font-size:12.5px;font-weight:500;color:var(--ink-muted);}
.ie-toggle button.on{background:var(--card);color:var(--accent);box-shadow:var(--shadow);}
.ie-svg{width:100%;height:auto;display:block;margin-top:.5rem;overflow:visible;}
.ie-grid{stroke:var(--rule-soft);stroke-width:1;}
.ie-ylab,.ie-xlab{font-size:12px;fill:var(--ink-muted);}
.ie-line{fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;}
.ie-inc{stroke:#2d5a3d;}.ie-exp{stroke:#b45309;}
.ie-foot{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.6rem;margin-top:.8rem;padding-top:.9rem;border-top:1px solid var(--rule-soft);}
.ie-legend{display:flex;gap:1.3rem;}
.ie-legend span{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--ink-soft);}
.ie-legend i{width:11px;height:11px;border-radius:3px;display:inline-block;}
.ie-net{font-size:13px;color:var(--ink-soft);}
.ie-net b{font-variant-numeric:tabular-nums;}
.ie-plot{position:relative;}
.ie-cursor{fill:var(--ink-muted);opacity:.45;transition:x .2s cubic-bezier(.4,0,.2,1);}
.ie-dot{stroke:#fff;stroke-width:2;transition:cx .2s cubic-bezier(.4,0,.2,1),cy .2s cubic-bezier(.4,0,.2,1);}
.ie-inc-dot{fill:#2d5a3d;}.ie-exp-dot{fill:#b45309;}
.ie-tip{position:absolute;top:6px;transform:translateX(-50%);background:var(--ink);color:#fff;border-radius:10px;padding:9px 11px;min-width:128px;box-shadow:0 8px 24px rgba(26,26,24,.22);pointer-events:none;z-index:5;transition:left .2s cubic-bezier(.4,0,.2,1);}
.ie-tip-m{font-weight:600;font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:#9eccae;margin-bottom:6px;}
.ie-tip-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:2px 0;font-size:12.5px;}
.ie-tip-row span{display:inline-flex;align-items:center;gap:7px;color:#d6e6db;}
.ie-tip-row i{width:8px;height:8px;border-radius:2px;display:inline-block;}
.ie-tip-row b{font-variant-numeric:tabular-nums;font-weight:600;color:#fff;}
.ie-tip-row.net{border-top:1px solid rgba(255,255,255,.16);margin-top:4px;padding-top:6px;}
/* ledger total difference */
.led-tot-tag{font-style:normal;font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:2px 8px;border-radius:100px;margin-left:11px;vertical-align:middle;white-space:nowrap;}
.led-tot-tag.good{background:var(--accent-light);color:var(--accent);}
.led-tot-tag.bad{background:var(--over-light);color:var(--over);}
/* budget stat cards (with sparkline + deltas) */
.budstat{display:flex;flex-direction:column;}
.budstat-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:5px;}
.budstat-top .m-label{margin-bottom:0;}
.mini-spark{flex-shrink:0;display:block;}
.budstat .m-val{margin-bottom:0;}
.budstat-foot-row{display:flex;justify-content:flex-end;margin-top:auto;padding-top:8px;}
.budstat-delta{font-size:11.5px;font-weight:600;font-variant-numeric:tabular-nums;display:inline-flex;align-items:center;gap:5px;white-space:nowrap;}
.budstat-delta i{font-style:normal;font-size:9px;}
.budstat-delta small{color:var(--ink-muted);font-weight:400;margin-left:1px;}
.budstat-delta.good{color:var(--accent);}
.budstat-delta.bad{color:var(--over);}
.budstat-note{font-size:12px;color:var(--ink-muted);}
/* cash flow / sankey */
.cf-summary{display:flex;gap:2.2rem;flex-wrap:wrap;padding-bottom:1rem;margin-bottom:.2rem;border-bottom:1px solid var(--rule-soft);}
.cf-lab{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);}
.cf-val{font-family:var(--serif);font-size:1.35rem;line-height:1.15;font-variant-numeric:tabular-nums;}
.sankey-wrap{position:relative;}
.sankey-svg{width:100%;height:auto;display:block;margin-top:.5rem;}
.sk-tip{margin-top:10px;display:inline-block;font-size:13px;color:var(--ink);background:var(--accent-tint);border-radius:10px;padding:8px 14px;}
.sk-tip b{font-weight:600;}
.sk-cap{font-size:10px;fill:var(--ink-muted);letter-spacing:.07em;text-transform:uppercase;}
.sk-name{font-size:11px;fill:var(--ink-soft);}
.sk-amt{font-size:11.5px;font-weight:600;fill:var(--ink);font-variant-numeric:tabular-nums;}
/* mobile cash flow */
.cfm-block{margin-top:1.1rem;}
.cfm-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.5rem;}
.cfm-head b{font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);}
.cfm-head span{font-family:var(--serif);font-size:1.1rem;}
.cfm-bar{display:flex;height:16px;border-radius:5px;overflow:hidden;background:var(--rule-soft);}
.cfm-bar>span{height:100%;}
.cfm-list{margin-top:.7rem;display:flex;flex-direction:column;gap:.4rem;}
.cfm-item{display:flex;align-items:center;gap:9px;font-size:13px;}
.cfm-item .ld{width:9px;height:9px;border-radius:3px;flex-shrink:0;}
.cfm-item .nm{flex:1;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cfm-item .am{font-weight:500;font-variant-numeric:tabular-nums;}
.cfm-item .pc{color:var(--ink-muted);font-size:11.5px;width:34px;text-align:right;}
/* cash flow toggle + trend */
.cf-toggle{display:inline-flex;gap:2px;background:var(--rule-soft);border-radius:100px;padding:3px;margin:1rem 0 .3rem;}
.cf-toggle button{border:none;background:none;padding:6px 16px;border-radius:100px;font-size:12.5px;font-weight:500;color:var(--ink-muted);}
.cf-toggle button.on{background:var(--card);color:var(--accent);box-shadow:var(--shadow);}
.trend-legend{display:flex;gap:1.1rem;flex-wrap:wrap;margin-top:.8rem;}
.trend-legend span{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-soft);}
.trend-legend i{width:11px;height:11px;border-radius:3px;display:inline-block;}
.trend-legend i.ln{width:14px;height:0;border-top:2px solid var(--ink);border-radius:0;}
.trend-svg{width:100%;height:auto;display:block;margin-top:.6rem;}
.tr-zero{stroke:var(--rule);stroke-width:1;}
.tr-ax{font-size:10px;fill:var(--ink-muted);}
.tr-net-line{fill:none;stroke:var(--ink);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;}
.tr-net-dot{fill:#fff;stroke:var(--ink);stroke-width:1.8;}
.tr-guide{stroke:var(--ink-muted);stroke-width:1;stroke-dasharray:3 3;opacity:.5;}
.trend-wrap{position:relative;}
.trend-tip{position:absolute;top:0;transform:translateX(-50%);background:var(--ink);color:#fff;border-radius:10px;padding:9px 12px;min-width:150px;box-shadow:0 8px 24px rgba(26,26,24,.22);pointer-events:none;z-index:5;}
.trend-tip-m{font-weight:600;font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:#9eccae;margin-bottom:6px;}
.trend-tip-r{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:2px 0;font-size:12.5px;}
.trend-tip-r span{display:inline-flex;align-items:center;gap:7px;color:#d6e6db;}
.trend-tip-r i{width:8px;height:8px;border-radius:2px;display:inline-block;}
.trend-tip-r b{font-variant-numeric:tabular-nums;font-weight:600;color:#fff;}
.trend-tip-r.net{border-top:1px solid rgba(255,255,255,.16);margin-top:4px;padding-top:6px;}
.tr-val{font-size:10px;font-weight:600;font-variant-numeric:tabular-nums;}
.trend-foot{font-size:12.5px;color:var(--ink-soft);margin-top:.9rem;}
.trend-foot b{font-weight:600;color:var(--ink);}
/* ledger */
.ledger-card{margin-bottom:1.2rem;}
/* review card-stack flow (mobile) */
.rf{display:flex;flex-direction:column;gap:14px;}
.rf-top{display:flex;align-items:center;justify-content:space-between;}
.rf-count{font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-muted);}
.rf-listbtn{background:none;border:none;color:var(--accent);font-size:13px;font-weight:600;padding:4px;}
.rf-cardbtn{display:inline-flex;align-items:center;gap:7px;background:var(--accent-light);border:1px solid #d2e2d7;color:var(--accent);border-radius:9px;padding:11px 14px;font-size:13.5px;font-weight:600;width:100%;justify-content:center;margin-bottom:1rem;}
.rf-cardbtn .icon{width:16px;height:16px;stroke:var(--accent);}
.rf-card{background:var(--card);border:1px solid var(--rule);border-radius:14px;box-shadow:var(--shadow);padding:1.5rem 1.3rem;animation:rfIn .26s cubic-bezier(.2,.8,.2,1) both;}
.rf-swipe{position:relative;}
.rf-hint{position:absolute;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;opacity:0;transition:opacity .15s;pointer-events:none;z-index:0;max-width:42%;overflow:hidden;}
.rf-hint .icon{width:18px;height:18px;}
.rf-hint.left{left:14px;color:var(--accent);}
.rf-hint.right{right:14px;color:var(--over);}
.rf-hint.left .icon{stroke:var(--cta);}.rf-hint.right .icon{stroke:var(--over);}
.rf-hint.on{opacity:1;}
.rf-swipe .rf-card{position:relative;z-index:1;touch-action:pan-y;}
.rf-card.leaving{transition:transform .18s ease!important;}
.rf-swipe-tip{text-align:center;font-size:11.5px;color:var(--ink-muted);margin:2px 0 0;}
.ptr{position:fixed;top:-34px;left:50%;z-index:90;width:34px;height:34px;border-radius:50%;background:var(--card);box-shadow:0 3px 12px rgba(26,26,24,.16);display:flex;align-items:center;justify-content:center;transition:opacity .2s;pointer-events:none;}
.ptr-spin{width:18px;height:18px;border-radius:50%;border:2.5px solid var(--rule);border-top-color:var(--accent);}
.ptr.refreshing .ptr-spin{animation:ptrspin .7s linear infinite;}
@keyframes ptrspin{to{transform:rotate(360deg);}}
@keyframes rfIn{from{opacity:0;transform:translateY(12px) scale(.98);}to{opacity:1;transform:none;}}
.rf-step{animation:rfStep .26s cubic-bezier(.2,.8,.2,1) both;}
@keyframes rfStep{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.rf-meta{font-size:12px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-muted);}
.rf-amt{font-family:var(--serif);font-size:2.6rem;line-height:1.05;color:var(--over);margin:6px 0 4px;font-variant-numeric:tabular-nums;}
.rf-amt.pos{color:var(--accent);}
.rf-desc{font-size:15px;color:var(--ink);font-weight:500;margin-bottom:1.2rem;line-height:1.35;}
.rf-sugg{margin-bottom:1.2rem;}
.rf-sugg-lab{display:block;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:7px;}
.rf-accept{display:flex;align-items:center;gap:9px;width:100%;background:var(--accent);border:none;color:#fff;border-radius:11px;padding:15px 16px;font-size:15.5px;font-weight:600;text-align:left;}
.rf-accept .ld{width:11px;height:11px;border-radius:3px;flex-shrink:0;}
.rf-accept .icon{width:19px;height:19px;stroke:#fff;margin-left:auto;}
.rf-accept:active{transform:scale(.98);}
.rf-pick-lab{font-size:12.5px;color:var(--ink-muted);margin-bottom:9px;}
.rf-chips{display:flex;flex-wrap:wrap;gap:8px;}
.rf-chip{display:inline-flex;align-items:center;gap:7px;background:var(--paper);border:1px solid var(--rule);color:var(--ink);border-radius:100px;padding:11px 15px;font-size:13.5px;font-weight:500;min-height:44px;}
.rf-chip .ld{width:9px;height:9px;border-radius:3px;}
.rf-chip:active{background:var(--accent-tint);border-color:var(--accent);}
.rf-slide{position:relative;display:flex;justify-content:center;margin-top:6px;}
.rf-slide-tab{position:relative;display:flex;align-items:center;justify-content:center;width:94%;height:54px;padding:0 18px;border:1px solid var(--cta);border-radius:100px;background:var(--card);color:var(--ink);font-size:14px;font-weight:600;box-shadow:0 2px 12px rgba(26,26,24,.12);overflow:hidden;touch-action:pan-y;}
.rf-slide-tab.go-r{transform:scale(1.03);box-shadow:0 6px 22px rgba(17,133,122,.28);}
.rf-slide-tab.go-l{transform:scale(.985);}
.rf-slide-fill{position:absolute;top:0;bottom:0;}
.rf-slide-fill.right{left:0;background:var(--cta);}
.rf-slide-fill.left{right:0;background:var(--over-light);}
.rf-slide-lbl{position:relative;z-index:2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .1s;pointer-events:none;}
.rf-slide-mark{position:absolute;z-index:3;display:flex;align-items:center;justify-content:center;pointer-events:none;animation:markpop .18s ease both;}
.rf-slide-mark.right{right:18px;}
.rf-slide-mark.left{left:18px;}
.rf-slide-mark .icon{width:21px;height:21px;}
.rf-slide-mark.right .icon{stroke:#fff;}
.rf-slide-mark.left .icon{stroke:var(--over);}
@keyframes markpop{from{opacity:0;transform:scale(.5);}to{opacity:1;transform:scale(1);}}
.rf-slide-tip{text-align:center;font-size:11.5px;color:var(--ink-muted);margin:9px 0 0;}
.rf-chip-add{border-style:dashed;color:var(--accent);font-weight:600;}
.rf-chip-add .icon{width:14px;height:14px;stroke:var(--accent);}
.rf-newcat{display:flex;align-items:center;gap:8px;margin-top:10px;}
.rf-newcat input{flex:1;min-width:0;border:1px solid var(--rule);border-radius:9px;padding:11px 12px;font-size:14px;color:var(--ink);background:var(--paper);min-height:44px;}
.rf-newcat input:focus{outline:none;border-color:var(--accent);background:#fff;}
.rf-newcat-add{flex-shrink:0;background:var(--accent);color:#fff;border:none;border-radius:9px;padding:0 16px;font-size:13.5px;font-weight:600;min-height:44px;}
.rf-newcat-add:disabled{opacity:.45;}
.rf-newcat-x{flex-shrink:0;background:none;border:1px solid var(--rule);border-radius:9px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;color:var(--ink-muted);}
.rf-newcat-x .icon{width:16px;height:16px;}
.rf-remove{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;background:none;border:1px solid var(--rule);color:var(--ink-soft);border-radius:10px;padding:13px;font-size:13.5px;font-weight:500;min-height:46px;}
.rf-remove .icon{width:16px;height:16px;}
.rf-remove:active{border-color:var(--over);color:var(--over);}
.rf-done{text-align:center;padding:2.6rem 1.5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;}
.rf-done-ic{width:54px;height:54px;border-radius:50%;background:var(--accent-light);display:flex;align-items:center;justify-content:center;margin-bottom:.4rem;}
.rf-done-ic .icon{width:26px;height:26px;stroke:var(--accent);}
.rf-done h3{font-size:1.2rem;}
.rf-done p{font-size:13.5px;color:var(--ink-soft);max-width:38ch;line-height:1.5;}
.led-row{display:grid;grid-template-columns:1fr 104px 104px 104px;gap:.9rem;align-items:center;padding:7px 0;}
.led-row:not(.head):hover{background:var(--accent-tint);box-shadow:0 0 0 8px var(--accent-tint);border-radius:4px;border-top-color:transparent;}
.led-row.head.head{border:none;padding-bottom:6px;}
.led-cap{display:none;}
.led-pl{display:flex;align-items:center;min-width:0;}
.led-pl .mini{width:100%;}
.led-ac{display:flex;align-items:center;justify-content:flex-end;min-width:0;}
.led-bar{grid-column:1 / -1;height:4px;border-radius:100px;background:var(--rule-soft);overflow:hidden;margin-top:9px;}
.led-bar-fill{display:block;height:100%;border-radius:100px;transition:width .3s ease;}
.led-bar-fill.good{background:var(--accent);}
.led-bar-fill.warn{background:#c9a24a;}
.led-bar-fill.over{background:var(--over);}
.led-row.head span{font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);}
.led-row.head .r{text-align:right;}.led-row.head .c{text-align:right;}
.led-row.head>span:nth-child(2){padding-right:11px;}
.led-row.head>span:nth-child(3){padding-right:11px;}
.led-row.head>span:nth-child(4){padding-right:11px;}
.led-row>.led-ac{padding-right:11px;}
.led-row>.led-df{padding-right:11px;}
.led-tot>:nth-child(2){padding-right:11px;}
.led-tot>:nth-child(3){padding-right:11px;}
.led-tot>:nth-child(4){padding-right:11px;}
.led-name{display:flex;align-items:center;gap:9px;min-width:0;}
.led-name .ld{width:9px;height:9px;border-radius:3px;flex-shrink:0;}
.led-name span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:14px;}
.led-tot{display:grid;grid-template-columns:1fr 104px 104px 104px;gap:.9rem;align-items:center;padding:12px 0 2px;border-top:1px solid var(--rule);margin-top:2px;}
.led-tot b{font-family:var(--serif);font-size:1.05rem;}.led-tot .lab{font-size:13px;font-weight:500;}
.num{text-align:right;font-size:14px;font-variant-numeric:tabular-nums;}
.num.der{color:var(--ink-soft);}.num.accent{color:var(--accent);font-weight:500;}.num.over{color:var(--over);font-weight:500;}.num.warn,.led-df.warn{color:#b58a2e;font-weight:500;}
.led-df{white-space:nowrap;}
.actual-link{background:none;border:none;padding:0;text-align:right;display:inline-flex;align-items:center;justify-content:flex-end;gap:1px;cursor:pointer;width:100%;color:var(--accent);font-weight:500;text-decoration:underline;text-decoration-color:color-mix(in srgb,var(--accent) 35%,transparent);text-underline-offset:3px;transition:text-decoration-color .12s;}
.actual-link:hover{text-decoration-color:var(--accent);}
.mini{width:100%;border:1px solid var(--rule);background:var(--card);border-radius:8px;padding:7px 11px;font-size:14px;font-weight:500;text-align:right;color:var(--ink);-moz-appearance:textfield;transition:border-color .12s,box-shadow .12s,background .12s;}
.mini:hover{border-color:#c7c7bd;}
.mini::-webkit-outer-spin-button,.mini::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.mini:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px var(--accent-tint);}
.mini.der{background:var(--accent-tint);border-color:transparent;color:var(--accent);font-weight:500;cursor:default;}
.led-rename{flex:1;min-width:0;border:1px solid transparent;background:none;border-radius:6px;padding:4px 6px;font-size:14px;color:var(--ink);}
.led-rename:hover{background:var(--paper);}
.led-rename:focus{outline:none;border-color:var(--accent);background:#fff;}
.led-del{background:none;border:none;color:var(--ink-muted);padding:3px;display:flex;flex-shrink:0;opacity:0;transition:opacity .12s ease;}
.led-row:hover .led-del{opacity:1;}
.led-del:hover{color:var(--over);}.led-del .icon{width:14px;height:14px;}
.led-add{background:none;border:1px dashed var(--rule);border-radius:7px;width:100%;padding:8px;color:var(--ink-muted);font-size:13px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:7px;margin-top:.7rem;}
.led-add:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-tint);}
.led-add .icon{width:14px;height:14px;}
/* transactions */
.tx-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.3rem;flex-wrap:wrap;}
.pill{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--rule);border-radius:9px;padding:9px 14px;font-size:13px;font-weight:500;color:var(--ink-soft);}
.pill:hover{background:var(--accent-tint);color:var(--accent);}.pill .icon{width:15px;height:15px;}
.tx-grid{display:grid;grid-template-columns:230px 1fr;gap:1.3rem;align-items:start;}
.tx-accts{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:.8rem;margin-bottom:1.3rem;}
.acctcard{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--rule);border-radius:12px;box-shadow:var(--shadow);padding:.95rem 1rem;text-align:left;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease;}
.acctcard:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-md);}
.acctcard:active{transform:translateY(0);}
.acctcard.active{border-color:var(--accent);background:var(--accent-light);box-shadow:inset 0 0 0 1px var(--accent);}
.acctcard-ic{width:40px;height:40px;border-radius:10px;background:var(--accent-tint);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.acctcard.active .acctcard-ic{background:#fff;}
.acctcard-ic .icon{width:20px;height:20px;}
.acctcard-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;}
.acctcard-name{font-size:14px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.acctcard.active .acctcard-name{color:var(--accent);}
.acctcard-type{font-size:11.5px;color:var(--ink-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.acctcard.add{border-style:dashed;background:none;box-shadow:none;}
.acctcard.add:hover{background:var(--accent-tint);}
.acctcard-ic.add{background:var(--rule-soft);color:var(--ink-muted);}
.acctcard.add:hover .acctcard-ic.add{background:#fff;color:var(--accent);}
.acct-rail{background:var(--card);border:1px solid var(--rule);border-radius:10px;box-shadow:var(--shadow);padding:.6rem;}
.rail-h{font-size:10px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-muted);padding:.6rem .7rem .5rem;}
.acct{display:flex;align-items:center;gap:10px;width:100%;padding:9px 10px;border:none;background:none;border-radius:9px;text-align:left;}
.acct:hover{background:var(--accent-tint);}.acct.active{background:var(--accent-light);}
.acct-ic{width:32px;height:32px;border-radius:8px;background:var(--accent-tint);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.acct.active .acct-ic{background:#fff;}.acct-ic .icon{width:16px;height:16px;}
.acct-meta{flex:1;min-width:0;}
.acct-name{font-size:13.5px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;line-height:1.2;}
.acct.active .acct-name{color:var(--accent);}.acct-type{font-size:11px;color:var(--ink-muted);}
.acct-cnt{font-size:11px;font-weight:600;color:var(--ink-muted);background:var(--rule-soft);border-radius:100px;padding:1px 7px;}
.acct.active .acct-cnt{background:#fff;color:var(--accent);}
.rail-add{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px;border:1px dashed var(--rule);background:none;border-radius:9px;color:var(--ink-muted);font-size:13px;font-weight:500;margin-top:6px;}
.rail-add:hover{color:var(--accent);background:var(--accent-tint);}
.acct-banner{display:flex;align-items:center;gap:11px;background:var(--card);border:1px solid var(--rule);border-radius:10px;padding:11px 14px;margin-bottom:1rem;}
.acct-banner b{font-size:14px;font-weight:500;}.acct-banner small{display:block;font-size:12px;color:var(--ink-muted);}
.acct-clr{margin-left:auto;background:none;border:none;color:var(--accent);font-size:12.5px;font-weight:500;text-decoration:underline;text-underline-offset:2px;}
.stabs{display:flex;gap:6px;margin-bottom:1.1rem;flex-wrap:wrap;}
.stab{border:1px solid var(--rule);background:var(--card);border-radius:100px;padding:8px 16px;font-size:13px;font-weight:500;color:var(--ink-soft);display:inline-flex;align-items:center;gap:8px;}
.stab:hover{border-color:var(--accent);color:var(--accent);}
.stab.active{border-color:var(--accent);background:var(--accent-light);color:var(--accent);}
.stab .cnt{font-size:11px;font-weight:600;border-radius:100px;padding:1px 7px;background:var(--rule-soft);color:var(--ink-muted);}
.stab.active .cnt{background:#fff;color:var(--accent);}
.stab.review .cnt{background:var(--over-light);color:var(--over);}.stab.review.active{border-color:#e5b877;background:var(--over-light);color:var(--over);}
.bulk{display:flex;align-items:center;gap:12px;background:var(--accent-light);border:1px solid #d2e2d7;border-radius:10px;padding:10px 14px;margin-bottom:1rem;font-size:13px;color:var(--accent);}
.bulk-sp{flex:1;}
.bulk button{border:1px solid var(--accent);background:#fff;color:var(--accent);border-radius:7px;padding:6px 13px;font-size:12.5px;font-weight:500;display:inline-flex;align-items:center;gap:6px;}
.bulk button:hover{background:var(--accent);color:#fff;}
.bulk button.danger{border-color:var(--over);color:var(--over);}.bulk button.danger:hover{background:var(--over);color:#fff;}
.bulk button .icon{width:13px;height:13px;}
.tx-card{background:var(--card);border:1px solid var(--rule);border-radius:10px;box-shadow:var(--shadow);overflow:hidden;}
.trow{display:grid;grid-template-columns:34px 84px 1fr 200px 100px 60px;gap:.85rem;align-items:center;padding:9px 1rem;border-top:1px solid var(--rule-soft);}
.trow.head{border:none;background:var(--paper);}
.trow.head span{font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);}
.trow.head .r{text-align:right;}.trow.rem{opacity:.55;}.trow:hover{background:var(--accent-tint);}
.chk{width:17px;height:17px;accent-color:var(--accent);cursor:pointer;}
.t-date{font-size:12.5px;color:var(--ink-muted);white-space:nowrap;}
.t-desc{font-size:14px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.t-desc small{display:block;font-size:11px;color:var(--ink-muted);}
.t-amt{text-align:right;font-size:14px;font-weight:500;font-variant-numeric:tabular-nums;}.t-amt.pos{color:var(--accent);}
.cat-cell{display:flex;align-items:center;gap:8px;min-width:0;}
.cat-cell .ld{width:9px;height:9px;border-radius:3px;flex-shrink:0;}
.cat-excl{font-size:13px;color:var(--ink-muted);}
.cat-pick{flex:1;min-width:0;border:1px solid var(--rule);background:var(--card);border-radius:100px;padding:8px 32px 8px 13px;font-size:13px;font-weight:500;color:var(--ink);cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2383837c' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;transition:border-color .12s,box-shadow .12s;}
.cat-pick:hover{border-color:var(--accent);}
.cat-pick.uncat{border-color:#f0d9b8;background-color:var(--over-light);color:var(--over);}.cat-pick:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-tint);}
.cat-pick option{font-weight:400;color:var(--ink);}
.cat-pick option.cat-new,.cat-pick option[value="__new"]{color:var(--accent);font-weight:600;}
.rowact{display:flex;gap:4px;justify-content:flex-end;}
.rowact-lbl{display:none;}
.iconbtn{width:28px;height:28px;border:1px solid var(--rule);background:var(--card);border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--ink-muted);}
.iconbtn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-tint);}
.iconbtn.danger:hover{border-color:var(--over);color:var(--over);background:var(--over-light);}.iconbtn .icon{width:15px;height:15px;}
.tx-empty{text-align:center;color:var(--ink-muted);font-size:13.5px;padding:2.8rem 1rem;line-height:1.5;}
.tx-empty::before{content:'';display:block;width:42px;height:42px;margin:0 auto .9rem;border-radius:50%;background:var(--accent-light) url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%232d5a3d'%20stroke-width='1.7'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M22%2012h-6l-2%203h-4l-2-3H2'/%3E%3Cpath%20d='M5.45%205.11%202%2012v6a2%202%200%200%200%202%202h16a2%202%200%200%200%202-2v-6l-3.45-6.89A2%202%200%200%200%2016.76%204H7.24a2%202%200%200%200-1.79%201.11z'/%3E%3C/svg%3E") center/20px%2020px no-repeat;}
.tx-acctbar{display:flex;align-items:center;gap:12px;margin-bottom:1.1rem;flex-wrap:wrap;}
.tx-import{flex-shrink:0;}
.acct-chips{display:flex;gap:8px;flex:1;min-width:0;overflow-x:auto;padding-bottom:2px;}
.acct-chips::-webkit-scrollbar{height:5px;}.acct-chips::-webkit-scrollbar-thumb{background:var(--rule);border-radius:100px;}
.achip{flex:0 0 auto;display:inline-flex;align-items:center;gap:8px;border:1px solid var(--rule);background:var(--card);border-radius:100px;padding:7px 13px;font-size:13px;font-weight:500;color:var(--ink-soft);}
.achip:hover{background:var(--accent-tint);color:var(--accent);}
.achip.active{border-color:var(--accent);background:var(--accent-light);color:var(--accent);}
.achip-ic{display:flex;}.achip-ic .icon{width:15px;height:15px;}
.achip-nm{white-space:nowrap;max-width:150px;overflow:hidden;text-overflow:ellipsis;}
.achip-cnt{font-size:11px;font-weight:600;background:var(--rule-soft);color:var(--ink-muted);border-radius:100px;padding:0 7px;}
.achip.active .achip-cnt{background:#fff;color:var(--accent);}
.achip-add{padding:7px 10px;color:var(--ink-muted);}
.acct-rail .tx-import{width:100%;justify-content:center;margin-bottom:.6rem;}
.help-dot{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--rule);color:var(--ink-muted);font-size:11px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;cursor:help;position:relative;margin-left:2px;align-self:center;}
.help-dot:hover,.help-dot:focus{border-color:var(--accent);color:var(--accent);outline:none;}
.help-pop{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(5px);width:250px;background:var(--ink);color:#fff;font-size:12px;font-weight:400;line-height:1.5;text-align:left;padding:11px 13px;border-radius:10px;box-shadow:0 8px 24px rgba(26,26,24,.22);opacity:0;visibility:hidden;transition:opacity .15s,transform .15s;z-index:30;}
.help-pop b{color:#fff;font-weight:600;}
.help-dot:hover .help-pop,.help-dot:focus .help-pop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.tx-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:.8rem;flex-wrap:wrap;}
.tx-search{flex:1;min-width:160px;display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--rule);border-radius:9px;padding:8px 12px;}
.tx-search input{flex:1;min-width:0;border:none;background:none;font-size:13.5px;color:var(--ink);}
.tx-search input:focus{outline:none;}
.tx-search .icon{width:15px;height:15px;stroke:var(--ink-muted);}
.tx-search-x{background:none;border:none;color:var(--ink-muted);padding:0;display:flex;}
.tx-search-x:hover{color:var(--over);}.tx-search-x .icon{width:14px;height:14px;}
.tx-sort{display:inline-flex;gap:2px;background:var(--rule-soft);border-radius:8px;padding:3px;}
.tx-sort button{border:none;background:none;padding:6px 13px;border-radius:6px;font-size:12.5px;font-weight:500;color:var(--ink-muted);}
.tx-sort button.on{background:var(--card);color:var(--accent);box-shadow:var(--shadow);}
.tx-summary{font-size:12px;color:var(--ink-muted);margin-bottom:.7rem;}
.tx-summary b{font-weight:600;}
/* modal */
.ov{position:fixed;inset:0;background:rgba(26,26,24,.5);display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:100;}
.mdl{background:var(--card);border-radius:12px;max-width:480px;width:100%;padding:2rem;position:relative;box-shadow:var(--shadow-lg);max-height:88vh;overflow-y:auto;}
.mdl-x{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--ink-muted);padding:6px;}
.mdl h3{font-size:1.45rem;margin-bottom:.4rem;}.mdl .l{font-size:14px;color:var(--ink-soft);margin-bottom:1.3rem;}
.field{margin-bottom:1.1rem;}
.field label{display:block;font-size:12px;font-weight:500;color:var(--ink-soft);margin-bottom:.45rem;}
.field input,.field select{width:100%;border:1px solid var(--rule);background:var(--card);border-radius:8px;padding:11px 13px;font-size:15px;color:var(--ink);transition:border-color .12s,box-shadow .12s;}
.field input:focus,.field select:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px var(--accent-tint);}
.type-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
.type-opt{border:1px solid var(--rule);background:var(--card);border-radius:10px;padding:.9rem .5rem;display:flex;flex-direction:column;align-items:center;gap:7px;font-size:12.5px;font-weight:500;color:var(--ink-soft);}
.type-opt:hover{border-color:var(--accent);}.type-opt.sel{border-color:var(--accent);background:var(--accent-light);color:var(--accent);}.type-opt .icon{width:20px;height:20px;}
.dropzone{border:1.5px dashed var(--rule);border-radius:12px;padding:1.8rem;text-align:center;cursor:pointer;display:block;}
.dropzone:hover,.dropzone.drag{border-color:var(--accent);background:var(--accent-tint);}
.dropzone .icon{width:28px;height:28px;stroke:var(--accent);margin:0 auto .6rem;display:block;}
.dropzone b{font-size:14px;font-weight:500;color:var(--ink);}.dropzone p{font-size:12.5px;color:var(--ink-muted);margin-top:4px;}
.prev-tbl{width:100%;border-collapse:collapse;margin-bottom:1rem;}
.prev-tbl th{font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);text-align:left;padding:6px;border-bottom:1px solid var(--rule);}
.prev-tbl th.r,.prev-tbl td.r{text-align:right;}
.prev-tbl td{font-size:13px;padding:8px 6px;border-bottom:1px solid var(--rule-soft);color:var(--ink-soft);}
.btn-primary{background:var(--cta);color:#fff;border:none;border-radius:9px;padding:11px 18px;font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:8px;text-decoration:none;}
.btn-primary:hover{background:var(--cta-deep);}.btn-primary:disabled{opacity:.45;}
.btn-ghost{background:none;border:1px solid var(--rule);border-radius:9px;padding:10px 16px;font-size:14px;font-weight:500;color:var(--ink-soft);}
.step-dots{display:flex;gap:6px;margin-bottom:1.2rem;}
.step-dots span{width:7px;height:7px;border-radius:50%;background:var(--rule);}.step-dots span.on{background:var(--accent);}
.mdl-foot{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:1rem;}
.mdl-sum{font-size:13px;color:var(--ink-soft);flex:1;}
.banner{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:10px;font-size:13.5px;margin-bottom:1.2rem;}
.banner.ok{background:var(--accent-tint);border:1px solid #d6e4da;color:var(--ink-soft);}
.banner .icon{stroke:var(--accent);width:16px;height:16px;}
.banner .go{margin-left:auto;background:var(--accent);color:#fff;border:none;border-radius:7px;padding:6px 13px;font-size:12.5px;font-weight:500;text-decoration:none;white-space:nowrap;}
.banner button.bx{margin-left:auto;background:none;border:none;color:var(--ink-muted);padding:2px;}
/* nw / goals / taxes */
.nw-hero{background:linear-gradient(162deg,var(--accent),var(--accent-deep));border-radius:10px;padding:1.25rem 1.4rem;display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;margin-bottom:1.2rem;}
.nw-hero small.l{font-size:11px;font-weight:500;letter-spacing:.09em;text-transform:uppercase;color:#9eccae;}
.nw-hero .big{font-family:var(--serif);font-size:2.1rem;color:#fff;line-height:1;margin:5px 0 7px;font-variant-numeric:tabular-nums;}
.nw-hero .dl{font-size:13px;color:#9be3b4;}
.nw-side{display:flex;gap:1.6rem;}.nw-side small{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#9eccae;display:block;}.nw-side b{font-family:var(--serif);font-size:1.3rem;color:#fff;}
.tax-big{font-family:var(--serif);font-size:1.9rem;color:var(--accent);line-height:1;font-variant-numeric:tabular-nums;}
.range{width:100%;accent-color:var(--accent);}
.goal-bar{height:11px;background:var(--rule-soft);border-radius:100px;overflow:hidden;margin:.7rem 0;}
.goal-bar>span{display:block;height:100%;background:var(--accent);border-radius:100px;}
.lever{background:var(--card);border:1px solid var(--rule);border-radius:10px;padding:1.2rem;}
.lever .lt{font-size:10px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--accent);}
.lever .lv{font-family:var(--serif);font-size:1.5rem;margin:4px 0 5px;}.lever p{font-size:12.5px;color:var(--ink-soft);}
.subtabs{display:inline-flex;gap:2px;background:var(--rule-soft);border-radius:100px;padding:3px;margin-bottom:1.4rem;}
.rep-subtabs{display:flex;align-items:center;justify-content:space-between;gap:12px;background:none;padding:0;border-radius:0;flex-wrap:wrap;}
.rep-subtabs .subtabs-tabs{display:inline-flex;gap:2px;background:var(--rule-soft);border-radius:100px;padding:3px;}
.rep-monthsel{margin-bottom:0;}
.subtab{border:none;background:none;padding:7px 18px;border-radius:100px;font-size:13px;font-weight:500;color:var(--ink-muted);}
.subtab.active{background:var(--card);color:var(--accent);box-shadow:var(--shadow);}
.add-btn{background:none;border:1px dashed var(--rule);border-radius:8px;width:100%;padding:9px;color:var(--ink-muted);font-size:13px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:.7rem;}
.add-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-tint);}
.conn-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.conn-card{background:var(--card);border:1px solid var(--rule);border-radius:10px;padding:1.1rem;box-shadow:var(--shadow);transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease;}
.conn-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}
.conn-ico{width:44px;height:44px;border-radius:11px;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:.5rem;}
.conn-ico .icon{width:22px;height:22px;}
.conn-soon{font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--over);background:var(--over-light);padding:2px 9px;border-radius:100px;}
.conn-card h3{font-size:1.15rem;margin:.5rem 0 .3rem;}.conn-card p{font-size:13px;color:var(--ink-soft);}

/* ===== boot splash ===== */
.boot{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:var(--paper);}
.boot-mark{width:54px;height:54px;border-radius:13px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-style:italic;font-size:22px;animation:bootpulse 1.3s ease-in-out infinite;}
.boot-text{font-size:13px;color:var(--ink-muted);}
@keyframes bootpulse{0%,100%{opacity:.55;transform:scale(.96);}50%{opacity:1;transform:scale(1);}}

/* ===== Pro modal ===== */
.pro-mdl{text-align:left;}
.pro-badge{display:inline-block;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-light);border:1px solid #d2e2d7;padding:3px 11px;border-radius:100px;margin-bottom:1rem;}
.pro-feats{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin:0 0 1.3rem;}
.pro-feats li{display:flex;align-items:flex-start;gap:9px;font-size:13.5px;color:var(--ink-soft);line-height:1.45;}
.pro-feats li .icon{width:16px;height:16px;stroke:var(--accent);flex-shrink:0;margin-top:2px;}
.pro-feats li b{color:var(--ink);font-weight:600;}
.pro-buy{width:100%;justify-content:center;white-space:nowrap;}
.pro-fine{font-size:11.5px;color:var(--ink-muted);text-align:center;margin:.7rem 0 1.2rem;line-height:1.5;}
.pro-restore{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding-top:1.1rem;border-top:1px solid var(--rule-soft);}
.pro-restore span{font-size:12.5px;color:var(--ink-muted);}
.pro-restore input{flex:1;min-width:120px;border:1px solid var(--rule);border-radius:7px;padding:8px 11px;font-size:13px;}
.pro-restore input:focus{outline:none;border-color:var(--accent);}
.pro-restore input.err{border-color:var(--over);}
.pro-restore button{background:none;border:none;color:var(--accent);font-size:13px;font-weight:600;text-decoration:underline;text-underline-offset:2px;}
.pro-err{font-size:12px;color:var(--over);margin-top:.6rem;}

/* ===== editable net-worth accounts ===== */
.nwacct{display:flex;align-items:center;gap:10px;padding:9px 0;border-top:1px solid var(--rule-soft);}
.nwacct .ld{width:9px;height:9px;border-radius:3px;flex-shrink:0;}
.nwacct-name{flex:1;min-width:0;border:1px solid transparent;background:none;border-radius:7px;padding:6px 8px;font-size:14px;color:var(--ink);}
.nwacct-name:hover{background:var(--paper);}
.nwacct-name:focus{outline:none;border-color:var(--accent);background:#fff;}
.nwacct-cur{font-size:13px;color:var(--ink-muted);}
.nwacct-bal{width:108px;flex-shrink:0;}
.nwacct-rm{background:none;border:none;color:var(--ink-muted);padding:5px;display:flex;flex-shrink:0;}
.nwacct-rm:hover{color:var(--over);}.nwacct-rm .icon{width:16px;height:16px;}
.nw-nudge{align-items:flex-start;}
.nw-saved-line{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-soft);margin:-.4rem 0 1.2rem;}
.nw-saved-line .icon{width:15px;height:15px;stroke:var(--accent);}
.nwacct-month{flex:1;min-width:0;font-size:14px;color:var(--ink);padding:6px 8px;}
.nw-hist-empty{font-size:13px;color:var(--ink-muted);line-height:1.5;padding:.4rem 0 .2rem;max-width:60ch;}

/* ===== goals & forecasting ===== */
.goal-input{width:100%;border:1px solid var(--rule);background:var(--card);border-radius:8px;padding:9px 11px;font-size:15px;color:var(--ink);transition:border-color .12s,box-shadow .12s;}
.goal-input:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px var(--accent-tint);}
.goal-sec-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.9rem;}
.goal-sec-head h3{font-family:var(--serif);font-size:1.05rem;}
.goal-add{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--rule);background:var(--card);border-radius:100px;padding:7px 14px;font-size:13px;font-weight:500;color:var(--accent);}
.goal-add:hover{background:var(--accent-tint);color:var(--accent);}.goal-add .icon{width:15px;height:15px;}
.goal-list{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.goal-card{background:var(--card);border:1px solid var(--rule);border-radius:10px;padding:1.05rem;box-shadow:var(--shadow);}
.goal-card-top{display:flex;align-items:center;gap:8px;margin-bottom:.9rem;}
.goal-name{flex:1;min-width:0;border:1px solid transparent;background:none;border-radius:7px;padding:5px 8px;font-family:var(--serif);font-size:1.1rem;color:var(--ink);}
.goal-name:hover{background:var(--paper);}.goal-name:focus{outline:none;border-color:var(--accent);background:#fff;}
.goal-rm{background:none;border:none;color:var(--ink-muted);padding:5px;display:flex;}.goal-rm:hover{color:var(--over);}.goal-rm .icon{width:16px;height:16px;}
.goal-meta{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-top:7px;font-size:12px;color:var(--ink-muted);}
.goal-eta{font-weight:600;color:var(--accent);}
.goal-fields{display:flex;gap:.7rem;margin-top:1.1rem;}
.goal-fields label{flex:1;font-size:11px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-muted);display:flex;flex-direction:column;gap:5px;}
.gf-row{display:flex;align-items:center;gap:5px;border:1px solid var(--rule);background:var(--paper);border-radius:7px;padding:0 9px;}
.gf-row span{font-size:13px;color:var(--ink-muted);}
.gf-row input{flex:1;min-width:0;border:none;background:none;padding:8px 0;font-size:14px;color:var(--ink);-moz-appearance:textfield;}
.gf-row input::-webkit-outer-spin-button,.gf-row input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.gf-row input:focus{outline:none;}.gf-row:focus-within{border-color:var(--accent);background:#fff;}
.goal-sub{font-size:12.5px;color:var(--ink-soft);margin-top:.9rem;}

/* ===== bank-sync waitlist ===== */
.wl-card{margin-top:1rem;}
.wl-card h3{font-size:1.15rem;margin-bottom:.4rem;}
.wl-card p{font-size:13px;color:var(--ink-soft);line-height:1.5;margin-bottom:1rem;max-width:60ch;}
.wl-form{display:flex;gap:8px;max-width:440px;}
.wl-form input{flex:1;min-width:0;border:1px solid var(--rule);background:var(--paper);border-radius:8px;padding:11px 13px;font-size:15px;color:var(--ink);}
.wl-form input:focus{outline:none;border-color:var(--accent);background:#fff;}.wl-form input.err{border-color:var(--over);}
.wl-form button{white-space:nowrap;}
.wl-err{font-size:12px;color:var(--over);margin-top:.6rem;}
.wl-done{display:flex;align-items:center;gap:14px;}.wl-done .conn-ico{margin:0;flex-shrink:0;}.wl-done h3{margin-bottom:2px;}.wl-done p{margin:0;}
.conn-foot{font-size:13px;color:var(--ink-muted);margin-top:1.1rem;}
.backup-card{margin-top:1.4rem;}
.backup-hd{display:flex;gap:14px;align-items:flex-start;margin-bottom:1.1rem;}
.backup-hd .conn-ico{margin:0;flex-shrink:0;}
.backup-hd h3{margin-bottom:4px;}
.backup-hd p{font-size:13px;color:var(--ink-soft);line-height:1.55;margin:0;}
.backup-actions{display:flex;gap:10px;flex-wrap:wrap;}
.backup-actions .btn-primary .icon,.backup-actions .btn-ghost .icon{width:16px;height:16px;}
.backup-actions .btn-ghost{display:inline-flex;align-items:center;gap:8px;cursor:pointer;}
.backup-actions .btn-ghost:hover{border-color:var(--accent);color:var(--accent);}
.backup-note{font-size:13px;margin:.9rem 0 0;display:flex;align-items:center;gap:7px;}
.backup-note .icon{width:15px;height:15px;}
.backup-note.ok{color:var(--accent);}.backup-note.ok .icon{stroke:var(--accent);}
.backup-note.err{color:var(--over);}
.backup-tip{font-size:12px;color:var(--ink-muted);margin:.9rem 0 0;line-height:1.5;}
.linklike{background:none;border:none;color:var(--accent);font-size:13px;font-weight:500;text-decoration:underline;text-underline-offset:2px;padding:0;}

/* ===== mobile bottom nav ===== */
.mobnav{display:none;}
@media(max-width:1000px){.metrics{grid-template-columns:1fr 1fr;}.grid-2,.grid-2.even,.conn-grid,.goal-list{grid-template-columns:1fr;}}
@media(max-width:900px){.tx-grid{grid-template-columns:1fr;}.acct-rail{display:flex;flex-wrap:wrap;gap:6px;}.acct{width:auto;}}
@media(max-width:760px){
  .sidebar{display:none;}
  .content,.topbar{padding-left:1.2rem;padding-right:1.2rem;}
  .content{padding-bottom:5.5rem;}
  .legend{grid-template-columns:1fr;}
  .mobnav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--card);border-top:1px solid var(--rule);padding:6px 6px;gap:2px;box-shadow:0 -3px 14px rgba(26,26,24,.06);}
  .mobnav::-webkit-scrollbar{display:none;}
  .mobnav button{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;border-radius:10px;padding:8px 4px;color:var(--ink-muted);font-size:10.5px;font-weight:500;position:relative;white-space:nowrap;}
  .mobnav button.active{color:var(--accent);background:var(--accent-light);}
  .mobnav button .icon{width:21px;height:21px;}
  .mobnav .mn-badge{position:absolute;top:2px;right:7px;background:var(--over);color:#fff;font-size:9px;line-height:1.4;border-radius:100px;padding:0 5px;}
  .mn-sheet{display:flex;position:fixed;bottom:62px;right:8px;z-index:61;background:var(--card);border:1px solid var(--rule);border-radius:12px;box-shadow:0 6px 24px rgba(26,26,24,.16);padding:6px;flex-direction:column;min-width:160px;}
  .mn-sheet button{display:flex;align-items:center;gap:10px;background:none;border:none;border-radius:8px;padding:10px 12px;font-size:13px;color:var(--ink-soft);text-align:left;}
  .mn-sheet button.active{background:var(--accent-light);color:var(--accent);}
  .mn-sheet button.locked{opacity:.55;}
  .mn-soon{margin-left:auto;font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;background:var(--rule-soft);color:var(--ink-muted);border-radius:100px;padding:2px 8px;}
  .mn-sheet button .icon{width:18px;height:18px;}
}
@media(max-width:680px){.trow{grid-template-columns:28px 1fr 92px;grid-template-areas:'chk desc amt' 'chk cat cat' 'chk act act';gap:.5rem .7rem;}.trow.head{display:none;}.t-date{display:none;}.chk{grid-area:chk;}.t-desc{grid-area:desc;}.t-amt{grid-area:amt;}.cat-cell{grid-area:cat;}.rowact{grid-area:act;justify-content:flex-start;gap:8px;margin-top:2px;}.type-grid{grid-template-columns:1fr;}.goal-fields{flex-direction:column;}
  .rowact .iconbtn{width:auto;height:auto;min-height:38px;padding:0 14px;gap:6px;border-radius:9px;font-size:13px;font-weight:600;}
  .rowact .rowact-lbl{display:inline;}
  .rowact .iconbtn:not(.danger){background:var(--accent-light);border-color:#d2e2d7;color:var(--accent);}
  .rowact .iconbtn:not(.danger) .icon{stroke:var(--accent);}
  .rowact .iconbtn.danger{color:var(--ink-soft);}
  .rowact .iconbtn.danger .icon{stroke:var(--ink-soft);}
  .t-desc{font-size:14.5px;font-weight:500;}
}

/* ===== mobile polish (phones) ===== */
@media(max-width:760px){
  /* topbar: stack title + month selector on the left, login stays top-right */
  .topbar{align-items:flex-start;padding-top:.7rem;padding-bottom:.7rem;gap:.6rem;transition:transform .28s ease;}
  .topbar.tb-hidden{transform:translateY(-100%);}
  .tb-left{flex-direction:column;align-items:flex-start;gap:8px;min-width:0;flex:1;}
  .tb-title{font-size:1.15rem;}
  .tb-monthsel{margin:0;}
  .tb-monthsel .dr-sel{min-height:40px;}
  .login-pill{flex-shrink:0;min-height:40px;padding:0 14px;display:inline-flex;align-items:center;}
  .tb-right:has(.backup-icon-btn) .login-pill{width:40px;padding:0;justify-content:center;}
  .tb-right:has(.backup-icon-btn) .login-pill .login-txt{display:none;}
  .tb-right:has(.backup-icon-btn) .login-pill .icon{width:18px;height:18px;}
  /* comfortable tap targets */
  .dr-sel{min-height:40px;}
  .dh-ai-btn,.attn-cta,.me-btn,.qa-btn{min-height:42px;}
  .attn-cta{padding-top:0;padding-bottom:0;display:inline-flex;align-items:center;}
  .ie-toggle button{min-height:34px;}
  /* hero spacing */
  .dash-hero{padding:1.1rem 1.15rem;}
  .dh-val-row{gap:10px;}
  /* recurring hero number wraps cleanly */
  .recur-hero{gap:.5rem;}
  .recur-bar-note{margin-left:0;width:100%;}
  /* eduardo modal fits the screen */
  .ed-modal{max-width:none;width:calc(100vw - 26px);}
  /* import modal as full-screen sheet */
  .ov:has(.import-modal){padding:0;}
  .mdl.import-modal{position:fixed;top:0;left:0;right:0;bottom:0;height:100%;max-width:none;width:auto;min-height:0;border-radius:0;padding:1.4rem 1.2rem 5.5rem;display:flex;flex-direction:column;max-height:none;overflow-y:auto;}
  .import-modal .prev-tbl{font-size:12.5px;}
  .import-modal .mdl-foot{position:fixed;left:0;right:0;bottom:0;background:var(--card);border-top:1px solid var(--rule);padding:.9rem 1.2rem;margin:0;display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;box-shadow:0 -3px 14px rgba(26,26,24,.07);z-index:2;}
  .import-modal .mdl-foot .btn-primary{flex:1;justify-content:center;min-height:46px;}
  .import-modal .mdl-foot .mdl-sum{order:-1;width:100%;text-align:left!important;}
  .ed-ov{padding:1rem;}
  /* dashboard chart swap: one slot, tap to switch */
  .dash-chart-swap{display:inline-flex;gap:2px;background:var(--rule-soft);border-radius:100px;padding:3px;margin-bottom:1rem;}
  .dash-chart-swap button{flex:1;border:none;background:none;padding:8px 16px;border-radius:100px;font-size:13px;font-weight:500;color:var(--ink-muted);min-height:38px;}
  .dash-chart-swap button.on{background:var(--card);color:var(--accent);box-shadow:var(--shadow);}
  .dash-charts{position:relative;}
  .dash-charts .ie-card,.dash-charts .dash-donut{transition:opacity .32s var(--ease-soft);}
  .dash-charts.show-trend .ie-card{opacity:1;}
  .dash-charts.show-trend .dash-donut{position:absolute;inset:0;opacity:0;pointer-events:none;}
  .dash-charts.show-spend .dash-donut{opacity:1;}
  .dash-charts.show-spend .ie-card{position:absolute;inset:0;opacity:0;pointer-events:none;}
  /* transaction status tabs fit one line */
  .stabs{flex-wrap:nowrap;gap:5px;align-items:center;}
  .help-pop{left:auto;right:0;transform:translateY(5px);width:min(250px,calc(100vw - 30px));}
  .help-dot:hover .help-pop,.help-dot:focus .help-pop{transform:translateY(0);}
  .stab{flex:0 1 auto;min-width:0;justify-content:center;padding:8px 11px;font-size:12px;gap:5px;white-space:nowrap;}
  .stab .cnt{padding:1px 5px;flex-shrink:0;}
  .help-dot{flex-shrink:0;}
  /* reports tabs row: let the 5 tabs scroll horizontally instead of forcing page overflow */
  .rep-subtabs{gap:10px;}
  .rep-subtabs .subtabs-tabs{flex:1 1 100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
  .rep-subtabs .subtabs-tabs::-webkit-scrollbar{display:none;}
  .rep-subtabs .subtab{white-space:nowrap;flex:0 0 auto;}
  /* ledger: stack name on top, Planned/Actual/Diff in a row below */
  .led-row,.led-row.head,.led-tot{grid-template-columns:1fr 1fr 1fr;grid-template-areas:'name name name' 'pl ac df' 'bar bar bar';gap:.25rem .7rem;}
  .led-row>:nth-child(5){grid-area:bar;}
  .led-row>:nth-child(1),.led-row.head>:nth-child(1),.led-tot>:nth-child(1){grid-area:name;}
  .led-row>:nth-child(2),.led-row.head>:nth-child(2),.led-tot>:nth-child(2){grid-area:pl;}
  .led-row>:nth-child(3),.led-row.head>:nth-child(3),.led-tot>:nth-child(3){grid-area:ac;}
  .led-row>:nth-child(4),.led-row.head>:nth-child(4),.led-tot>:nth-child(4){grid-area:df;}
  .led-row.head{display:none;}
  .led-pl,.led-ac,.led-df{flex-direction:column;align-items:flex-start;gap:2px;justify-content:flex-start;}
  .led-ac{align-items:flex-end;}
  .led-pl{align-items:flex-end;}
  .led-pl .led-cap{padding-right:11px;}
  .led-ac .num{text-align:right;}
  .led-cap{display:block;font-size:9px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-muted);}
  .led-row .mini{width:100%;min-height:40px;}
  .led-row .num,.led-tot .num{text-align:left;}
  .led-tot .led-cap{display:none;}
  .led-name{padding-bottom:2px;}
  .actual-link{align-items:flex-end;justify-content:flex-end;}
  /* compact icon blocks so cards breathe on small screens */
  .attn-row{gap:11px;padding:12px 14px;}
  .attn-ic{width:30px;height:30px;border-radius:8px;}
  .attn-ic .icon{width:16px;height:16px;}
  .ins-row{gap:9px;}
  .ins-ic{width:26px;height:26px;border-radius:7px;}
  .ins-ic .icon{width:14px;height:14px;}
  .ed-note-av{width:34px;height:34px;}
}
@media(max-width:430px){
  .content,.topbar{padding-left:1rem;padding-right:1rem;}
  .dh-val{font-size:2.3rem;}
  .recur-big{font-size:1.9rem;}
  /* attn rows: CTA full-width under the text for easy tapping */
  .attn-row{flex-wrap:wrap;}
  .attn-cta{margin-left:41px;}
  /* budget date range fields stack so selects are full width */
  .daterange{width:100%;}
  .daterange .dr-field{flex:1;}
  .daterange .dr-sel{width:100%;min-width:0;}
  /* modals use the small screen better */
  .ov{padding:1rem;}
  .mdl{padding:1.4rem;}
  .mdl h3{font-size:1.25rem;}
}

/* =========================================================
   MOTION LANGUAGE  ·  smoothed transitions
   Two easings (--ease-calm / --ease-soft) + a short duration
   scale. Quiet and consistent — no springs.
   ========================================================= */

/* ---- modals & popups: smooth enter + exit ----
   Scoped with :not(.ed-ov) so the AI note modal keeps its own
   richer enter/exit untouched. */
.ov:not(.ed-ov){animation:ovIn .26s ease both;backdrop-filter:blur(2.5px);}
.ov:not(.ed-ov) .mdl{animation:mdlIn .34s var(--ease-calm) both;}
.ov:not(.ed-ov).closing{animation:ovOut .22s ease forwards;}
.ov:not(.ed-ov).closing .mdl{animation:mdlOut .2s var(--ease-soft) forwards;}
@keyframes ovIn{from{opacity:0;}to{opacity:1;}}
@keyframes ovOut{from{opacity:1;}to{opacity:0;}}
@keyframes mdlIn{from{opacity:0;transform:translateY(14px) scale(.96);}to{opacity:1;transform:none;}}
@keyframes mdlOut{from{opacity:1;transform:none;}to{opacity:0;transform:translateY(8px) scale(.985);}}

/* ---- mobile "More" sheet: slide + fade up ---- */
.mn-sheet{animation:sheetIn .2s var(--ease-calm) both;transform-origin:bottom right;}
@keyframes sheetIn{from{opacity:0;transform:translateY(10px) scale(.97);}to{opacity:1;transform:none;}}

/* ---- segmented toggles: sliding thumb ----
   Add class "seg-th" (via the Seg component); the thumb glides
   under the active label instead of the pill snapping. */
.seg-th{position:relative;}
.seg-th .seg-thumb{position:absolute;top:3px;bottom:3px;left:0;border-radius:100px;background:var(--card);box-shadow:var(--shadow);transition:left .34s var(--ease-calm),width .34s var(--ease-calm);z-index:0;pointer-events:none;}
.seg-th button{position:relative;z-index:1;transition:color .25s var(--ease-calm);}
.seg-th button.on{background:transparent!important;box-shadow:none!important;}

/* ---- review cards: calm enter/exit + a subtle depth stack ---- */
.rf-swipe{position:relative;}
.rf-card{position:relative;z-index:1;animation:rfSettle .34s var(--ease-soft) both;}
@keyframes rfSettle{from{opacity:0;transform:translateY(7px) scale(.985);}to{opacity:1;transform:none;}}
.rf-stack-peek{position:absolute;left:8px;right:8px;top:0;height:100%;background:var(--card);border:1px solid var(--rule);border-radius:14px;box-shadow:var(--shadow);transform:translateY(12px) scale(.965);transform-origin:top center;opacity:.7;z-index:0;pointer-events:none;}
.rf-exit-clone{position:absolute;inset:0;z-index:5;background:var(--card);border:1px solid var(--rule);border-radius:14px;box-shadow:var(--shadow-md);padding:1.5rem 1.3rem;pointer-events:none;overflow:hidden;}
.rf-exit-clone .rf-meta{font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-muted);}
.rf-exit-clone.rf-exit-accept{animation:rfExitAccept .4s var(--ease-calm) both;}
.rf-exit-clone.rf-exit-remove{animation:rfExitRemove .44s var(--ease-calm) both;}
@keyframes rfExitAccept{from{opacity:1;transform:translateY(0) scale(1);}to{opacity:0;transform:translateY(-10px) scale(.92);}}
@keyframes rfExitRemove{from{opacity:1;transform:translateX(0) rotate(0);}to{opacity:0;transform:translateX(-118%) rotate(-7deg);}}
