:root{--bg:#f5f4ef;--bg-elevated:#fff;--bg-subtle:#edebe4;--bg-inverse:#0a0a0a;--ink-1:#0a0a0a;--ink-2:#4a4a48;--ink-3:#8b8b85;--ink-4:#c8c6be;--border:#e4e1d8;--border-strong:#0a0a0a;--accent:#b8ff5b;--accent-ink:#0a0a0a;--accent-deep:#4b9b3f;--accent-soft:#e8ffc9;--income:#4b9b3f;--income-soft:#e8ffc9;--expense:#1a1a1a;--danger:#d64545;--danger-soft:#fce8e8;--warn:#c08a1a;--warn-soft:#fff3d1;--warn-ink:#92400e;--cat-food:#ffd6b8;--cat-food-ink:#8a4a1f;--cat-transport:#c7e0ff;--cat-transport-ink:#1a4b88;--cat-home:#d4f0d4;--cat-home-ink:#2e6b3a;--cat-fun:#e8d1ff;--cat-fun-ink:#5a2e8a;--cat-health:#ffd1dc;--cat-health-ink:#8a2e4b;--cat-other:#e4e1d8;--cat-other-ink:#4a4a48;--font-sans:"Inter", -apple-system, system-ui, sans-serif;--font-display:"Inter", -apple-system, system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-7:32px;--sp-8:48px;--sp-9:64px;--r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:20px;--r-pill:999px;--shadow-sm:0 1px 0 #0a0a0a0a;--shadow-md:0 4px 16px #0a0a0a0f;--shadow-lg:0 12px 40px #0a0a0a1a;--ease:cubic-bezier(.2, .8, .2, 1);--dur-fast:.12s;--dur-base:.2s;--dur-slow:.36s}*,:before,:after{box-sizing:border-box}html,body{background:var(--bg);height:100%;margin:0}body{font-family:var(--font-sans);color:var(--ink-1);font-feature-settings:"ss01", "cv11";-webkit-font-smoothing:antialiased;min-height:100vh;display:flex}button{font:inherit;cursor:pointer;color:inherit;background:0 0;border:none}a{color:inherit;text-decoration:none}input,select,textarea{font:inherit;color:inherit}#root{flex:1;width:100%;min-height:100vh;display:flex}.t-display-xl{font-family:var(--font-display);letter-spacing:-.04em;font-feature-settings:"ss01","cv11","tnum";font-size:72px;font-weight:800;line-height:.95}.t-display-lg{font-family:var(--font-display);letter-spacing:-.04em;font-feature-settings:"ss01","cv11","tnum";font-size:56px;font-weight:800;line-height:1}.t-display-md{font-family:var(--font-display);letter-spacing:-.035em;font-feature-settings:"ss01","cv11";font-size:40px;font-weight:800;line-height:1.05}.t-display-sm{font-family:var(--font-display);letter-spacing:-.03em;font-size:28px;font-weight:800;line-height:1.1}.t-h1{letter-spacing:-.02em;font-size:32px;font-weight:700;line-height:1.15}.t-h2{letter-spacing:-.01em;font-size:24px;font-weight:700;line-height:1.2}.t-h3{font-size:18px;font-weight:600;line-height:1.3}.t-h4{font-size:15px;font-weight:600;line-height:1.35}.t-body{font-size:15px;line-height:1.5}.t-body-sm{font-size:13px;line-height:1.5}.t-label{letter-spacing:.02em;color:var(--ink-3);font-size:12px;font-weight:500;line-height:1.3}.t-label-up,.lbl-up{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font-size:11px;font-weight:600;line-height:1.3}.t-mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:13px}.t-num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.app-layout{flex:1;width:100%;min-height:100vh;display:flex}.main-area{flex-direction:column;flex:1;min-height:100vh;margin-left:240px;display:flex}.top-bar{z-index:20;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#f5f4efd9;justify-content:space-between;align-items:center;padding:16px 32px;display:flex;position:sticky;top:0}.top-bar h1{letter-spacing:-.02em;margin:0;font-size:22px;font-weight:700}.top-bar .actions{align-items:center;gap:10px;display:flex}.content{flex:1;max-width:1200px;padding:28px 32px}.sidebar{background:var(--bg);border-right:1px solid var(--border);z-index:50;flex-direction:column;width:240px;padding:20px 14px;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:14px;padding:6px 8px 20px;display:flex}.sidebar-brand img{width:34px;height:34px}.brand-name{letter-spacing:-.01em;font-size:15px;font-weight:700}.brand-name em{color:var(--accent-deep);font-style:normal}.brand-sub{color:var(--ink-3);margin-top:1px;font-size:10px}.sidebar-nav{flex-direction:column;flex:1;gap:1px;display:flex}.sidebar-nav a{border-radius:var(--r-md);color:var(--ink-2);cursor:pointer;transition:background var(--dur-fast);align-items:center;gap:10px;padding:9px 10px;font-size:13.5px;font-weight:500;display:flex}.sidebar-nav a svg{stroke-width:2px;width:17px;height:17px;color:var(--ink-3);flex-shrink:0}.sidebar-nav a:hover{background:var(--bg-subtle);color:var(--ink-1)}.sidebar-nav a.active{background:var(--ink-1);color:var(--bg)}.sidebar-nav a.active svg{color:var(--accent)}.sidebar-separator{background:var(--border);height:1px;margin:10px 12px}.sidebar-user{border-top:1px solid var(--border);align-items:center;gap:10px;margin-top:12px;padding:12px 8px;display:flex}.sidebar-avatar{background:var(--accent);width:32px;height:32px;color:var(--ink-1);border-radius:999px;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:12.5px;font-weight:600}.sidebar-user-email{color:var(--ink-3);font-size:10.5px}.sidebar-logout{color:var(--ink-3);cursor:pointer;text-align:left;background:0 0;border:none;margin-top:2px;padding:0;font-size:10.5px}.sidebar-logout:hover{color:var(--ink-1)}.btn{border-radius:var(--r-md);transition:all var(--dur-base) var(--ease);cursor:pointer;border:1px solid #0000;align-items:center;gap:7px;padding:9px 16px;font-size:13px;font-weight:600;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{stroke-width:2.2px;width:15px;height:15px}.btn-primary{background:var(--ink-1);color:var(--bg)}.btn-primary:hover:not(:disabled){background:#2a2a2a}.btn-accent{background:var(--accent);color:var(--ink-1)}.btn-accent:hover:not(:disabled){background:#a5f04a}.btn-ghost{background:var(--bg-elevated);color:var(--ink-1);border-color:var(--border)}.btn-ghost:hover:not(:disabled){border-color:var(--ink-2)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b83838}.btn-sm{padding:6px 12px;font-size:12px}.card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px}.card h3{letter-spacing:-.01em;justify-content:space-between;align-items:center;margin:0 0 16px;font-size:15px;font-weight:600;display:flex}.card h3 a{color:var(--ink-3);font-size:12px;font-weight:500}.card h3 a:hover{color:var(--ink-1)}.pill{border-radius:var(--r-sm);background:var(--bg-subtle);color:var(--ink-2);border:1px solid var(--border);align-items:center;gap:4px;padding:3px 9px;font-size:10.5px;font-weight:500;display:inline-flex}.pill.ok{color:#166534;background:#dcfce7;border:none}.pill.warn{background:var(--warn-soft);color:var(--warn-ink);border:none}.pill.on{background:var(--ink-1);color:var(--bg);border:none}.pill.danger{background:var(--danger-soft);color:var(--danger);border:none}.empty-state{background:var(--bg-elevated);border:1px dashed var(--border);border-radius:var(--r-lg);text-align:center;color:var(--ink-3);padding:40px 24px}.empty-state svg{width:32px;height:32px;margin-bottom:12px}.loading{color:var(--ink-3);text-align:center;padding:24px;font-size:13px}.error-msg{color:var(--danger);background:var(--danger-soft);border-radius:var(--r-md);padding:12px;font-size:13px}.bottom-nav{background:var(--bg-elevated);border-top:1px solid var(--border);z-index:50;justify-content:space-around;padding:10px 16px;display:none;position:fixed;bottom:0;left:0;right:0}.bottom-nav .nav-item{color:var(--ink-3);flex-direction:column;align-items:center;gap:2px;padding:4px;font-size:10px;font-weight:500;display:flex}.bottom-nav .nav-item svg{width:20px;height:20px}.bottom-nav .nav-item.active{color:var(--ink-1)}.bottom-nav .nav-item.active svg{color:var(--accent-deep)}.bottom-nav .fab{background:var(--accent);width:48px;height:48px;color:var(--ink-1);border-radius:999px;justify-content:center;align-items:center;margin-top:-16px;display:flex}.bottom-nav .fab svg{width:22px;height:22px}.period{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:22px;display:flex}.period .chev{border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-elevated);cursor:pointer;width:32px;height:32px;color:var(--ink-2);justify-content:center;align-items:center;display:flex}.period .chev:hover:not(:disabled){border-color:var(--ink-2);color:var(--ink-1)}.period .chev:disabled{opacity:.4;cursor:not-allowed}.period .chev svg{width:15px;height:15px}.period .m-name{letter-spacing:-.01em;font-size:17px;font-weight:600}.month-pills{background:var(--bg-subtle);border-radius:var(--r-md);gap:4px;margin-left:auto;padding:3px;display:flex}.month-pills button{color:var(--ink-2);border-radius:calc(var(--r-md) - 3px);cursor:pointer;transition:all var(--dur-fast);padding:6px 14px;font-size:12px;font-weight:500}.month-pills button.on{background:var(--bg-elevated);color:var(--ink-1);box-shadow:var(--shadow-sm)}.hero-grid{grid-template-columns:1.4fr 1fr 1fr;gap:14px;margin-bottom:18px;display:grid}.hero-card{background:var(--ink-1);color:var(--bg);border-radius:var(--r-xl);flex-direction:column;justify-content:space-between;min-height:170px;padding:24px;display:flex}.hero-card .lbl-up{color:#ffffff80}.hero-card .big{font-family:var(--font-display);letter-spacing:-.04em;font-feature-settings:"ss01","cv11","tnum";margin:6px 0 0;font-size:56px;font-weight:800;line-height:.95}.hero-card .big .cents{color:#ffffff80;margin-left:4px;font-size:26px}.hero-card .delta{color:#ffffffb3;align-items:center;gap:6px;margin-top:10px;font-size:12px;display:inline-flex}.hero-card .delta svg{width:12px;height:12px;color:var(--accent)}.hero-card .cta{background:var(--accent);color:var(--ink-1);border-radius:var(--r-md);cursor:pointer;align-self:flex-start;align-items:center;gap:7px;margin-top:16px;padding:9px 14px;font-size:13px;font-weight:600;display:inline-flex}.hero-card .cta svg{width:14px;height:14px}.stat{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);flex-direction:column;justify-content:space-between;padding:18px;display:flex}.stat .lbl-up{margin-bottom:8px}.stat .num{font-family:var(--font-display);letter-spacing:-.035em;color:var(--ink-1);font-feature-settings:"ss01","cv11","tnum";font-size:34px;font-weight:800;line-height:1}.stat .sub{color:var(--ink-3);margin-top:6px;font-size:11px}.stat .sub.up{color:var(--danger)}.stat .sub.ok{color:var(--income)}.two-col{grid-template-columns:1.3fr 1fr;gap:18px;margin-bottom:18px;display:grid}.cat-row{border-bottom:1px solid var(--bg-subtle);align-items:center;gap:12px;padding:10px 0;display:flex}.cat-row:last-child{border-bottom:none}.cat-ico{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.cat-ico svg{stroke-width:2px;width:18px;height:18px}.cat-info{flex:1;min-width:0}.cat-name{font-size:13.5px;font-weight:600}.cat-bar-bg{background:var(--bg-subtle);border-radius:2px;height:4px;margin-top:6px;overflow:hidden}.cat-bar{background:var(--ink-1);border-radius:2px;height:100%}.cat-amt{text-align:right;flex-shrink:0}.cat-amount{font-variant-numeric:tabular-nums;font-size:13.5px;font-weight:600}.cat-pct{color:var(--ink-3);margin-top:1px;font-size:10.5px}.trend{align-items:flex-end;gap:8px;height:120px;padding-top:10px;display:flex}.tcol{flex-direction:column;flex:1;align-items:center;height:100%;display:flex}.tbar{background:var(--bg-subtle);border-radius:4px 4px 0 0;width:100%;transition:height .5s}.tbar.on{background:var(--accent)}.tlbl{color:var(--ink-3);margin-top:8px;font-size:10.5px;font-weight:500}.tlbl.on{color:var(--ink-1);font-weight:600}.acc-list{flex-direction:column;gap:8px;display:flex}.acc{background:var(--bg-subtle);border-radius:var(--r-md);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.acc-name{font-size:13px;font-weight:600}.acc-bank{color:var(--ink-3);font-size:11px}.acc-amount{font-variant-numeric:tabular-nums;font-size:15px;font-weight:600}.add-wrap{grid-template-columns:1fr 360px;gap:22px;display:grid}.form-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden}.amt-display{background:var(--ink-1);color:var(--bg);text-align:center;padding:36px 28px}.amt-display .lbl-up{color:#ffffff80;margin-bottom:10px}.amt-display .big{font-family:var(--font-display);letter-spacing:-.045em;font-feature-settings:"ss01","cv11","tnum";font-size:72px;font-weight:800;line-height:.95}.amt-display .big .dim{color:#ffffff4d}.amt-display .cur-btn{color:#fffc;cursor:pointer;background:#ffffff14;border-radius:999px;margin-top:8px;padding:4px 12px;font-size:11px;display:inline-block}.amt-display input.amt-input{font-family:var(--font-display);letter-spacing:-.045em;font-feature-settings:"ss01","cv11","tnum";color:var(--bg);text-align:center;width:100%;caret-color:var(--accent);background:0 0;border:none;outline:none;font-size:72px;font-weight:800;line-height:.95}.amt-display input.amt-input::placeholder{color:#ffffff4d}.form-body{padding:24px 26px}.seg{background:var(--bg-subtle);border-radius:var(--r-md);gap:2px;margin-bottom:22px;padding:3px;display:flex}.seg button{border-radius:calc(var(--r-md) - 3px);color:var(--ink-2);cursor:pointer;flex:1;justify-content:center;align-items:center;gap:6px;padding:9px;font-size:13px;font-weight:600;display:inline-flex}.seg button svg{width:14px;height:14px}.seg button.on{background:var(--bg-elevated);color:var(--ink-1);box-shadow:var(--shadow-sm)}.field{margin-bottom:14px}.field-row{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px;display:grid}.field label,.field-label{color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px;font-size:11px;font-weight:600;display:block}.inp{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-md);color:var(--ink-1);cursor:text;transition:all var(--dur-base) var(--ease);align-items:center;gap:9px;width:100%;padding:11px 14px;font-size:14px;display:flex}.inp svg{width:15px;height:15px;color:var(--ink-3);flex-shrink:0}.inp:hover{border-color:var(--ink-3)}.inp:focus-within,.inp.focused{border-color:var(--ink-1);box-shadow:0 0 0 3px var(--accent-soft)}.inp.empty{color:var(--ink-4)}.inp .cv{color:var(--ink-3);margin-left:auto}.inp input,.inp select,.inp textarea{color:var(--ink-1);font:inherit;background:0 0;border:none;outline:none;flex:1;min-width:0}.inp input::placeholder{color:var(--ink-4)}.inp select{cursor:pointer;appearance:none}.save{background:var(--accent);width:100%;color:var(--ink-1);border-radius:var(--r-md);cursor:pointer;transition:all var(--dur-base) var(--ease);border:none;justify-content:center;align-items:center;gap:8px;margin-top:8px;padding:14px;font-size:14px;font-weight:600;display:inline-flex}.save:hover:not(:disabled){background:#a5f04a}.save:disabled{opacity:.5;cursor:not-allowed}.save svg{width:15px;height:15px}.recent{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);height:fit-content;padding:22px}.recent h3{margin:0 0 14px;font-size:14px;font-weight:600}.recent-row{border-bottom:1px solid var(--bg-subtle);align-items:center;gap:12px;padding:10px 0;display:flex}.recent-row:last-child{border-bottom:none}.recent-info{flex:1;min-width:0}.recent-name{font-size:13px;font-weight:600}.recent-meta{color:var(--ink-3);margin-top:1px;font-size:11px}.recent-amt{font-variant-numeric:tabular-nums;font-size:13.5px;font-weight:600}.tx-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.tx-search{background:var(--bg-elevated);border:1.5px solid var(--border);border-radius:var(--r-md);flex:1;align-items:center;gap:8px;min-width:220px;padding:10px 14px;font-size:13.5px;display:flex}.tx-search:focus-within{border-color:var(--ink-1)}.tx-search svg{width:15px;height:15px;color:var(--ink-3)}.tx-search input{color:var(--ink-1);font:inherit;background:0 0;border:none;outline:none;flex:1}.tx-search input::placeholder{color:var(--ink-3)}.tx-sel{border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--bg-elevated);color:var(--ink-1);cursor:pointer;appearance:none;align-items:center;gap:6px;padding:10px 12px;font-size:12.5px;display:inline-flex}.tx-sel:hover{border-color:var(--ink-2)}.tx-sel svg{width:13px;height:13px;color:var(--ink-3)}.tx-stats{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);color:var(--ink-2);flex-wrap:wrap;gap:24px;margin-bottom:16px;padding:14px 18px;font-size:12.5px;display:flex}.tx-stats .val{color:var(--ink-1);font-size:18px;font-weight:800;font-family:var(--font-display);letter-spacing:-.02em;font-feature-settings:"tnum";margin-top:2px;display:block}.tx-list{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.tx-head{background:var(--bg-subtle);color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;grid-template-columns:80px 44px 1fr 160px 110px 130px;gap:12px;padding:10px 18px;font-size:10.5px;font-weight:600;display:grid}.tx-head .right{text-align:right}.tx{border-top:1px solid var(--border);cursor:pointer;transition:background var(--dur-fast);grid-template-columns:80px 44px 1fr 160px 110px 130px;align-items:center;gap:12px;padding:12px 18px;display:grid}.tx:hover{background:var(--bg-subtle)}.tx-date{color:var(--ink-2);font-size:12px;font-family:var(--font-mono)}.tx-ico{border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.tx-ico svg{stroke-width:2px;width:18px;height:18px}.tx-name{font-size:13.5px;font-weight:600}.tx-raw{color:var(--ink-3);margin-top:1px;font-size:11px}.tx-cat{color:var(--ink-2);align-items:center;gap:6px;font-size:12px;display:inline-flex}.tx-cat .dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.tx-src{background:var(--bg-subtle);color:var(--ink-2);border-radius:6px;padding:3px 9px;font-size:10.5px;font-weight:500;display:inline-block}.tx-amt{text-align:right;font-variant-numeric:tabular-nums;color:var(--ink-1);font-size:14px;font-weight:600}.tx-amt.in{color:var(--income)}.pagination{color:var(--ink-3);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-top:16px;font-size:12px;display:flex}.page-btns{gap:4px;display:flex}.pgb{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg-elevated);color:var(--ink-2);cursor:pointer;justify-content:center;align-items:center;padding:6px 10px;font-size:12px;display:inline-flex}.pgb:hover:not(:disabled){border-color:var(--ink-2);color:var(--ink-1)}.pgb.on{background:var(--ink-1);color:var(--bg);border-color:var(--ink-1)}.pgb:disabled{opacity:.4;cursor:not-allowed}.pgb svg{width:12px;height:12px}.upload-hero{grid-template-columns:1fr 360px;gap:24px;display:grid}.upload-drop{border:2px dashed var(--border);background:var(--bg-elevated);text-align:center;cursor:pointer;border-radius:18px;flex-direction:column;align-items:center;padding:48px 32px;transition:all .15s;display:flex}.upload-drop:hover,.upload-drop.dragging{border-color:var(--accent);background:var(--accent-soft)}.upload-icon{background:var(--accent-soft);width:64px;height:64px;color:var(--accent-deep);border-radius:18px;justify-content:center;align-items:center;margin-bottom:16px;display:flex}.upload-icon svg{width:30px;height:30px}.upload-title{letter-spacing:-.3px;font-size:18px;font-weight:600}.upload-sub{color:var(--ink-3);max-width:380px;margin-top:6px;font-size:13px}.upload-supported{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:center;gap:6px 14px;width:100%;margin-top:24px;padding-top:18px;display:flex}.upload-supported span{color:var(--ink-3);align-items:center;gap:4px;font-size:11px;display:inline-flex}.upload-supported svg{width:12px;height:12px;color:var(--income)}.upload-side{flex-direction:column;gap:14px;display:flex}.how{color:var(--ink-2);flex-direction:column;gap:10px;margin:0;padding:0;font-size:13px;list-style:none;display:flex}.how b{color:var(--accent-deep);margin-right:6px}.up-row{border-top:1px solid var(--border);align-items:center;gap:10px;padding:10px 0;font-size:13px;display:flex}.up-row:first-of-type{border-top:none;padding-top:4px}.up-row svg{width:18px;height:18px;color:var(--ink-3);flex-shrink:0}.up-row .up-info{flex:1;min-width:0}.up-row .up-name{font-weight:600}.up-row .up-meta{color:var(--ink-3);font-size:11px}.extract-totals{border-top:1px solid var(--border);border-bottom:1px solid var(--border);grid-template-columns:repeat(4,1fr);gap:18px;padding:14px 0;display:grid}.extract-totals .val{font-size:18px;font-weight:800;font-family:var(--font-display);letter-spacing:-.02em;margin-top:2px;display:block}.cf-summary{grid-template-columns:1.4fr 1fr 1fr;gap:14px;display:grid}.cf-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:14px;padding:18px}.cf-card:first-child{background:linear-gradient(135deg, var(--accent-soft) 0%, #fff 70%)}.cf-big{letter-spacing:-.6px;color:var(--accent-deep);margin-top:8px;font-size:30px;font-weight:600}.cf-card:not(:first-child) .cf-big{color:var(--ink-1)}.cf-bars{grid-template-columns:repeat(6,1fr);align-items:end;gap:14px;height:220px;padding:0 8px;display:grid}.cf-bar{flex-direction:column;align-items:center;gap:8px;height:100%;display:flex}.cf-stack{background:var(--bg-subtle);border-radius:8px;flex-direction:column-reverse;flex:1;width:100%;max-width:60px;display:flex;overflow:hidden}.cf-inst{background:var(--cat-fun-ink);border-bottom:2px solid var(--bg-elevated);width:100%}.cf-rec{background:var(--cat-home-ink);width:100%}.cf-bar-label{color:var(--ink-3);text-align:center;font-size:11px;line-height:1.3}.cf-bar-label span{color:var(--ink-1);font-size:12px;font-weight:600;display:block}.inst-row{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 0;display:flex}.inst-row:first-of-type{border-top:none;padding-top:4px}.inst-row .inst-name{font-weight:600}.inst-row .inst-meta{color:var(--ink-3);font-size:11px}.inst-row .inst-amt{text-align:right;font-weight:600}.inst-row .inst-amt-sub{color:var(--ink-3);text-align:right;font-size:11px}.cz-hero{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:18px;display:flex}.cz-stats{grid-template-columns:1.4fr 1fr 1fr;gap:14px;display:grid}.cz-stat{background:var(--bg-elevated);border:1px solid var(--border);border-radius:14px;padding:16px}.cz-bar{background:var(--bg-subtle);border-radius:99px;height:8px;margin-top:10px;overflow:hidden}.cz-bar span{background:linear-gradient(90deg, var(--accent), var(--accent-deep));border-radius:99px;height:100%;display:block}.cz-row{border-top:1px solid var(--border);grid-template-columns:60px 36px 1fr 1.2fr 100px 80px;align-items:center;gap:12px;padding:14px 18px;font-size:13px;display:grid}.cz-row.warn{background:#fffbeb}.cz-suggest{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.suggest-label{color:var(--ink-3);text-transform:uppercase;letter-spacing:.5px;margin-right:2px;font-size:10px}.suggest-pill{background:var(--accent-soft);color:var(--accent-deep);border:1px solid var(--accent);cursor:pointer;border-radius:99px;align-items:center;gap:6px;padding:5px 10px;font-size:12px;font-weight:500;display:inline-flex}.suggest-pill:hover{background:var(--accent);color:var(--ink-1)}.suggest-pill .dot{border-radius:50%;width:8px;height:8px}.suggest-alt{border:1px dashed var(--border);color:var(--ink-2);cursor:pointer;background:0 0;border-radius:99px;padding:5px 10px;font-size:12px}.suggest-alt:hover{border-style:solid;border-color:var(--ink-3)}.ic-btn{border:1px solid var(--border);background:var(--bg-elevated);cursor:pointer;width:32px;height:32px;color:var(--ink-3);border-radius:8px;justify-content:center;align-items:center;display:inline-flex}.ic-btn svg{width:15px;height:15px}.ic-btn:hover{color:var(--ink-1);border-color:var(--ink-3)}.ic-btn.ok{background:var(--income);border-color:var(--income);color:#fff}.ic-btn.ok:hover{background:#15803d}.acc-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.acc-card{aspect-ratio:1.585;color:#fff;border-radius:18px;flex-direction:column;justify-content:space-between;padding:18px;display:flex;position:relative;box-shadow:0 8px 24px #0000001f}.acc-card .acc-bank{opacity:.95;color:#fff;align-items:center;gap:6px;font-size:12px;font-weight:500;display:inline-flex}.acc-card .acc-bank svg{width:14px;height:14px}.acc-brand{letter-spacing:1px;margin-top:auto;margin-bottom:6px;font-size:18px;font-weight:700}.acc-num{font-family:var(--font-mono);letter-spacing:2px;opacity:.95;font-size:15px}.acc-card-row{justify-content:space-between;align-items:flex-end;margin-top:14px;font-size:13px;font-weight:500;display:flex}.acc-card-row .lbl-up{color:#ffffffb3}.acc-foot{justify-content:space-between;align-items:center;margin-top:10px;display:flex}.acc-card.add{background:var(--bg-elevated);border:2px dashed var(--border);color:var(--ink-3);box-shadow:none;text-align:center;cursor:pointer;justify-content:center;align-items:center;gap:8px;padding:24px}.acc-card.add:hover{border-color:var(--accent);color:var(--accent-deep)}.acc-card.add svg{width:32px;height:32px}.bnk{border-top:1px solid var(--border);align-items:center;gap:12px;padding:14px 0;display:flex}.bnk:first-of-type{border-top:none;padding-top:4px}.bnk-logo{color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.bnk-logo svg{width:18px;height:18px}.bnk-info{flex:1;min-width:0}.bnk-name{font-weight:600}.bnk-meta{color:var(--ink-3);font-size:12px}.bnk-amount{text-align:right}.bnk-amount .amt{font-weight:600}.bnk-amount .at{color:var(--ink-3);font-size:11px}.cat-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.catgroup{background:var(--bg-elevated);border:1px solid var(--border);border-radius:14px;overflow:hidden}.catgroup-head{align-items:center;gap:8px;padding:12px 14px;font-size:14px;font-weight:600;display:flex}.catgroup-head svg{width:16px;height:16px}.catgroup-list{padding:8px 6px}.catitem{cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;font-size:13px;display:flex}.catitem:hover{background:var(--bg-subtle)}.catitem .dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.catitem .ct{color:var(--ink-3);background:var(--bg-subtle);border-radius:99px;margin-left:auto;padding:2px 8px;font-size:11px}.catitem.add{color:var(--ink-3);font-style:italic}.catgroup.empty{background:0 0;border-style:dashed}.catgroup.empty .catgroup-head{cursor:pointer;color:var(--ink-3)}.rec-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.rec-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:8px;padding:16px;display:flex}.rec-card .cat-ico{border-radius:12px;align-self:flex-start;width:40px;height:40px}.rec-card .cat-ico svg{width:20px;height:20px}.rec-name{margin-top:4px;font-size:14px;font-weight:600}.rec-amt{letter-spacing:-.3px;font-size:20px;font-weight:600}.rec-amt span{color:var(--ink-3);margin-left:2px;font-size:12px;font-weight:500}.rec-meta{border-top:1px solid var(--border);color:var(--ink-3);justify-content:space-between;align-items:center;gap:6px;margin-top:auto;padding-top:8px;font-size:11px;display:flex}.rec-card.pending{background:var(--bg-subtle);border-style:dashed}.fam-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:12px;display:flex}.mem{border-top:1px solid var(--border);align-items:center;gap:12px;padding:12px 0;display:flex}.mem:first-of-type{border-top:none;padding-top:4px}.mem .mem-info{flex:1;min-width:0}.mem .mem-name{flex-wrap:wrap;align-items:center;gap:6px;font-weight:600;display:flex}.mem .mem-meta{color:var(--ink-3);font-size:12px}.avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:14px;font-weight:600;display:flex}.mem.pending{opacity:.85}.memstat{margin-bottom:14px;font-size:13px}.memstat .bar{background:var(--bg-subtle);border-radius:99px;height:8px;overflow:hidden}.memstat .bar span{border-radius:99px;height:100%;display:block}.login-container{background:var(--bg);flex:1;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);text-align:center;width:100%;max-width:400px;box-shadow:var(--shadow-md);padding:40px 36px}.login-card .login-logo{width:220px;height:auto;margin:0 auto 8px;display:block}.login-card .login-brand{font-family:var(--font-display);letter-spacing:-.03em;margin-bottom:4px;font-size:32px;font-weight:800}.login-card .login-brand em{color:var(--accent-deep);font-style:normal}.login-card .login-sub{color:var(--ink-3);margin-bottom:28px;font-size:13px}.login-google{background:var(--ink-1);color:var(--bg);border-radius:var(--r-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px 18px;font-size:14px;font-weight:600;display:inline-flex}.login-google:hover{background:#2a2a2a}.page-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:18px;display:flex}.page-head .page-title{letter-spacing:-.02em;margin:0;font-size:24px;font-weight:700}.page-head .page-sub{color:var(--ink-3);margin-top:4px;font-size:13px}.page-head .actions{flex-wrap:wrap;gap:8px;display:flex}.modal-backdrop{z-index:100;background:#0a0a0a66;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-elevated);border-radius:var(--r-xl);width:100%;max-width:480px;box-shadow:var(--shadow-lg);max-height:90vh;padding:28px;overflow-y:auto}.modal h3{letter-spacing:-.01em;margin:0 0 8px;font-size:18px;font-weight:700}.modal .modal-sub{color:var(--ink-3);margin-bottom:20px;font-size:13px}.modal .modal-actions{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.4)}}@media (width<=800px){html,body{overflow-x:hidden}.sidebar{display:none}.main-area{min-width:0;margin-left:0;padding-bottom:80px}.top-bar{padding:14px 16px}.top-bar h1{font-size:18px}.top-bar .actions .btn-text{display:none}.content{max-width:100%;padding:16px}.hero-grid,.two-col,.add-wrap{grid-template-columns:1fr}.tx-head{display:none}.tx{grid-template-columns:44px 1fr auto}.tx-date,.tx-cat,.tx-src,.tx-src-wrap{display:none}.upload-hero{grid-template-columns:1fr}.cf-summary,.cz-stats,.extract-totals{grid-template-columns:1fr 1fr}.cf-bars{gap:6px;height:160px}.cz-row{grid-template-columns:36px 1fr auto;gap:8px;padding:12px}.cz-row .tx-date,.cz-row .cz-suggest{display:none}.acc-grid,.cat-grid,.rec-grid{grid-template-columns:1fr}.cz-hero,.fam-head,.page-head{flex-direction:column;align-items:flex-start;gap:12px}.field-row{grid-template-columns:1fr}.bottom-nav{display:flex}.month-pills{flex-wrap:wrap;margin-left:0}.hero-card{min-height:0;padding:20px}.hero-card .big{letter-spacing:-.03em;font-size:36px}.hero-card .big .cents{font-size:18px}.stat{padding:16px}.stat .num{font-size:26px}.amt-display{padding:28px 20px}.amt-display .big{font-size:48px}.tx-stats{gap:14px;padding:12px 14px}.tx-stats .val{font-size:16px}.cf-big{font-size:24px}.extract-totals .val{font-size:14px}.tx-toolbar{gap:8px}.tx-search{min-width:100%}.tx-toolbar .btn-text{display:inline}.pagination{gap:12px}.modal{max-width:calc(100vw - 32px)}.modal-backdrop{padding:16px}.page-head .actions{width:100%}.page-head .actions .btn{flex:1;justify-content:center}}
