:root{--accent: oklch(.52 .11 162);--accent-ink: oklch(.98 .01 162);--accent-soft: oklch(.52 .11 162 / .1);--pos: oklch(.55 .13 152);--neg: oklch(.56 .17 25);--warn: oklch(.72 .15 70);--bg: oklch(.975 .004 160);--surface: oklch(1 0 0);--surface-2: oklch(.985 .004 160);--ink: oklch(.24 .015 170);--ink-2: oklch(.44 .012 170);--muted: oklch(.58 .01 170);--line: oklch(.91 .005 170);--line-strong: oklch(.85 .006 170);--radius: 16px;--radius-sm: 10px;--radius-lg: 22px;--shadow: 0 1px 2px oklch(.4 .02 170 / .04), 0 8px 24px oklch(.4 .02 170 / .05);--shadow-sm: 0 1px 2px oklch(.4 .02 170 / .05);--card-border: 1px solid var(--line);--card-shadow: var(--shadow-sm);--pad-card: 22px;--gap: 18px;--row-pad: 14px;--font: "IBM Plex Sans", system-ui, sans-serif;--mono: "IBM Plex Mono", ui-monospace, monospace}[data-accent=blue]{--accent: oklch(.5 .13 250);--accent-soft: oklch(.5 .13 250 / .1)}[data-accent=indigo]{--accent: oklch(.5 .16 285);--accent-soft: oklch(.5 .16 285 / .1)}[data-accent=teal]{--accent: oklch(.55 .1 200);--accent-soft: oklch(.55 .1 200 / .1)}[data-accent=red]{--accent: oklch(.5 .13 25);--accent-soft: oklch(.5 .13 25 / .1)}[data-theme=dark]{--accent-ink: oklch(.99 .005 162);--accent-soft: oklch(.65 .12 162 / .16);--pos: oklch(.7 .14 152);--neg: oklch(.68 .17 25);--warn: oklch(.8 .14 75);--bg: oklch(.18 .01 250);--surface: oklch(.22 .012 250);--surface-2: oklch(.25 .013 250);--ink: oklch(.95 .006 250);--ink-2: oklch(.78 .01 250);--muted: oklch(.62 .012 250);--line: oklch(.32 .012 250);--line-strong: oklch(.4 .014 250);--shadow: 0 1px 2px oklch(0 0 0 / .3), 0 10px 30px oklch(0 0 0 / .35);--shadow-sm: 0 1px 3px oklch(0 0 0 / .3)}[data-theme=dark][data-accent=blue]{--accent-soft: oklch(.6 .13 250 / .16)}[data-theme=dark][data-accent=indigo]{--accent-soft: oklch(.6 .16 285 / .16)}[data-theme=dark][data-accent=teal]{--accent-soft: oklch(.65 .1 200 / .16)}[data-theme=dark][data-accent=red]{--accent-soft: oklch(.6 .13 25 / .16)}[data-density=compact]{--pad-card: 16px;--gap: 12px;--row-pad: 10px;--radius: 12px;--radius-lg: 16px}[data-cards=flat]{--card-border: none;--card-shadow: var(--shadow)}[data-cards=outlined]{--card-border: 1px solid var(--line-strong);--card-shadow: none}*{box-sizing:border-box}html,body,#app{margin:0;height:100%}body{font-family:var(--font);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.45}a{color:inherit;text-decoration:none}.mono{font-family:var(--mono);font-feature-settings:"tnum" 1;letter-spacing:-.01em}button{font-family:inherit;cursor:pointer}input,select{font-family:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:10px;border:3px solid var(--bg)}.app{display:flex;min-height:100vh}.sidebar{width:244px;flex:none;position:sticky;top:0;height:100vh;background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:20px 14px;gap:6px;z-index:20}.brand{display:flex;align-items:center;gap:11px;padding:6px 10px 18px}.brand-mark{width:34px;height:34px;border-radius:9px;flex:none;background:var(--accent);color:var(--accent-ink);display:grid;place-items:center;font-weight:700;font-size:17px;box-shadow:inset 0 0 0 1px #ffffff1f}.brand-name{font-weight:600;font-size:15px;letter-spacing:-.01em}.brand-sub{font-size:11.5px;color:var(--muted)}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--ink-2);border:none;background:none;width:100%;text-align:left;font-size:14.5px;font-weight:500;transition:background .15s,color .15s}.nav-item:hover{background:var(--surface-2);color:var(--ink)}.nav-item.active{background:var(--accent-soft);color:var(--accent);font-weight:600}.nav-item.active svg{color:var(--accent)}.nav-badge{margin-left:auto;font-size:11px;font-weight:600;background:var(--neg);color:#fff;min-width:19px;height:19px;border-radius:10px;padding:0 5px;display:grid;place-items:center}.sidebar-foot{margin-top:auto;padding-top:12px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:8px}.switch-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:4px 10px}.member-switch{display:flex;flex-direction:column;gap:2px}.member-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);border:none;background:none;width:100%;color:var(--ink-2);font-size:13.5px;font-weight:500}.member-row:hover{background:var(--surface-2)}.member-row.active{background:var(--surface-2);color:var(--ink)}.member-row.active .dotcheck{background:var(--accent);border-color:var(--accent)}.dotcheck{width:16px;height:16px;border-radius:50%;border:2px solid var(--line-strong);margin-left:auto}.avatar{display:inline-grid;place-items:center;border-radius:50%;color:#fff;font-weight:600;flex:none;line-height:1}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:15;background:oklch(from var(--bg) l c h / .82);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;padding:14px 28px}.page-title{font-size:20px;font-weight:600;letter-spacing:-.02em}.page-sub{font-size:12.5px;color:var(--muted);margin-top:1px}.topbar-spacer{flex:1}.avatars-filter{display:flex;align-items:center;gap:6px}.avatar-btn{border:2px solid transparent;border-radius:50%;padding:0;background:none;display:grid;place-items:center;transition:border-color .15s,transform .1s}.avatar-btn:hover{transform:translateY(-1px)}.avatar-btn.active{border-color:var(--accent)}.avatar-all{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:var(--surface-2);border:1px solid var(--line);color:var(--ink-2);font-size:11px;font-weight:600}.month-nav{display:flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:3px;box-shadow:var(--shadow-sm)}.month-nav button{border:none;background:none;width:30px;height:30px;border-radius:50%;color:var(--ink-2);display:grid;place-items:center}.month-nav button:hover{background:var(--surface-2);color:var(--ink)}.month-label{font-size:13.5px;font-weight:600;padding:0 10px;min-width:116px;text-align:center;text-transform:capitalize}.btn{display:inline-flex;align-items:center;gap:8px;border-radius:var(--radius-sm);padding:10px 16px;font-size:14px;font-weight:600;border:1px solid transparent;transition:filter .15s,background .15s,transform .05s}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--accent-ink);box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){filter:brightness(1.06)}.btn-ghost{background:var(--surface);color:var(--ink);border-color:var(--line)}.btn-ghost:hover{background:var(--surface-2)}.btn-icon{padding:9px}.btn-block{width:100%;justify-content:center}.content{padding:26px 28px 60px;max-width:1240px;width:100%;margin:0 auto}.content.narrow{max-width:980px}.card{background:var(--surface);border:var(--card-border);border-radius:var(--radius);box-shadow:var(--card-shadow);padding:var(--pad-card)}.card.pad0{padding:0;overflow:hidden}.card-head{display:flex;align-items:center;gap:10px;margin-bottom:16px}.card-title{font-size:14.5px;font-weight:600;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}.card-title .ic{color:var(--muted)}.card-action{margin-left:auto;font-size:12.5px;font-weight:600;color:var(--accent);background:none;border:none;padding:4px 6px;border-radius:6px}.card-action:hover{background:var(--accent-soft)}.grid{display:grid;gap:var(--gap)}.grid-kpi{grid-template-columns:repeat(4,1fr)}.grid-2{grid-template-columns:1.35fr 1fr}.grid-2e{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:repeat(3,1fr)}.stack{display:flex;flex-direction:column;gap:var(--gap)}.mt{margin-top:var(--gap)}.kpi{display:flex;flex-direction:column;gap:10px}.kpi-top{display:flex;align-items:center;gap:9px;color:var(--muted);font-size:12.5px;font-weight:500}.kpi-ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:var(--surface-2);color:var(--ink-2)}.kpi-val{font-size:27px;font-weight:600;letter-spacing:-.02em}.kpi-foot{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:5px}.delta{display:inline-flex;align-items:center;gap:2px;font-weight:600;font-size:12px}.delta.up{color:var(--pos)}.delta.down{color:var(--neg)}.money{font-family:var(--mono);font-feature-settings:"tnum" 1;font-weight:500}.money.pos{color:var(--pos)}.money.neg{color:var(--neg)}.pill{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:999px;line-height:1.4;white-space:nowrap}.pill-neutral{background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line)}.pill-pos{background:oklch(from var(--pos) l c h / .13);color:var(--pos)}.pill-neg{background:oklch(from var(--neg) l c h / .13);color:var(--neg)}.pill-warn{background:oklch(from var(--warn) l c h / .16);color:oklch(from var(--warn) calc(l - .08) c h)}.pill-accent{background:var(--accent-soft);color:var(--accent)}[data-theme=dark] .pill-warn{color:var(--warn)}.rows{display:flex;flex-direction:column}.row{display:flex;align-items:center;gap:13px;padding:var(--row-pad) var(--pad-card);border-bottom:1px solid var(--line)}.row:last-child{border-bottom:none}.row:hover{background:var(--surface-2)}.row-ic{width:38px;height:38px;border-radius:10px;flex:none;display:grid;place-items:center}.row-main{min-width:0;flex:1}.row-title{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-meta{font-size:12px;color:var(--muted);margin-top:1px;display:flex;align-items:center;gap:7px;flex-wrap:wrap}.row-right{margin-left:auto;text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:3px}.dot{width:5px;height:5px;border-radius:50%;background:var(--line-strong)}.cat-ic{color:#fff}.section-label{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:16px var(--pad-card) 7px;display:flex;align-items:center;gap:8px}.section-label .count{color:var(--line-strong);font-weight:600}.ccard{border-radius:18px;padding:20px;color:#fff;position:relative;overflow:hidden;box-shadow:0 10px 30px #0b172340;min-height:168px;display:flex;flex-direction:column}.ccard:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(120% 90% at 110% -10%,oklch(1 0 0 / .16),transparent 55%);pointer-events:none}.ccard-top{display:flex;justify-content:space-between;align-items:flex-start}.ccard-name{font-weight:600;font-size:15px;white-space:nowrap}.ccard-bank{font-size:11.5px;opacity:.8}.ccard-chip{width:34px;height:25px;border-radius:6px;background:linear-gradient(135deg,#e2cc91,#bb9951);opacity:.9}.ccard-num{font-family:var(--mono);letter-spacing:.12em;font-size:14px;margin-top:auto;opacity:.92}.ccard-foot{display:flex;justify-content:space-between;align-items:flex-end;margin-top:12px}.ccard-label{font-size:10.5px;opacity:.75;text-transform:uppercase;letter-spacing:.05em}.ccard-val{font-family:var(--mono);font-weight:600;font-size:15px}.chart-svg{width:100%;height:auto;display:block;overflow:visible}.chart-label{fill:var(--muted);font-size:11px;font-family:var(--font);font-weight:500}.donut-wrap{position:relative;flex:none}.donut-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.donut-center-top{font-size:11px;color:var(--muted);font-weight:500}.donut-center-main{font-size:19px;font-weight:600;letter-spacing:-.02em}.donut-center-sub{font-size:11.5px;color:var(--muted)}.legend{display:flex;flex-direction:column;gap:9px}.legend-item{display:flex;align-items:center;gap:9px;font-size:13px}.legend-swatch{width:10px;height:10px;border-radius:3px;flex:none}.legend-name{color:var(--ink-2)}.legend-val{margin-left:auto;font-family:var(--mono);font-weight:500;font-size:12.5px}.legend-pct{color:var(--muted);font-size:11.5px;width:38px;text-align:right}.chart-legend-inline{display:flex;gap:18px}.cli{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--ink-2);font-weight:500}.cli-swatch{width:10px;height:10px;border-radius:3px}.pbar{width:100%;border-radius:999px;overflow:hidden}.pbar-fill{height:100%;border-radius:999px;transition:width .4s ease}.budget-row{padding:14px var(--pad-card);border-bottom:1px solid var(--line)}.budget-row:last-child{border-bottom:none}.budget-head{display:flex;align-items:center;gap:10px;margin-bottom:9px}.budget-name{font-size:13.5px;font-weight:500}.budget-fig{margin-left:auto;font-size:12.5px;color:var(--muted)}.budget-fig b{font-family:var(--mono);color:var(--ink);font-weight:600}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f171f6b;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:flex-end;justify-content:center;z-index:60;padding:0;animation:fade .15s}@keyframes fade{0%{opacity:0}}@media(min-width:720px){.modal-bg{align-items:center;padding:24px}}.modal{background:var(--surface);width:100%;max-width:480px;border-radius:22px 22px 0 0;box-shadow:var(--shadow);animation:slideup .22s cubic-bezier(.2,.8,.2,1);max-height:92vh;overflow-y:auto}@media(min-width:720px){.modal{border-radius:22px;animation:pop .18s ease}}@keyframes slideup{0%{transform:translateY(40px);opacity:.6}}@keyframes pop{0%{transform:scale(.97);opacity:0}}.modal-head{display:flex;align-items:center;padding:18px 20px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--surface);z-index:1}.modal-title{font-size:16px;font-weight:600}.modal-x{margin-left:auto;border:none;background:var(--surface-2);width:32px;height:32px;border-radius:50%;display:grid;place-items:center;color:var(--ink-2)}.modal-x:hover{background:var(--line)}.modal-body{padding:20px;display:flex;flex-direction:column;gap:16px}.modal-foot{padding:16px 20px;border-top:1px solid var(--line);display:flex;gap:10px;position:sticky;bottom:0;background:var(--surface)}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:12.5px;font-weight:600;color:var(--ink-2)}.field-hint{font-size:11.5px;color:var(--muted)}.field-error{font-size:12px;color:var(--neg);font-weight:500}.input,.select{width:100%;border:1px solid var(--line-strong);background:var(--surface-2);color:var(--ink);border-radius:10px;padding:11px 13px;font-size:14.5px;font-family:inherit;transition:border-color .15s,box-shadow .15s}.input:focus,.select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.input.mono{font-family:var(--mono);font-size:17px;font-weight:600}.input-money{display:flex;align-items:center;gap:8px;border:1px solid var(--line-strong);background:var(--surface-2);border-radius:10px;padding:0 13px;transition:border-color .15s,box-shadow .15s}.input-money:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.input-money .prefix{color:var(--muted);font-family:var(--mono);font-weight:600;font-size:16px}.input-money input{border:none;background:none;outline:none;width:100%;padding:11px 0;font-family:var(--mono);font-size:17px;font-weight:600;color:var(--ink)}.seg{display:flex;gap:6px}.seg-btn{flex:1;padding:11px;border-radius:10px;border:1px solid var(--line-strong);background:var(--surface-2);font-size:13.5px;font-weight:600;color:var(--ink-2);display:flex;align-items:center;justify-content:center;gap:6px}.seg-btn.on-pos{border-color:var(--pos);background:oklch(from var(--pos) l c h / .12);color:var(--pos)}.seg-btn.on-neg{border-color:var(--neg);background:oklch(from var(--neg) l c h / .12);color:var(--neg)}.seg-btn.on-accent{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.chips{display:flex;flex-wrap:wrap;gap:7px}.chip{display:inline-flex;align-items:center;gap:6px;padding:7px 11px;border-radius:999px;border:1px solid var(--line-strong);background:var(--surface-2);font-size:12.5px;font-weight:500;color:var(--ink-2)}.chip.on{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.chip-swatch{width:10px;height:10px;border-radius:3px}.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:var(--gap)}.search{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:9px 13px;flex:1;min-width:180px;box-shadow:var(--shadow-sm)}.search input{border:none;background:none;outline:none;font-family:inherit;font-size:14px;color:var(--ink);width:100%}.search input::placeholder{color:var(--muted)}.filter-chip{display:inline-flex;align-items:center;gap:6px;padding:9px 13px;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface);font-size:13px;font-weight:500;color:var(--ink-2);box-shadow:var(--shadow-sm)}.filter-chip.on{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.empty{text-align:center;padding:50px 20px;color:var(--muted)}.empty svg{margin:0 auto 12px;opacity:.5}.empty-title{font-size:15px;font-weight:600;color:var(--ink-2);margin-bottom:4px}.fab,.bottomnav{display:none}.auth{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:100%;max-width:400px;background:var(--surface);border:var(--card-border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:32px 28px}.auth-brand{display:flex;align-items:center;gap:11px;margin-bottom:22px}.auth-title{font-size:21px;font-weight:600;letter-spacing:-.02em}.auth-sub{font-size:13px;color:var(--muted);margin-top:2px;margin-bottom:22px}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-foot{margin-top:18px;font-size:13px;color:var(--muted);text-align:center}.auth-foot a{color:var(--accent);font-weight:600}.auth-alert{background:oklch(from var(--neg) l c h / .1);color:var(--neg);border:1px solid oklch(from var(--neg) l c h / .25);border-radius:10px;padding:10px 13px;font-size:13px;font-weight:500}.spinner{width:30px;height:30px;border-radius:50%;border:3px solid var(--line);border-top-color:var(--accent);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen{min-height:100vh;display:grid;place-items:center}@media(max-width:1100px){.grid-kpi{grid-template-columns:repeat(2,1fr)}}@media(max-width:900px){.grid-2,.grid-2e,.grid-3{grid-template-columns:1fr}}@media(max-width:760px){.sidebar{display:none}.topbar{padding:12px 16px}.content{padding:16px 14px 96px}.kpi-val{font-size:23px}.page-title{font-size:17px}.fab{display:grid;place-items:center;position:fixed;right:18px;bottom:84px;width:56px;height:56px;border-radius:18px;background:var(--accent);color:var(--accent-ink);border:none;z-index:40;box-shadow:0 8px 24px #1a755166}.bottomnav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:40;background:oklch(from var(--surface) l c h / .92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding:8px 6px calc(8px + env(safe-area-inset-bottom));justify-content:space-around}.bn-item{display:flex;flex-direction:column;align-items:center;gap:3px;border:none;background:none;color:var(--muted);font-size:10.5px;font-weight:500;padding:4px 10px;border-radius:10px;flex:1;position:relative}.bn-item.active{color:var(--accent)}.bn-badge{position:absolute;top:0;right:50%;transform:translate(16px);font-size:9px;font-weight:700;background:var(--neg);color:#fff;min-width:15px;height:15px;border-radius:8px;padding:0 4px;display:grid;place-items:center}.grid-kpi{grid-template-columns:repeat(2,1fr);gap:12px}.month-label{min-width:92px;font-size:12.5px}}@media(max-width:420px){.grid-kpi{grid-template-columns:1fr 1fr}}
