:root{
  --bg:#f3f5f9; --panel:#ffffff; --panel2:#f8fafc; --raise:#eef2f7;
  --line:#e3e8f0; --line2:#cdd5e2;
  --hi:#1e2734; --mid:#5a6677; --dim:#8d97a8;
  --green:#16966a; --green-bg:#e7f6ef; --green-line:#bfe6d4;
  --red:#dc3a3a; --red-bg:#fdeced; --red-line:#f4c4c6;
  --amber:#c97a04; --amber-bg:#fbf2e0;
  --blue:#2563eb; --blue-bg:#e8f0ff;
  --violet:#6d3ad6; --violet-bg:#f1ebfc; --violet-line:#ddccf5;
  --mono:'JetBrains Mono','SF Mono',ui-monospace,monospace;
  --sans:'Inter',system-ui,-apple-system,sans-serif;
  --shadow:0 1px 2px rgba(20,30,50,.04),0 4px 14px rgba(20,30,50,.05);
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--hi);font-family:var(--sans);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;padding:0 0 80px}
.num{font-family:var(--mono);font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}
button{font-family:inherit;cursor:pointer}
input,select{font-family:inherit}

/* ---- auth ---- */
body.auth{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.authbox{background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:30px;width:340px;max-width:100%}
.authbox h1{font-size:20px;font-weight:700;letter-spacing:-.01em}
.authsub{color:var(--dim);font-size:13px;margin:4px 0 18px}
.authbox label{display:block;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--mid);font-weight:600;margin-bottom:14px}
.authbox input{display:block;width:100%;margin-top:6px;background:var(--panel2);border:1px solid var(--line2);border-radius:9px;padding:10px 12px;font-size:14px;color:var(--hi);outline:none}
.authbox input:focus{border-color:var(--blue)}
.authbox button{width:100%;background:var(--blue);color:#fff;border:none;border-radius:9px;padding:11px;font-size:14px;font-weight:600;margin-top:6px}
.autherr{background:var(--red-bg);color:var(--red);border:1px solid var(--red-line);border-radius:9px;padding:9px 12px;font-size:13px;margin-bottom:14px}
code{font-family:var(--mono);background:var(--raise);padding:1px 5px;border-radius:5px;font-size:12px}

header{position:sticky;top:0;z-index:30;background:rgba(243,245,249,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:13px 22px}
.hwrap{max-width:1340px;margin:0 auto;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.brand{display:flex;align-items:baseline;gap:10px}
.brand b{font-size:17px;font-weight:700;letter-spacing:-.01em}
.brand span{font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:.12em;border:1px solid var(--line2);padding:2px 6px;border-radius:5px}
.brand span.saving{color:var(--amber);border-color:var(--amber)}
.brand span.error{color:var(--red);border-color:var(--red-line)}
.mselect select{background:var(--panel);border:1px solid var(--line2);color:var(--hi);border-radius:8px;padding:6px 10px;font-size:13px;font-weight:500;box-shadow:var(--shadow)}
.ghost{background:var(--panel);border:1px solid var(--line2);color:var(--mid);border-radius:8px;padding:7px 13px;font-size:13px;font-weight:500;box-shadow:var(--shadow);display:inline-flex;gap:6px;align-items:center;text-decoration:none}
.ghost:hover{border-color:var(--blue);color:var(--blue)}
.topfig{margin-left:auto;display:flex;gap:24px;align-items:center}
.tf{text-align:right}
.tf .lbl{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);margin-bottom:1px}
.tf .val{font-size:19px;font-weight:600}
.chip{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;border-radius:10px;font-weight:600;font-size:13px;border:1px solid transparent}
.chip .dot{width:8px;height:8px;border-radius:50%}
.chip.ok{background:var(--green-bg);color:var(--green);border-color:var(--green-line)}
.chip.ok .dot{background:var(--green)}
.chip.bad{background:var(--red-bg);color:var(--red);border-color:var(--red-line)}
.chip.bad .dot{background:var(--red)}

main{max-width:1340px;margin:22px auto;padding:0 22px;display:grid;grid-template-columns:1fr 392px;gap:22px;align-items:start}
@media(max-width:980px){main{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow)}
.card-h{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px}
.card-h h2{font-size:13px;font-weight:600;letter-spacing:.01em}
.card-h .sub{font-size:11px;color:var(--dim);margin-left:auto}
.card-h .act{margin-left:auto;display:flex;gap:8px}
.tinybtn{background:var(--panel2);border:1px solid var(--line2);color:var(--mid);border-radius:7px;padding:5px 10px;font-size:12px;font-weight:500;display:inline-flex;gap:5px;align-items:center}
.tinybtn:hover{border-color:var(--blue);color:var(--blue)}

.income{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line)}
.inc-cell{background:var(--panel);padding:13px 16px}
.inc-cell label{font-size:10px;letter-spacing:.11em;text-transform:uppercase;color:var(--dim);display:block;margin-bottom:5px}
.inc-cell input{background:transparent;border:none;color:var(--hi);font-size:18px;font-weight:600;width:100%;font-family:var(--mono);outline:none;border-bottom:1px dashed transparent;padding-bottom:2px}
.inc-cell input:focus{border-bottom-color:var(--blue)}
.budgetbar{display:flex;align-items:center;gap:16px;padding:11px 18px;background:var(--panel2);border-top:1px solid var(--line);font-size:12px;color:var(--mid);border-radius:0 0 14px 14px;flex-wrap:wrap}
.budgetbar .seg b{color:var(--hi);font-family:var(--mono);font-weight:600}
.budgetbar .seg{display:flex;gap:6px;align-items:center}
.budgetbar .diff.pos{color:var(--green)} .budgetbar .diff.neg{color:var(--red)}

.pillar{border-bottom:1px solid var(--line)}
.pillar:last-child{border-bottom:none}
.pillar-h{display:flex;align-items:center;gap:13px;padding:12px 18px}
.caret{color:var(--dim);transition:transform .15s;font-size:11px;width:12px;cursor:pointer}
.pillar.open .caret{transform:rotate(90deg)}
.pillar-name{font-weight:600;font-size:14px;min-width:96px;cursor:pointer}
.pillar-name small{display:block;font-size:10px;color:var(--dim);font-weight:500;letter-spacing:.04em}
.bar{flex:1;height:8px;background:var(--raise);border-radius:6px;overflow:hidden;border:1px solid var(--line)}
.bar .fill{height:100%;border-radius:6px;transition:width .25s ease}
.pillar-fig{text-align:right;min-width:188px;display:flex;align-items:center;gap:8px;justify-content:flex-end}
.pillar-fig .actual{font-family:var(--mono);font-weight:600;font-size:13px}
.pillar-fig .of{color:var(--dim);font-size:12px}
.tgt-in{width:74px;background:var(--panel2);border:1px solid var(--line2);border-radius:7px;color:var(--hi);font-family:var(--mono);font-weight:600;text-align:right;font-size:13px;padding:4px 6px;outline:none}
.tgt-in:focus{border-color:var(--blue)}
.gap{font-size:11px;font-weight:600;min-width:84px;text-align:right}
.gap.under{color:var(--green)} .gap.over{color:var(--red)}

.sections{display:none;background:var(--panel2)}
.pillar.open .sections{display:block}
.section{padding:4px 18px}
.sec-h{display:flex;align-items:center;gap:8px;padding:9px 0 5px}
.sec-h .nm{font-size:11px;letter-spacing:.09em;text-transform:uppercase;color:var(--mid);font-weight:600}
.sec-h .st{margin-left:auto;font-family:var(--mono);font-size:12px;color:var(--mid);font-weight:600}
table.items{width:100%;border-collapse:collapse}
table.items td{padding:5px 6px;border-bottom:1px solid var(--line);vertical-align:middle}
table.items tr:last-child td{border-bottom:none}
.it-name{font-size:13px;width:36%}
.it-name.empty{color:var(--dim);font-style:italic}
td.it-pay,td.it-to{width:21%}
.mini{background:var(--panel);border:1px solid var(--line2);color:var(--mid);border-radius:7px;padding:5px 7px;font-size:12px;width:100%;outline:none}
.mini:focus{border-color:var(--blue);color:var(--hi)}
.mini.cc{color:var(--violet);border-color:var(--violet-line);background:var(--violet-bg)}
.it-amt{width:19%;text-align:right}
.amt-in{background:transparent;border:none;border-bottom:1px dashed var(--line2);color:var(--hi);font-family:var(--mono);font-weight:600;font-size:13px;text-align:right;width:100%;outline:none;padding:3px 2px;font-variant-numeric:tabular-nums}
.amt-in:focus{border-bottom-color:var(--blue)}
.amt-in.cc{color:var(--violet)}
.it-name-in{background:transparent;border:none;border-bottom:1px dashed transparent;font-size:13px;color:var(--hi);width:100%;outline:none;padding:2px 0;font-family:var(--sans)}
.it-name-in:focus{border-bottom-color:var(--blue)}
.it-del{width:22px;text-align:center;color:var(--dim);cursor:pointer;font-size:14px;opacity:0;transition:.12s}
tr:hover .it-del{opacity:1}
.it-del:hover{color:var(--red)}
.addrow{padding:6px 18px 12px}
.addrow button{background:transparent;border:1px dashed var(--line2);color:var(--mid);border-radius:8px;padding:6px 12px;font-size:12px;width:100%}
.addrow button:hover{border-color:var(--blue);color:var(--blue)}

.rail{display:flex;flex-direction:column;gap:22px;position:sticky;top:80px}
@media(max-width:980px){.rail{position:static}}
.legend{padding:13px 18px;display:flex;flex-direction:column;gap:8px}
.lg-row{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--mid)}
.lg-row b{color:var(--hi);font-weight:600}
.swatch{width:11px;height:11px;border-radius:3px;flex-shrink:0}
.acct{display:flex;align-items:center;gap:10px;padding:9px 18px;border-bottom:1px solid var(--line)}
.acct:last-child{border-bottom:none}
.acct .nm{font-size:13px;font-weight:500}
.acct .amt{margin-left:auto;font-family:var(--mono);font-weight:600}
.acct.zero{opacity:.4}
.rail-total{display:flex;align-items:center;padding:13px 18px;background:var(--panel2);border-radius:0 0 14px 14px;font-weight:600}
.rail-total .amt{margin-left:auto;font-family:var(--mono);font-size:16px;color:var(--blue)}

