@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-vietnamese-wght-normal-CnvboYUG.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-latin-ext-wght-normal-Ca2vKHc0.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-latin-wght-normal-ukD16Tqj.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Hanken Grotesk Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(data:font/woff2;base64,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) format("woff2-variations");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Hanken Grotesk Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/hanken-grotesk-vietnamese-wght-normal-CHiFlh_0.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Hanken Grotesk Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/hanken-grotesk-latin-ext-wght-normal-Dg-wlmqe.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Hanken Grotesk Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/hanken-grotesk-latin-wght-normal-CaVRRdDk.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--paper: #f3ecdf;--paper-tint: #ece2d1;--surface: #fbf7ef;--surface-raised: #ffffff;--ink: #221e18;--ink-soft: #6a6253;--ink-faint: #9a9079;--line: #e4d8c2;--line-strong: #d2c2a6;--income: #1f6b4f;--income-deep: #14503b;--income-soft: #e6f0e8;--expense: #b4502e;--expense-deep: #8f3c1f;--expense-soft: #f5e7de;--accent: #c8962b;--danger: #b23a2e;--radius: 16px;--radius-sm: 10px;--shadow-sm: 0 1px 2px rgba(34, 30, 24, .05);--shadow: 0 1px 2px rgba(34, 30, 24, .04), 0 14px 34px -18px rgba(34, 30, 24, .28);--font-display: "Fraunces Variable", Georgia, "Times New Roman", serif;--font-body: "Hanken Grotesk Variable", system-ui, -apple-system, sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font-body);color:var(--ink);background-color:var(--paper);background-image:radial-gradient(1100px 540px at 12% -8%,rgba(31,107,79,.08),transparent 60%),radial-gradient(900px 520px at 108% 4%,rgba(180,80,46,.09),transparent 55%);background-attachment:fixed;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,select{font-family:inherit;font-size:inherit;color:inherit}button{cursor:pointer}.app{max-width:1220px;margin:0 auto;padding:40px 28px 64px}.app-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:30px}.brand{display:flex;align-items:center;gap:18px}.brand-mark{display:grid;place-items:center;width:56px;height:56px;border-radius:50%;background:var(--income);color:#fbf7ef;font-family:var(--font-display);font-weight:600;font-size:1.7rem;box-shadow:inset 0 0 0 4px #fbf7ef2e;flex-shrink:0}.brand-text h1{font-family:var(--font-display);font-weight:600;font-size:clamp(1.9rem,3.2vw,2.6rem);line-height:1.04;letter-spacing:-.015em;margin:0}.brand-text p{margin:6px 0 0;color:var(--ink-soft);font-size:.95rem;max-width:42ch}.header-actions{display:flex;align-items:center;gap:12px}.view-toggle{display:inline-flex;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:4px;box-shadow:var(--shadow-sm)}.view-toggle button{border:0;background:transparent;color:var(--ink-soft);padding:8px 18px;border-radius:999px;font-weight:600;font-size:.9rem;transition:background .18s ease,color .18s ease}.view-toggle button.is-active{background:var(--ink);color:var(--paper)}.btn-print{border:1px solid var(--line-strong);background:var(--surface);color:var(--ink);padding:9px 18px;border-radius:999px;font-weight:600;font-size:.9rem;box-shadow:var(--shadow-sm);transition:transform .15s ease,border-color .18s ease,background .18s ease}.btn-print:hover{transform:translateY(-1px);border-color:var(--ink);background:var(--surface-raised)}.user-chip{display:inline-flex;align-items:center;gap:10px;padding:5px 6px 5px 14px;background:var(--surface);border:1px solid var(--line);border-radius:999px;box-shadow:var(--shadow-sm)}.user-name{font-weight:600;font-size:.88rem;color:var(--ink-soft);max-width:18ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-signout{border:0;background:var(--ink);color:var(--paper);padding:7px 14px;border-radius:999px;font-weight:600;font-size:.85rem;transition:opacity .15s ease}.btn-signout:hover{opacity:.85}.auth-gate{min-height:100dvh;display:grid;place-items:center;padding:24px}.auth-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;max-width:420px;padding:44px 36px;background:var(--surface-raised);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.auth-card h1{font-family:var(--font-display);font-weight:600;font-size:1.9rem;margin:6px 0 0;color:var(--ink)}.auth-card p{margin:0;color:var(--ink-soft);font-size:.98rem;line-height:1.5}.auth-login{margin-top:10px;border:0;background:var(--income);color:#fbf7ef;padding:12px 26px;border-radius:999px;font-weight:600;font-size:1rem;box-shadow:var(--shadow-sm);transition:transform .15s ease,background .18s ease}.auth-login:hover{transform:translateY(-1px);background:var(--income-deep)}.banner-error{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;background:var(--expense-soft);border:1px solid rgba(180,80,46,.4);color:var(--expense-deep);border-radius:var(--radius-sm);padding:12px 18px;margin-bottom:22px;font-size:.92rem}.banner-error button{border:1px solid currentColor;background:transparent;color:inherit;padding:6px 14px;border-radius:999px;font-weight:600}.loading{padding:80px 0;text-align:center;color:var(--ink-soft);font-family:var(--font-display);font-size:1.3rem}.overview{display:grid;grid-template-columns:1.55fr 1fr;gap:22px;margin-bottom:30px}.summary,.donut-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px 26px}.summary-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:22px}.stat{display:flex;flex-direction:column;gap:4px;padding:16px 18px;border-radius:var(--radius-sm);background:var(--surface-raised);border:1px solid var(--line)}.stat-label{font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint)}.stat-value{font-family:var(--font-display);font-weight:600;font-size:clamp(1.4rem,2.4vw,1.95rem);font-variant-numeric:tabular-nums;letter-spacing:-.01em}.stat-unit{font-size:.8rem;color:var(--ink-soft)}.stat-balance{border:0}.stat-balance.is-positive{background:var(--income-soft);color:var(--income-deep)}.stat-balance.is-positive .stat-label,.stat-balance.is-positive .stat-unit{color:var(--income-deep);opacity:.8}.stat-balance.is-negative{background:var(--expense-soft);color:var(--expense-deep)}.stat-balance.is-negative .stat-label,.stat-balance.is-negative .stat-unit{color:var(--expense-deep);opacity:.85}.balance-bar{display:flex;flex-direction:column;gap:12px}.balance-track{display:grid;grid-template-columns:86px 1fr;align-items:center;gap:12px}.balance-track-label{font-size:.82rem;font-weight:600;color:var(--ink-soft)}.balance-rail{height:12px;border-radius:999px;background:var(--paper-tint);overflow:hidden}.balance-fill{height:100%;border-radius:999px}.fill-income{background:linear-gradient(90deg,var(--income),#2c8c66)}.fill-expense{background:linear-gradient(90deg,var(--expense),#d06a44)}.donut-title{margin:0 0 14px;font-family:var(--font-display);font-weight:600;font-size:1.2rem}.donut-body{display:flex;gap:18px;align-items:center}.donut-svg{flex-shrink:0}.donut-center-value{font-family:var(--font-display);font-weight:600;font-size:1.05rem;fill:var(--ink)}.donut-center-label{font-size:.7rem;fill:var(--ink-faint);letter-spacing:.04em}.donut-legend{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px;width:100%;max-height:188px;overflow-y:auto}.legend-row{display:grid;grid-template-columns:12px 1fr auto;align-items:center;gap:8px;font-size:.84rem}.legend-dot{width:11px;height:11px;border-radius:3px}.legend-name{color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.legend-value{font-variant-numeric:tabular-nums;font-weight:600}.legend-empty{color:var(--ink-faint);font-size:.88rem}.columns{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:start}.column{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;position:relative;overflow:hidden}.column:before{content:"";position:absolute;inset:0 0 auto 0;height:4px}.column-income:before{background:linear-gradient(90deg,var(--income),#36a079)}.column-expense:before{background:linear-gradient(90deg,var(--expense),#d9764f)}.column-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;padding-bottom:16px;margin-bottom:16px;border-bottom:1px solid var(--line)}.column-title{display:flex;align-items:center;gap:10px}.column-title h2{font-family:var(--font-display);font-weight:600;font-size:1.5rem;margin:0}.column-tag{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 9px;border-radius:999px}.column-tag.accent-income{background:var(--income-soft);color:var(--income-deep)}.column-tag.accent-expense{background:var(--expense-soft);color:var(--expense-deep)}.column-total{text-align:right;display:flex;flex-direction:column}.column-total-value{font-family:var(--font-display);font-weight:600;font-size:1.5rem;font-variant-numeric:tabular-nums}.column-total-unit{font-size:.78rem;color:var(--ink-soft)}.category-stack{display:flex;flex-direction:column;gap:14px}.category-card{background:var(--surface-raised);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 14px 12px}.category-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}.category-name{flex:1;border:1px solid transparent;background:transparent;font-family:var(--font-display);font-weight:600;font-size:1.05rem;padding:5px 8px;border-radius:8px;min-width:0;transition:background .15s ease,border-color .15s ease}.category-name:hover{background:var(--paper)}.category-name:focus{outline:none;background:var(--surface);border-color:var(--line-strong)}.category-total{font-family:var(--font-display);font-weight:600;font-variant-numeric:tabular-nums;font-size:1rem}.category-remove{display:grid;place-items:center;width:30px;height:30px;border:1px solid transparent;background:transparent;color:var(--ink-faint);border-radius:8px;transition:color .15s ease,background .15s ease}.category-remove:hover{color:var(--danger);background:var(--expense-soft)}.item-list{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.item-row{display:grid;grid-template-columns:1fr 116px 116px 30px;align-items:center;gap:8px}.item-label{border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:8px 10px;min-width:0;transition:border-color .15s ease,box-shadow .15s ease}.item-label:focus{outline:none;border-color:var(--ink-soft);box-shadow:0 0 0 3px #221e1812}.item-amount{display:flex;align-items:center;border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:0 10px 0 4px;transition:border-color .15s ease,box-shadow .15s ease}.item-amount:focus-within{border-color:currentColor}.item-amount.accent-income:focus-within{box-shadow:0 0 0 3px #1f6b4f24;border-color:var(--income)}.item-amount.accent-expense:focus-within{box-shadow:0 0 0 3px #b4502e24;border-color:var(--expense)}.item-amount-input{border:0;background:transparent;text-align:right;width:100%;padding:8px 4px 8px 8px;font-variant-numeric:tabular-nums;font-weight:600}.item-amount-input:focus{outline:none}.item-currency{color:var(--ink-faint);font-weight:600;font-size:.9rem}.item-interval{border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:8px 6px;color:var(--ink-soft);font-size:.86rem}.item-interval:focus{outline:none;border-color:var(--ink-soft)}.item-remove{display:grid;place-items:center;width:30px;height:32px;border:1px solid transparent;background:transparent;color:var(--ink-faint);border-radius:8px;font-size:1.3rem;line-height:1;transition:color .15s ease,background .15s ease}.item-remove:hover{color:var(--danger);background:var(--expense-soft)}.item-empty{color:var(--ink-faint);font-size:.85rem;margin:4px 2px 8px}.add-item,.add-category{width:100%;border:1px dashed var(--line-strong);background:transparent;color:var(--ink-soft);padding:9px 12px;border-radius:9px;font-weight:600;font-size:.88rem;transition:border-color .16s ease,color .16s ease,background .16s ease}.add-category{margin-top:16px;padding:12px}.add-item.accent-income:hover,.add-category.accent-income:hover{border-color:var(--income);color:var(--income-deep);background:var(--income-soft)}.add-item.accent-expense:hover,.add-category.accent-expense:hover{border-color:var(--expense);color:var(--expense-deep);background:var(--expense-soft)}.accent-income{color:var(--income-deep)}.accent-expense{color:var(--expense-deep)}.app-footer{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:36px;padding-top:18px;border-top:1px solid var(--line);color:var(--ink-faint);font-size:.82rem}@media (max-width: 940px){.overview,.columns{grid-template-columns:1fr}}@media (max-width: 560px){.app{padding:24px 16px 48px}.summary-stats{grid-template-columns:1fr}.item-row{grid-template-columns:1fr 96px 30px;grid-template-areas:"label label label" "amount interval remove";gap:6px}.item-label{grid-area:label}.item-amount{grid-area:amount}.item-interval{grid-area:interval}.item-remove{grid-area:remove}.donut-body{flex-direction:column}}@media print{body{background:#fff}.header-actions,.add-item,.add-category,.item-remove,.category-remove,.banner-error{display:none!important}.column,.summary,.donut-panel,.category-card{box-shadow:none;break-inside:avoid}}
