:root{--accent-h: 18;--accent-c: .13;--accent: oklch(.62 var(--accent-c) var(--accent-h));--accent-soft: oklch(.92 .06 var(--accent-h));--accent-on: #fff;--bg: #f0e7d8;--paper: #fff8e8;--paper-2: #faf2e2;--line: #e3d8c4;--line-2: #ebdfc9;--ink: #1a1715;--ink-2: #2a2421;--muted: #6e6358;--muted-2: #8a7e70;--faint: #b5a797;--pos: #3d6b4f;--pos-soft: #d8e8d4;--neg: oklch(.58 .14 25);--radius-s: 8px;--radius-m: 14px;--radius-l: 20px;--radius-xl: 28px;--shadow-sm: 0 1px 0 rgba(26,23,21,.04);--shadow-md: 0 4px 16px rgba(26,23,21,.06);--serif: "Instrument Serif", "Cormorant Garamond", Georgia, serif;--sans: "Inter Tight", "Inter", system-ui, -apple-system, sans-serif;--mono: "JetBrains Mono", "IBM Plex Mono", ui-monospace, monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:14px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.5}button{font-family:inherit;cursor:pointer}input,button,select,textarea{font-family:inherit}a{color:inherit;text-decoration:none}.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.serif{font-family:var(--serif);font-weight:400;letter-spacing:-.02em}.mono{font-family:var(--mono)}.label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:500}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--line);border-radius:6px;border:2px solid var(--bg)}::-webkit-scrollbar-track{background:transparent}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:76px;background:var(--paper);border-right:1px solid var(--line);padding:18px 0;display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;z-index:10}.sidebar .logo{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;flex-shrink:0;-webkit-user-select:none;user-select:none;overflow:hidden}.sidebar .logo img{width:42px;height:42px;border-radius:12px;display:block}.sidebar .nav-btn{width:44px;height:44px;border-radius:12px;border:0;background:transparent;color:var(--muted);display:flex;align-items:center;justify-content:center;position:relative;transition:color .15s,background .15s}.sidebar .nav-btn:hover{color:var(--ink);background:var(--paper-2)}.sidebar .nav-btn.active{background:var(--ink);color:var(--paper)}.sidebar .nav-btn .tip{position:absolute;left:56px;top:50%;transform:translateY(-50%);background:var(--ink);color:var(--paper);padding:5px 10px;border-radius:6px;font-size:11px;font-weight:500;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s;z-index:50}.sidebar .nav-btn:hover .tip{opacity:1}.sidebar .spacer{flex:1}.sidebar .ava{width:40px;height:40px;border-radius:50%;background:var(--ink);color:var(--paper);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s;position:relative;flex-shrink:0}.sidebar .ava:hover{background:var(--ink-2)}.sidebar .ava .tip{position:absolute;left:56px;top:50%;transform:translateY(-50%);background:var(--ink);color:var(--paper);padding:5px 10px;border-radius:6px;font-size:11px;font-weight:500;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s;z-index:50;text-align:left}.sidebar .ava:hover .tip{opacity:1}.main{flex:1;overflow-y:auto;overflow-x:hidden;padding:24px 32px 40px}.main-narrow{max-width:1280px;margin:0 auto}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;gap:18px}.topbar .greet h1{font-size:22px;font-weight:600;letter-spacing:-.01em}.topbar .greet .d{font-size:12px;color:var(--muted);margin-left:10px}.topbar .greet .sub{font-size:12px;color:var(--muted);margin-top:2px}.pill-group{display:inline-flex;gap:4px;padding:4px;background:var(--paper-2);border:1px solid var(--line);border-radius:999px}.pill{padding:6px 14px;font-size:12px;font-weight:500;border-radius:999px;border:0;background:transparent;color:var(--muted);transition:background .15s,color .15s}.pill.on{background:var(--ink);color:var(--paper)}.pill:not(.on):hover{background:var(--line);color:var(--ink)}.actions{display:flex;gap:8px;align-items:center}.ic-btn{width:36px;height:36px;border-radius:50%;background:var(--paper);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink);transition:background .15s,border-color .15s}.ic-btn:hover{background:var(--paper-2);border-color:var(--ink-2)}.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:999px;font-size:13px;font-weight:500;border:0;background:var(--ink);color:var(--paper);transition:background .15s,transform .1s;white-space:nowrap}.btn:hover{background:var(--ink-2)}.btn:active{transform:scale(.98)}.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}.btn.ghost:hover{background:var(--paper-2)}.btn.accent{background:var(--accent);color:var(--accent-on)}.btn.accent:hover{filter:brightness(.95)}.btn.danger{background:var(--neg);color:#fff}.btn.sm{padding:6px 12px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:22px 24px}.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.card-head h3{font-size:14px;font-weight:600;margin:0;letter-spacing:-.005em}.card-head .more{font-size:12px;color:var(--muted);border:0;background:transparent}.card-head .more:hover{color:var(--ink)}.dash-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:18px}.hero{grid-column:1 / 2;grid-row:1 / 3;padding:32px 32px 26px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-xl);position:relative;overflow:hidden}.hero .scrub{position:absolute;right:24px;top:24px;display:flex;gap:6px;align-items:center;font-size:11px;color:var(--muted)}.hero .scrub .dot{width:6px;height:6px;border-radius:50%;background:var(--pos)}.hero .big{font-family:var(--serif);font-size:88px;line-height:.94;letter-spacing:-.04em;margin:16px 0 6px;color:var(--ink)}.hero .big .pre{font-size:44px;vertical-align:top;color:var(--muted);margin-right:2px}.hero .big .cents{font-size:40px;color:var(--muted);vertical-align:top}.hero .delta-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.delta-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:500;background:var(--ink);color:var(--paper)}.delta-pill .gain{color:#96e498}.delta-pill .loss{color:#ff958d;color:oklch(.78 .13 25)}.hero .breakdown{margin-top:28px;padding-top:22px;border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.hero .breakdown .bv{font-family:var(--serif);font-size:26px;line-height:1;letter-spacing:-.02em;margin-top:6px}.hero .breakdown .bv.pos{color:var(--pos)}.hero .breakdown .micro{font-size:11px;color:var(--muted);margin-top:4px}.hero .accounts-strip{margin-top:22px;display:flex;gap:10px;flex-wrap:wrap}.acct-chip{flex:1;min-width:0;padding:14px;background:var(--paper-2);border-radius:14px;border:1px solid var(--line);text-align:left;transition:border-color .15s,transform .1s}.acct-chip:hover{border-color:var(--ink-2)}.acct-chip:active{transform:scale(.99)}.acct-chip .nm{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.acct-chip .av{font-size:16px;font-weight:600;margin-top:6px;font-variant-numeric:tabular-nums}.acct-chip .av.neg{color:var(--accent)}.left-spend{grid-column:2 / 3;grid-row:1 / 2;padding:24px;background:var(--ink);color:var(--paper);border-radius:var(--radius-l);display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden}.left-spend .pat{position:absolute;right:-40px;top:-40px;width:160px;height:160px;border:1px solid var(--ink-2);border-radius:50%;pointer-events:none}.left-spend .pat:before{content:"";position:absolute;top:24px;right:24px;bottom:24px;left:24px;border:1px solid var(--ink-2);border-radius:50%}.left-spend .label{color:var(--muted-2)}.left-spend .num-big{font-family:var(--serif);font-size:52px;line-height:1;letter-spacing:-.025em;margin:4px 0 0}.left-spend .sub{font-size:12px;color:var(--muted-2);margin-top:-2px}.left-spend .ring{display:flex;align-items:center;gap:14px;margin-top:auto}.left-spend .ring svg{transform:rotate(-90deg);flex-shrink:0}.left-spend .stat{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--muted-2);padding:8px 0;border-top:1px solid var(--ink-2)}.left-spend .stat strong{color:var(--paper);font-weight:500;font-variant-numeric:tabular-nums}.panel-budgets{grid-column:2 / 3;grid-row:2 / 3}.b-row .btop{display:flex;justify-content:space-between;align-items:center;font-size:12px}.b-row .bnm{font-weight:500;display:flex;gap:8px;align-items:center;color:var(--ink)}.b-row .bnm .bic{width:24px;height:24px;border-radius:7px;background:var(--paper-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted)}.b-row .bvals{color:var(--muted);font-variant-numeric:tabular-nums}.b-row .bvals strong{color:var(--ink);font-weight:500}.b-row .bbar{height:6px;background:var(--paper-2);border-radius:3px;overflow:hidden;border:1px solid var(--line-2)}.b-row .bbar>span{display:block;height:100%;background:var(--ink);border-radius:3px;transition:width .4s ease}.b-row.over .bbar>span{background:var(--accent)}.panel-trans{grid-column:1 / 3}.panel-trans .phead{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.phead .more{white-space:nowrap;padding:6px 14px;border:1px solid var(--line);border-radius:999px;background:var(--paper);font-size:12px;color:var(--accent);font-weight:500;cursor:pointer}.phead .more:hover{background:var(--paper-2)}.tag-group{display:flex;gap:6px}.tag{padding:5px 11px;font-size:11px;border-radius:999px;background:var(--paper-2);color:var(--muted);border:1px solid var(--line);cursor:pointer;font-weight:500;transition:background .15s,color .15s}.tag.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}.tx-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px 28px}.tx-grid .tx{border-bottom:1px solid var(--line-2)}.tx-grid .tx:nth-last-child(-n+3){border-bottom:0}.dash-charts{grid-column:1 / 3;display:grid;grid-template-columns:1fr 1fr;gap:18px}.dash-chart-full{grid-column:1 / 3}.tx{display:flex;gap:12px;padding:10px 0;align-items:center}.tx .ic{width:34px;height:34px;border-radius:50%;background:var(--paper-2);display:flex;align-items:center;justify-content:center;color:var(--ink);flex-shrink:0;border:1px solid var(--line)}.tx .body{flex:1;min-width:0}.tx .p{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx .i{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.tx .v{font-size:13px;font-weight:500;font-variant-numeric:tabular-nums;flex-shrink:0}.tx .v.pos{color:var(--pos)}.page-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:22px}.page-head h1{font-family:var(--serif);font-size:44px;line-height:1;margin:0 0 4px;letter-spacing:-.025em}.page-head .desc{font-size:13px;color:var(--muted)}.page-head .right{display:flex;gap:8px;align-items:center}.search-bar{display:flex;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--line);padding:8px 14px;border-radius:999px;min-width:240px}.search-bar input{flex:1;background:transparent;border:0;outline:0;color:var(--ink);font-size:13px}.search-bar input::placeholder{color:var(--muted)}.filters-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.chip{padding:6px 12px;border-radius:999px;font-size:12px;font-weight:500;background:var(--paper);border:1px solid var(--line);color:var(--ink);display:inline-flex;align-items:center;gap:6px;transition:background .15s,color .15s;white-space:nowrap;flex-shrink:0}.chip.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}.chip:not(.on):hover{background:var(--paper-2)}.chip-divider{width:1px;height:18px;background:var(--line);margin:0 2px;flex-shrink:0}.tx-table{width:100%;border-collapse:collapse}.tx-table th{text-align:left;font-weight:500;font-size:10px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;padding:14px 10px 12px;border-bottom:1px solid var(--line);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.tx-table th:hover{color:var(--ink)}.tx-table td{padding:12px 10px;border-bottom:1px solid var(--line-2);font-size:13px;vertical-align:middle}.tx-table tbody tr:hover td{background:var(--paper)}.tx-table .r{text-align:right}.tx-table .tnm{font-weight:500;color:var(--ink)}.tx-table .tmeta{color:var(--muted);font-size:12px;margin-top:2px}.tx-table td.amount{font-variant-numeric:tabular-nums;font-weight:500}.tx-table td.amount.pos{color:var(--pos)}.tx-table td.amount.neg{color:var(--neg)}.cat-pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;background:var(--paper-2);border:1px solid var(--line);font-size:11px;color:var(--muted)}.cat-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);flex-shrink:0}.row-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.tx-table tbody tr:hover .row-actions{opacity:1}.act-btn{padding:4px 8px;border-radius:6px;font-size:11px;font-weight:500;border:1px solid var(--line);background:var(--paper);color:var(--ink);white-space:nowrap;transition:background .15s}.act-btn:hover{background:var(--paper-2)}.act-btn.del{border-color:var(--neg);color:var(--neg)}.act-btn.del:hover{background:#ffedeb;background:oklch(.96 .04 25)}.pagination{display:flex;align-items:center;gap:8px;padding:16px 0 0;font-size:13px;color:var(--muted);flex-wrap:wrap}.pg-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:var(--paper);color:var(--ink);display:flex;align-items:center;justify-content:center;font-size:12px;transition:background .15s}.pg-btn:hover{background:var(--paper-2)}.pg-btn.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}.pg-btn:disabled{opacity:.4;cursor:not-allowed}.pagination select{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:4px 8px;font-size:12px;color:var(--ink);outline:0}.acct-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.acct-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:22px 24px;position:relative;overflow:hidden}.acct-card.featured{background:var(--ink);color:var(--paper);border-color:var(--ink)}.acct-card .type-lbl{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.acct-card.featured .type-lbl{color:var(--muted-2)}.acct-card h3{font-size:16px;font-weight:600;margin:6px 0 0}.acct-card .balance{font-family:var(--serif);font-size:44px;line-height:1;letter-spacing:-.025em;margin:18px 0 4px}.acct-card .balance.neg{color:var(--accent)}.acct-card.featured .balance.neg{color:#ff958d;color:oklch(.78 .13 25)}.acct-card .bal-label{font-size:12px;color:var(--muted)}.acct-card.featured .bal-label{color:var(--muted-2)}.acct-card .util-bar{height:4px;background:var(--paper-2);border-radius:2px;overflow:hidden;margin:14px 0 6px}.acct-card.featured .util-bar{background:var(--ink-2)}.acct-card .util-bar>span{display:block;height:100%;background:var(--accent);transition:width .4s}.acct-card .util-meta{font-size:11px;color:var(--muted);display:flex;justify-content:space-between}.acct-card.featured .util-meta{color:var(--muted-2)}.acct-card .acct-actions{display:flex;gap:6px;margin-top:18px}.a-btn{flex:1;padding:8px;font-size:12px;font-weight:500;border-radius:8px;background:var(--paper-2);border:1px solid var(--line);color:var(--ink);display:flex;align-items:center;justify-content:center;gap:6px;transition:background .15s}.a-btn:hover{background:var(--line)}.acct-card.featured .a-btn{background:var(--ink-2);color:var(--paper);border-color:var(--ink-2)}.acct-card.featured .a-btn:hover{background:#332c27}.a-btn.danger{color:var(--neg)}.acct-card.featured .a-btn.danger{color:#ff958d;color:oklch(.78 .13 25)}.add-acct-card{background:transparent;border:2px dashed var(--line);border-radius:var(--radius-l);padding:22px 24px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:200px;cursor:pointer;transition:border-color .15s,background .15s}.add-acct-card:hover{border-color:var(--ink-2);background:var(--paper-2)}.transfer-wrap{max-width:560px;margin:0 auto;padding-top:20px}.cat-section{margin-bottom:32px}.cat-section-title{font-family:var(--serif);font-size:28px;letter-spacing:-.02em;margin-bottom:14px}.cat-list{display:flex;flex-direction:column;gap:8px}.cat-item{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-m);padding:14px 18px}.cat-header{display:flex;align-items:center;justify-content:space-between}.cat-name{font-weight:600;font-size:14px;display:flex;align-items:center;gap:8px}.cat-actions{display:flex;gap:6px}.sub-list{margin-top:10px;padding-top:10px;border-top:1px solid var(--line-2);display:flex;flex-wrap:wrap;gap:6px}.sub-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:var(--paper-2);border:1px solid var(--line);font-size:12px;color:var(--ink)}.del-sub{color:var(--muted);background:none;border:0;padding:0;line-height:1;cursor:pointer}.del-sub:hover{color:var(--neg)}.reports-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.chart-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:22px 24px}.chart-card.full{grid-column:1 / 3}.legend-row{display:flex;gap:16px;font-size:11px;color:var(--muted);padding-top:12px;border-top:1px solid var(--line);margin-top:12px;flex-wrap:wrap}.legend-dot{display:inline-block;width:9px;height:9px;border-radius:2px;margin-right:6px;vertical-align:middle}.donut-wrap{display:flex;gap:24px;align-items:center;flex-wrap:wrap}.donut-legend{flex:1;min-width:200px;display:flex;flex-direction:column;gap:6px}.donut-legend .drow{display:flex;justify-content:space-between;align-items:center;font-size:12px;padding:4px 0;border-bottom:1px solid var(--line-2)}.donut-legend .drow:last-child{border-bottom:0}.donut-legend .drow .dl{display:flex;align-items:center;gap:8px}.donut-legend .drow .dsw{width:10px;height:10px;border-radius:3px;flex-shrink:0}.donut-legend .drow .dv{font-variant-numeric:tabular-nums;color:var(--muted)}.donut-legend .drow .dv strong{color:var(--ink);font-weight:500}.modal-back{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a171573;z-index:150;display:flex;align-items:center;justify-content:center;animation:fade .2s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-xl);width:520px;max-width:calc(100vw - 32px);max-height:calc(100vh - 32px);overflow:auto;padding:28px 32px;animation:pop .25s cubic-bezier(.2,.8,.2,1);box-shadow:var(--shadow-md)}@keyframes fade{0%{opacity:0}}@keyframes pop{0%{opacity:0;transform:scale(.96) translateY(8px)}}.modal h2{font-family:var(--serif);font-size:32px;line-height:1;margin:0 0 4px;letter-spacing:-.02em}.modal .mdesc{font-size:13px;color:var(--muted);margin-bottom:20px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:11px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-weight:500}.field input,.field select,.field textarea{background:var(--paper-2);border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:13px;color:var(--ink);outline:0;transition:border-color .15s;width:100%}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--ink)}.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field-note{font-size:11px;color:var(--muted);margin-top:4px}.amt-input{display:flex;align-items:baseline;gap:4px;background:var(--paper-2);border:1px solid var(--line);border-radius:12px;padding:14px 18px;margin-bottom:18px;transition:border-color .15s}.amt-input:focus-within{border-color:var(--ink)}.amt-input .pre{font-family:var(--serif);font-size:36px;color:var(--muted)}.amt-input input{border:0;background:transparent;outline:0;font-family:var(--serif);font-size:48px;line-height:1;letter-spacing:-.02em;width:100%;color:var(--ink);padding:0}.type-toggle{display:inline-flex;padding:4px;background:var(--paper-2);border:1px solid var(--line);border-radius:999px;margin-bottom:14px}.type-toggle button{padding:6px 14px;border-radius:999px;border:0;background:transparent;font-size:12px;color:var(--muted);font-weight:500;transition:background .15s,color .15s}.type-toggle button.on{background:var(--ink);color:var(--paper)}.type-toggle button.on.income{background:var(--pos);color:#fff}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:22px;padding-top:18px;border-top:1px solid var(--line)}.card-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:24px;padding-top:18px;border-top:1px solid var(--line)}.auth-wrap{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-xl);width:420px;max-width:100%;padding:36px 40px;box-shadow:var(--shadow-md)}.auth-logo{width:52px;height:52px;border-radius:14px;overflow:hidden;margin-bottom:20px}.auth-logo img{width:52px;height:52px;display:block}.auth-card h1{font-family:var(--serif);font-size:36px;letter-spacing:-.025em;margin-bottom:4px}.auth-card .auth-sub{font-size:13px;color:var(--muted);margin-bottom:24px}.auth-error{background:#ffedeb;background:oklch(.96 .04 25);border:1px solid oklch(.88 .08 25);color:var(--neg);padding:10px 14px;border-radius:10px;font-size:13px;margin-bottom:16px}.auth-success{background:var(--pos-soft);border:1px solid #b8d4c0;color:var(--pos);padding:10px 14px;border-radius:10px;font-size:13px;margin-bottom:16px}.auth-switch{text-align:center;font-size:12px;color:var(--muted);margin-top:20px}.auth-switch button{background:none;border:0;color:var(--ink);font-weight:500;text-decoration:underline;cursor:pointer}.empty{text-align:center;padding:60px 20px;color:var(--muted);font-size:13px}.empty .empty-icon{font-size:40px;margin-bottom:14px}.empty h2{font-family:var(--serif);font-size:28px;letter-spacing:-.02em;color:var(--ink);margin-bottom:8px}.empty p{max-width:320px;margin:0 auto 20px;line-height:1.6}.data-io{display:flex;flex-direction:column;gap:2px}.data-io-btn{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;border:0;background:transparent;color:var(--muted);font-size:12px;font-weight:500;transition:background .15s,color .15s;text-align:left;width:100%}.data-io-btn:hover{background:var(--paper-2);color:var(--ink)}.storage-note{font-size:10px;color:var(--faint);margin-top:8px;line-height:1.5}.toasts{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:200}.toast{background:var(--ink);color:var(--paper);padding:10px 16px;border-radius:10px;font-size:13px;box-shadow:var(--shadow-md);animation:slide-in .25s ease;display:flex;align-items:center;gap:10px}@keyframes slide-in{0%{transform:translate(20px);opacity:0}}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--line)}.recharts-tooltip-wrapper .recharts-default-tooltip{background:var(--paper)!important;border:1px solid var(--line)!important;border-radius:10px!important;box-shadow:var(--shadow-md)!important;font-family:var(--sans)!important;font-size:13px!important}.recharts-tooltip-label{color:var(--muted)!important;font-size:11px!important;text-transform:uppercase;letter-spacing:.1em}.recharts-legend-item-text{color:var(--muted)!important;font-size:12px!important}.loading-screen{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:14px}.loading-screen .spin{width:32px;height:32px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen p{font-size:13px;color:var(--muted)}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:18px;flex-wrap:wrap}.topbar .greet{display:flex;flex-direction:column;gap:2px}.topbar .greet .greet-h{display:flex;align-items:baseline;gap:10px}.topbar .greet h1{font-size:22px;font-weight:600;letter-spacing:-.01em;margin:0}.topbar .greet .greet-date{font-size:12px;color:var(--muted)}.topbar .greet .greet-sub{font-size:12px;color:var(--muted);margin-top:2px}.topbar .greet .greet-sub strong{color:var(--pos);font-weight:600}.topbar .greet .greet-sub .neg-track{color:var(--neg)}.topbar-right{display:flex;align-items:center;gap:10px}.budget-summary{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-l);padding:24px 28px;margin-bottom:18px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:24px;align-items:end}@media(max-width:900px){.budget-summary{grid-template-columns:1fr 1fr}}.budget-summary .bsm-big{font-family:var(--serif);font-size:48px;line-height:1;letter-spacing:-.025em;margin-top:6px}.budget-summary .bsm-sub{height:6px;background:var(--paper-2);border-radius:3px;overflow:hidden;margin-top:14px;border:1px solid var(--line-2)}.budget-summary .bsm-sub span{display:block;height:100%;background:var(--ink);border-radius:3px;transition:width .4s ease}.budget-summary .bsm-v{font-family:var(--serif);font-size:28px;line-height:1;letter-spacing:-.02em;margin-top:6px}.budget-summary .bsm-v.pos{color:var(--pos)}.budget-summary .bsm-v.neg{color:var(--neg)}.budget-summary .bsm-hint{font-size:11px;color:var(--muted);margin-top:4px}.section-title{font-family:var(--serif);font-size:28px;letter-spacing:-.02em;margin:0 0 14px}.bud-list{display:flex;flex-direction:column;gap:8px}.bud-list .b-row{padding:16px 22px;border:1px solid var(--line);background:var(--paper);border-radius:14px;display:flex;flex-direction:column;gap:8px}.bud-list .b-row .top{display:flex;justify-content:space-between;align-items:center;font-size:14px}.bud-list .b-row .nm{font-weight:600;display:flex;gap:10px;align-items:center;color:var(--ink)}.bud-list .b-row .nm .ic{width:32px;height:32px;border-radius:10px;background:var(--paper-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);flex-shrink:0}.bud-list .b-row .vals{color:var(--muted);font-variant-numeric:tabular-nums}.bud-list .b-row .vals strong{color:var(--ink);font-weight:600}.bud-list .b-row .bar{height:8px;background:var(--paper-2);border-radius:4px;overflow:hidden;border:1px solid var(--line-2)}.bud-list .b-row .bar>span{display:block;height:100%;background:var(--ink);border-radius:4px;transition:width .4s ease}.bud-list .b-row.over .bar>span{background:var(--neg)}.bud-list .b-row.warn .bar>span{background:#e38d3d}.bud-list .b-row .meta{display:flex;justify-content:space-between;font-size:11px;color:var(--muted)}.bud-list .b-row.over{border-color:#febab4;background:snow;background:oklch(.99 .01 25)}.bud-list .b-row.over .meta{color:var(--neg);font-weight:500}.bud-list .b-row .no-budget{font-size:11px;color:var(--muted);font-style:italic}.bud-list .b-row .edit-budget{display:flex;gap:8px;align-items:center;margin-top:4px}.b-row{display:flex;flex-direction:column;gap:6px;padding:9px 0;border-bottom:1px solid var(--line-2)}.b-row:last-child{border-bottom:0}.b-row .top{display:flex;justify-content:space-between;align-items:center;font-size:12px}.b-row .nm{font-weight:500;display:flex;gap:8px;align-items:center;color:var(--ink)}.b-row .nm .ic{width:24px;height:24px;border-radius:7px;background:var(--paper-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);flex-shrink:0}.b-row .vals{color:var(--muted);font-variant-numeric:tabular-nums}.b-row .vals strong{color:var(--ink);font-weight:500}.b-row .bar{height:6px;background:var(--paper-2);border-radius:3px;overflow:hidden;border:1px solid var(--line-2)}.b-row .bar>span{display:block;height:100%;background:var(--ink);border-radius:3px;transition:width .4s ease}.b-row.over .bar>span{background:var(--neg)}.b-row.warn .bar>span{background:#e38d3d}.icon-picker{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.icon-picker button{width:36px;height:36px;border-radius:9px;border:1px solid var(--line);background:var(--paper-2);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .15s;cursor:pointer}.icon-picker button:hover{border-color:var(--ink);color:var(--ink);background:var(--paper)}.icon-picker button.selected{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.cat-icon-badge{width:26px;height:26px;border-radius:8px;background:var(--paper-2);border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center;color:var(--muted);flex-shrink:0}.budget-set-row{display:flex;gap:8px;align-items:center;padding-top:4px}.budget-set-row input{flex:1;max-width:140px;background:var(--paper-2);border:1px solid var(--line);border-radius:8px;padding:7px 10px;font-size:13px;color:var(--ink);outline:none}.budget-set-row input:focus{border-color:var(--ink)}.main::-webkit-scrollbar{width:8px}.main::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px;border:2px solid var(--bg)}.sidebar .ava{border:none;text-decoration:none}.sidebar .ava.active{background:var(--accent)}.sync-dot{position:absolute;top:2px;right:2px;width:9px;height:9px;border-radius:50%;background:var(--pos);border:2px solid var(--paper);pointer-events:none}.profile-head{display:flex;align-items:center;gap:16px;margin-bottom:4px}.profile-avatar{width:54px;height:54px;border-radius:50%;background:var(--accent);color:var(--accent-on);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:20px;letter-spacing:-.02em;flex-shrink:0;-webkit-user-select:none;user-select:none}.cloud-badge{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:var(--radius-m);font-size:13px;font-weight:500;margin-bottom:4px}.cloud-badge.synced{background:var(--pos-soft);color:var(--pos)}.cloud-badge.local{background:var(--paper-2);color:var(--muted);border:1px solid var(--line)}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--paper);border-top:1px solid var(--line);z-index:100;padding:6px 4px;padding-bottom:max(env(safe-area-inset-bottom),6px)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted-2);font-size:10px;font-weight:500;letter-spacing:.02em;border:0;background:transparent;padding:6px 4px;border-radius:var(--radius-s);transition:color .15s;text-decoration:none;cursor:pointer;font-family:var(--sans);-webkit-tap-highlight-color:transparent}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-item:not(.active):active{color:var(--ink)}.more-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a171573;z-index:200;display:flex;flex-direction:column;justify-content:flex-end;animation:fade .2s ease}.more-sheet{background:var(--paper);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:8px 12px calc(max(env(safe-area-inset-bottom),12px) + 72px);display:flex;flex-direction:column;gap:2px;animation:sheet-up .25s cubic-bezier(.2,.8,.2,1)}.more-sheet-handle{width:40px;height:4px;background:var(--line);border-radius:2px;margin:0 auto 12px}.more-sheet-item{display:flex;align-items:center;gap:16px;padding:14px 16px;border-radius:var(--radius-m);color:var(--ink);font-size:15px;font-weight:500;text-decoration:none;transition:background .15s;-webkit-tap-highlight-color:transparent}.more-sheet-item:active{background:var(--paper-2)}.more-sheet-item.active{color:var(--accent);background:var(--accent-soft)}@keyframes sheet-up{0%{transform:translateY(100%)}}.tx-desktop{display:block}.tx-mobile{display:none;flex-direction:column}.tx-card{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line-2)}.tx-card:last-child{border-bottom:0}.tx-card-main{flex:1;min-width:0}.tx-card-row1{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:3px}.tx-card-place{font-size:14px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.tx-card-amount{font-size:14px;font-weight:600;flex-shrink:0;font-variant-numeric:tabular-nums}.tx-card-amount.pos{color:var(--pos)}.tx-card-row2{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.tx-card-meta{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx-card-acts{display:flex;gap:4px;flex-shrink:0}@media(max-width:640px){.bottom-nav{display:flex}.sidebar{display:none}.main{padding:16px 16px calc(72px + max(env(safe-area-inset-bottom),0px))}.topbar{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:16px}.topbar-right{width:100%;display:flex;justify-content:space-between;align-items:center}.pill-group{overflow-x:auto;-webkit-overflow-scrolling:touch}.pill-group::-webkit-scrollbar{display:none}.hide-on-mobile{display:none!important}.page-head{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:16px}.page-head h1{font-size:28px}.page-head .right{width:100%;display:flex;justify-content:flex-end}.dash-grid{grid-template-columns:1fr}.hero{grid-column:1;grid-row:auto;padding:22px 20px 20px}.left-spend,.panel-budgets{grid-column:1;grid-row:auto}.panel-trans{grid-column:1}.dash-charts{grid-column:1;grid-template-columns:1fr}.dash-chart-full{grid-column:1}.hero .big{font-size:52px}.hero .big .pre{font-size:26px}.hero .big .cents{font-size:22px}.hero .breakdown{gap:8px}.hero .breakdown .bv{font-size:18px}.left-spend .num-big{font-size:38px}.tx-grid{grid-template-columns:1fr}.tx-grid .tx:nth-last-child(-n+3){border-bottom:1px solid var(--line-2)}.tx-grid .tx:last-child{border-bottom:0}.acct-grid{grid-template-columns:1fr}.hero .accounts-strip{display:grid;grid-template-columns:repeat(2,1fr)}.acct-chip{flex:unset}.acct-chip .nm{white-space:normal;overflow:visible;text-overflow:unset}.reports-summary-grid{grid-template-columns:repeat(2,1fr)!important}.reports-grid{grid-template-columns:1fr}.cat-filter-grid{grid-template-columns:1fr!important}.chart-card.full{grid-column:1}.donut-wrap{flex-direction:column}.donut-legend,.search-bar{min-width:unset;width:100%}.filters-bar{overflow-x:auto;flex-wrap:nowrap;padding-bottom:8px;-webkit-overflow-scrolling:touch}.filters-bar::-webkit-scrollbar{display:none}.tx-desktop{display:none}.tx-mobile{display:flex}.row-actions{opacity:1}.modal-back{align-items:flex-end}.modal{width:100%;max-width:100%;border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:24px 20px calc(max(env(safe-area-inset-bottom),16px) + 16px);animation:sheet-up .3s cubic-bezier(.2,.8,.2,1)}.field-grid{grid-template-columns:1fr}.form-layout{flex-direction:column!important}.form-panel-sidebar{width:100%!important;border-left:none!important;padding-left:0!important;border-top:1px solid var(--line);padding-top:16px;max-height:180px;overflow-y:auto}.amt-input input{font-size:36px}.amt-input .pre{font-size:28px}.budget-summary{grid-template-columns:1fr 1fr;gap:14px}.budget-summary .bsm-big{font-size:34px}.transfer-wrap{padding-top:0;max-width:100%}.transfer-grid{grid-template-columns:1fr!important}.profile-head{margin-bottom:8px}.section-title,.cat-section-title{font-size:22px}}