.cc-top{padding:16px 18px;background:var(--violet-bg);border-bottom:1px solid var(--violet-line)}
.cc-top .lbl{font-size:10px;letter-spacing:.11em;text-transform:uppercase;color:var(--violet);margin-bottom:3px}
.cc-top .big{font-size:25px;font-weight:700;font-family:var(--mono);color:var(--violet)}
.cc-top .hint{font-size:11px;color:var(--mid);margin-top:4px}
.ccard{padding:12px 18px;border-bottom:1px solid var(--line)}
.ccard-h{display:flex;align-items:baseline;gap:8px;margin-bottom:8px}
.ccard-h .nm{font-weight:600;font-size:13px}
.ccard-h .due{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--mid)}
.alloc{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--mid)}
.alloc input{background:var(--panel);border:1px solid var(--line2);color:var(--hi);border-radius:7px;padding:5px 8px;width:92px;font-family:var(--mono);text-align:right;outline:none;font-size:12px}
.alloc input:focus{border-color:var(--violet)}
.alloc .pay{margin-left:auto;display:flex;gap:5px}
.alloc .pay button{background:var(--panel);border:1px solid var(--line2);color:var(--mid);border-radius:6px;padding:4px 7px;font-size:10px}
.alloc .pay button:hover{border-color:var(--violet);color:var(--violet)}
.cc-foot{padding:13px 18px;display:flex;align-items:center;background:var(--panel2);border-radius:0 0 14px 14px}
.cc-foot .lbl{font-size:12px;color:var(--mid)}
.cc-foot .amt{margin-left:auto;font-family:var(--mono);font-weight:700;font-size:15px}
.cc-foot .amt.neg{color:var(--red)} .cc-foot .amt.pos{color:var(--green)}
.note{font-size:11px;color:var(--dim);padding:10px 18px;line-height:1.5}

