@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-cyrillic-ext-wght-normal-BOeWTOD4.woff2) 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:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-cyrillic-wght-normal-DqGufNeO.woff2) format("woff2-variations");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-greek-ext-wght-normal-DlzME5K_.woff2) format("woff2-variations");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-greek-wght-normal-CkhJZR-_.woff2) format("woff2-variations");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-vietnamese-wght-normal-CBcvBZtf.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:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-latin-ext-wght-normal-DO1Apj_S.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:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-latin-wght-normal-Dx4kXJAl.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{--page: #eceef3;--surface: #ffffff;--surface-2: #f4f6fa;--ink: #0b0c0e;--ink-soft: #51545c;--ink-faint: #8a8f98;--line: #e3e6ec;--line-strong: #d3d7e0;--accent: #4f46e5;--accent-hover: #4338ca;--accent-soft: #eef0ff;--income: #16a34a;--income-deep: #15803d;--income-soft: #e9f7ef;--expense: #dc2626;--expense-deep: #b91c1c;--expense-soft: #fdecec;--danger: #dc2626;--radius: 14px;--radius-sm: 10px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow: 0 1px 3px rgba(15, 23, 42, .07), 0 6px 16px -6px rgba(15, 23, 42, .12);--shadow-md: 0 2px 6px rgba(15, 23, 42, .08), 0 12px 26px -8px rgba(15, 23, 42, .16);--font: "Inter Variable", system-ui, -apple-system, "Segoe UI", sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font);color:var(--ink);background:var(--page);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;letter-spacing:-.006em}button,input,select{font-family:inherit;font-size:inherit;color:inherit}button{cursor:pointer}:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-soft);border-color:var(--accent)!important;border-radius:8px}.topbar{position:sticky;top:0;z-index:100;background:#ffffffd1;-webkit-backdrop-filter:saturate(180%) blur(12px);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}.topbar-inner{max-width:1220px;margin:0 auto;padding:12px 28px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}.brand{display:flex;align-items:center;gap:12px}.brand-glyph{display:block;flex-shrink:0}.brand-name{font-weight:700;font-size:1.18rem;letter-spacing:-.02em;margin:0}.header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.view-toggle{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:3px}.view-toggle button{border:0;background:transparent;color:var(--ink-soft);padding:7px 16px;border-radius:8px;font-weight:600;font-size:.88rem;transition:background .18s ease,color .18s ease,box-shadow .18s ease}.view-toggle button.is-active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.btn-print{border:1px solid var(--line-strong);background:var(--surface);color:var(--ink-soft);padding:8px 16px;border-radius:10px;font-weight:600;font-size:.88rem;transition:border-color .18s ease,color .18s ease,background .18s ease}.btn-print:hover{border-color:var(--ink-faint);color:var(--ink)}.user-chip{display:inline-flex;align-items:center;gap:8px;padding:4px 5px 4px 12px;background:var(--surface);border:1px solid var(--line);border-radius:10px}.user-name{font-weight:600;font-size:.85rem;color:var(--ink-soft);max-width:16ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-signout{border:0;background:var(--surface-2);color:var(--ink);padding:6px 12px;border-radius:8px;font-weight:600;font-size:.82rem;transition:background .15s ease,color .15s ease}.btn-signout:hover{background:var(--accent);color:#fff}.app{max-width:1220px;margin:0 auto;padding:30px 28px 64px}.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);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.auth-card h1{font-weight:700;font-size:1.7rem;letter-spacing:-.02em;margin:6px 0 0;color:var(--ink)}.auth-card p{margin:0;color:var(--ink-soft);font-size:.96rem;line-height:1.5}.auth-login{margin-top:10px;border:0;background:var(--accent);color:#fff;padding:12px 26px;border-radius:10px;font-weight:600;font-size:1rem;transition:background .18s ease}.auth-login:hover{background:var(--accent-hover)}.banner-error{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;background:var(--expense-soft);border:1px solid rgba(220,38,38,.25);color:var(--expense-deep);border-radius:var(--radius-sm);padding:12px 18px;margin-bottom:22px;font-size:.9rem}.banner-error button{border:1px solid currentColor;background:transparent;color:inherit;padding:6px 14px;border-radius:8px;font-weight:600}.loading{padding:80px 0;text-align:center;color:var(--ink-soft);font-size:1.1rem}.hero{display:grid;grid-template-columns:1.6fr 1fr;gap:20px;margin-bottom:28px}.summary,.donut-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px 24px}.summary-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px}.stat{display:flex;flex-direction:column;gap:3px;padding:16px;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--line)}.stat-label{font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-faint)}.stat-value{font-weight:700;font-size:clamp(1.35rem,2.3vw,1.85rem);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.stat-unit{font-size:.78rem;color:var(--ink-soft)}.stat-extra{font-size:.74rem;color:var(--ink-soft);font-variant-numeric:tabular-nums;margin-top:2px}.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:.85}.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}.stat-balance .stat-extra{color:inherit;opacity:.8}.balance-bar{display:flex;flex-direction:column;gap:10px}.balance-track{display:grid;grid-template-columns:80px 1fr;align-items:center;gap:12px}.balance-track-label{font-size:.8rem;font-weight:500;color:var(--ink-soft)}.balance-rail{height:8px;border-radius:999px;background:var(--surface-2);overflow:hidden}.balance-fill{height:100%;border-radius:999px}.fill-income{background:var(--income)}.fill-expense{background:var(--expense)}.donut-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.donut-title{margin:0;font-weight:700;font-size:1.02rem;letter-spacing:-.01em}.donut-toggle{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:9px;padding:3px;flex-shrink:0}.donut-toggle button{border:0;background:transparent;color:var(--ink-soft);padding:5px 11px;border-radius:7px;font-weight:600;font-size:.76rem;transition:background .18s ease,color .18s ease,box-shadow .18s ease}.donut-toggle button.is-active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.donut-body{display:flex;gap:18px;align-items:center}.donut-svg{flex-shrink:0}.donut-center-value{font-weight:700;font-size:1.05rem;fill:var(--ink)}.donut-center-label{font-size:.68rem;fill:var(--ink-faint);letter-spacing:.02em}.donut-legend{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;width:100%;max-height:188px;overflow-y:auto}.legend-row{display:grid;grid-template-columns:10px 1fr auto;align-items:center;gap:9px;font-size:.83rem}.legend-dot{width:10px;height:10px;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:.86rem}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--line);margin-bottom:24px}.tab{border:0;background:transparent;color:var(--ink-soft);font-weight:600;font-size:.95rem;padding:11px 16px;border-bottom:2px solid transparent;margin-bottom:-1px;border-radius:8px 8px 0 0;transition:color .15s ease,border-color .15s ease,background .15s ease}.tab:hover{color:var(--ink);background:var(--surface-2)}.tab.is-active{color:var(--accent);border-bottom-color:var(--accent)}.column{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}.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-weight:700;font-size:1.2rem;letter-spacing:-.01em;margin:0}.column-tag{font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:6px}.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-weight:700;font-size:1.35rem;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.column-total-unit{font-size:.76rem;color:var(--ink-soft)}.column-total-extra{font-size:.72rem;color:var(--ink-faint);font-variant-numeric:tabular-nums;margin-top:2px}.category-stack{display:flex;flex-direction:column;gap:12px}.category-card{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 14px 12px;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.category-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-sm)}.category-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}.category-name{flex:1;border:1px solid transparent;background:transparent;font-weight:600;font-size:1rem;letter-spacing:-.01em;padding:6px 8px;border-radius:8px;min-width:0;transition:background .15s ease,border-color .15s ease}.category-name:hover{background:var(--surface)}.category-name:focus{outline:none;background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.category-kind{border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:5px 6px;color:var(--ink-soft);font-size:.76rem;max-width:116px}.category-kind:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.category-total-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:1px;margin-left:auto}.category-total{font-weight:700;font-variant-numeric:tabular-nums;font-size:.98rem}.category-subnote{font-size:.68rem;color:var(--ink-faint);font-variant-numeric:tabular-nums;white-space:nowrap}.category-move{display:flex;flex-direction:column;gap:2px}.category-move-btn{display:grid;place-items:center;width:24px;height:15px;border:1px solid transparent;background:transparent;color:var(--ink-faint);border-radius:6px;transition:color .15s ease,background .15s ease}.category-move-btn:hover:not(:disabled){color:var(--accent);background:var(--accent-soft)}.category-move-btn:disabled{opacity:.3;cursor:default}.category-remove{display:grid;place-items:center;width:28px;height:28px;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:8px;margin-bottom:10px}.item-row{display:flex;flex-direction:column;gap:5px}.item-row-main{display:grid;grid-template-columns:1fr 116px 116px 28px;align-items:center;gap:8px}.item-label,.item-amount,.item-interval{border:1px solid var(--line);background:var(--surface);border-radius:9px;transition:border-color .15s ease,box-shadow .15s ease}.item-label{padding:9px 11px;min-width:0;font-size:.92rem}.item-label:focus,.item-interval:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.item-amount{display:flex;align-items:center;padding:0 11px 0 4px}.item-amount:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.item-amount-input{border:0;background:transparent;text-align:right;width:100%;padding:9px 4px 9px 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:.88rem}.item-interval{padding:9px 6px;color:var(--ink-soft);font-size:.84rem}.item-meta{display:flex;align-items:center;flex-wrap:wrap;gap:6px;padding-left:2px}.tag-chip{display:inline-flex;align-items:center;gap:5px;padding:2px 4px 2px 9px;border-radius:999px;color:#fff;font-size:.74rem;font-weight:600;line-height:1.4}.tag-chip-x{display:grid;place-items:center;width:15px;height:15px;border:0;border-radius:999px;background:#ffffff38;color:#fff;font-size:.9rem;line-height:1;padding:0;transition:background .15s ease}.tag-chip-x:hover{background:#fff6}.tag-add-input{border:1px dashed var(--line-strong);background:transparent;border-radius:999px;padding:3px 11px;font-size:.74rem;color:var(--ink-soft);width:110px;transition:border-color .15s ease,background .15s ease,color .15s ease,width .15s ease}.tag-add-input::placeholder{color:var(--ink-faint)}.tag-add-input:hover{background:var(--surface-2)}.tag-add-input:focus{outline:none;border-style:solid;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);color:var(--ink);width:140px}.item-equiv{font-size:.73rem;color:var(--ink-faint);font-variant-numeric:tabular-nums;margin-left:auto}.item-remove{display:grid;place-items:center;width:28px;height:32px;border:1px solid transparent;background:transparent;color:var(--ink-faint);border-radius:8px;font-size:1.25rem;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:.84rem;margin:2px 2px 8px}.add-item,.add-category{width:100%;border:1px dashed var(--line-strong);background:transparent;color:var(--ink-soft);padding:10px 12px;border-radius:9px;font-weight:600;font-size:.86rem;transition:border-color .16s ease,color .16s ease,background .16s ease}.add-category{margin-top:14px;padding:12px}.add-item:hover,.add-category:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.accent-income{color:var(--income-deep)}.accent-expense{color:var(--expense-deep)}.dashboard{display:flex;flex-direction:column;gap:16px;margin-top:20px}.dash-empty{color:var(--ink-faint);font-size:.9rem;margin:0}.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.kpi-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;align-items:start}.kpi{display:flex;flex-direction:column;gap:5px;padding:16px 18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}.kpi-card{gap:12px}.kpi-label{font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-faint)}.kpi-value{font-weight:700;font-size:1.5rem;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.kpi-sub{font-size:.75rem;color:var(--ink-soft)}.kpi-bar{height:6px;border-radius:999px;background:var(--surface-2);overflow:hidden}.kpi-bar-fill{height:100%;border-radius:999px}.kpi-note{font-size:.74rem;color:var(--ink-faint);margin:0}.kpi-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}.kpi-list-row{display:flex;align-items:center;gap:10px;font-size:.86rem}.kpi-list-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink-soft)}.kpi-bar-inline{width:68px;flex-shrink:0}.kpi-list-value{font-variant-numeric:tabular-nums;font-weight:600;white-space:nowrap}.kpi-list-share{color:var(--ink-faint);font-weight:500;margin-left:2px}.ratio-list{display:flex;flex-direction:column;gap:9px}.ratio-row{display:grid;grid-template-columns:84px 1fr auto;align-items:center;gap:10px;font-size:.84rem}.ratio-label{color:var(--ink-soft)}.ratio-track{position:relative;height:8px;border-radius:999px;background:var(--surface-2)}.ratio-fill{position:absolute;left:0;top:0;height:100%;border-radius:999px}.ratio-target{position:absolute;top:-3px;height:14px;width:2px;background:var(--ink);border-radius:2px;transform:translate(-1px)}.ratio-value{font-variant-numeric:tabular-nums;font-weight:600;white-space:nowrap}.ratio-goal{color:var(--ink-faint);font-weight:500}.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:.8rem}@media (max-width: 940px){.hero{grid-template-columns:1fr}.kpi-row{grid-template-columns:repeat(2,1fr)}}@media (max-width: 560px){.topbar-inner{padding:10px 16px}.app{padding:22px 16px 48px}.summary-stats,.kpi-row{grid-template-columns:1fr}.item-row-main{grid-template-columns:1fr 96px 28px;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}.item-equiv{margin-left:0}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media print{.topbar{position:static;background:#fff;-webkit-backdrop-filter:none;backdrop-filter:none}.header-actions,.add-item,.add-category,.item-remove,.category-remove,.category-move,.tag-add-input,.tag-chip-x,.banner-error{display:none!important}.column,.summary,.donut-panel,.category-card{box-shadow:none;break-inside:avoid}}