.scrim{position:fixed;inset:0;background:rgba(20,30,50,.32);z-index:50;display:none}
.scrim.show{display:block}
.drawer{position:fixed;top:0;right:0;height:100%;width:440px;max-width:92vw;background:var(--bg);z-index:60;transform:translateX(100%);transition:transform .22s ease;display:flex;flex-direction:column;box-shadow:-8px 0 30px rgba(20,30,50,.12)}
.drawer.show{transform:translateX(0)}
.drawer-h{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;background:var(--panel)}
.drawer-h h3{font-size:15px;font-weight:600}
.drawer-h .x{margin-left:auto;background:none;border:none;font-size:20px;color:var(--mid)}
.tabs{display:flex;gap:4px;padding:12px 20px 0;background:var(--panel);border-bottom:1px solid var(--line)}
.tab{padding:8px 14px;border:none;background:none;color:var(--mid);font-size:13px;font-weight:600;border-bottom:2px solid transparent}
.tab.on{color:var(--blue);border-bottom-color:var(--blue)}
.drawer-body{flex:1;overflow:auto;padding:16px 20px}
.drawer-foot{padding:14px 20px;border-top:1px solid var(--line);background:var(--panel)}
.drawer-foot .primary{width:100%;background:var(--blue);color:#fff;border:none;border-radius:9px;padding:11px;font-size:14px;font-weight:600}
.mrow{display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:9px 11px;margin-bottom:8px}
.mrow input.nm{flex:1;border:none;background:none;font-size:13px;font-weight:500;color:var(--hi);outline:none}
.mrow select.ty{border:1px solid var(--line2);border-radius:7px;padding:4px 6px;font-size:11px;color:var(--mid);background:var(--panel2)}
.mrow .pill{font-size:10px;padding:2px 7px;border-radius:20px;font-weight:600}
.pill.cc{background:var(--violet-bg);color:var(--violet)}
.pill.cash{background:var(--blue-bg);color:var(--blue)}
.pill.dc{background:var(--amber-bg);color:var(--amber)}
.mrow .del{background:none;border:none;color:var(--dim);font-size:15px}
.mrow .del:hover{color:var(--red)}
.ccmeta{display:flex;gap:6px;margin:4px 0 10px;padding-left:11px}
.ccmeta input{width:100%;border:1px solid var(--line2);border-radius:7px;padding:5px 7px;font-family:var(--mono);font-size:11px;text-align:right;outline:none}
.ccmeta label{font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);display:block;margin-bottom:2px}
.ccmeta>div{flex:1}
.addbtn{width:100%;border:1px dashed var(--line2);background:var(--panel);color:var(--mid);border-radius:10px;padding:10px;font-size:13px;font-weight:500;margin-top:4px}
.addbtn:hover{border-color:var(--blue);color:var(--blue)}
.drawer-note{font-size:11px;color:var(--dim);line-height:1.5;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
