@font-face{font-family:Plus Jakarta Sans Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(data:font/woff2;base64,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)format("woff2-variations");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Plus Jakarta Sans Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/assets/plus-jakarta-sans-vietnamese-wght-normal-qRpaaN48.woff2)format("woff2-variations");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Plus Jakarta Sans Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/assets/plus-jakarta-sans-latin-ext-wght-normal-DmpS2jIq.woff2)format("woff2-variations");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,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:Plus Jakarta Sans Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/assets/plus-jakarta-sans-latin-wght-normal-eXO_dkmS.woff2)format("woff2-variations");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--bg:#f4f5f2;--surface:#fff;--shell:#16241f0b;--hairline:#16241f14;--ink:#17211d;--ink-2:#52605a;--ink-3:#8a958f;--accent:#0e8a6b;--accent-ink:#0b6a53;--accent-soft:#0e8a6b1a;--negative:#c43d3f;--negative-soft:#c43d3f17;--warn:#b07c1f;--warn-soft:#b07c1f1f;--r-outer:24px;--r-inner:17px;--ease:cubic-bezier(.32, .72, 0, 1);--shadow-soft:0 1px 2px #17211d08, 0 8px 32px -12px #17211d24;--shadow-float:0 2px 6px #17211d0d, 0 24px 64px -20px #17211d38;--nav-h:84px}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;min-height:100dvh;font-family:Plus Jakarta Sans Variable,ui-sans-serif,system-ui,sans-serif;font-size:15px;line-height:1.55}button,input,select,textarea{font:inherit;color:inherit}a{color:inherit;text-decoration:none}h1,h2,h3{letter-spacing:-.02em;font-weight:800;line-height:1.15}h1{font-size:clamp(1.6rem,4vw,2.1rem)}h2{font-size:1.15rem}h3{font-size:.95rem}.tnum{font-variant-numeric:tabular-nums}@keyframes rise{0%{opacity:0;filter:blur(6px);transform:translateY(16px)}to{opacity:1;filter:blur();transform:translateY(0)}}.rise{animation:rise .8s var(--ease) both}.rise-1{animation-delay:50ms}.rise-2{animation-delay:.12s}.rise-3{animation-delay:.19s}.rise-4{animation-delay:.26s}@media (prefers-reduced-motion:reduce){.rise,.rise-1,.rise-2,.rise-3,.rise-4{animation:none}*{transition-duration:.01ms!important}}.shell{background:var(--shell);border:1px solid var(--hairline);border-radius:var(--r-outer);padding:6px}.card{background:var(--surface);border-radius:var(--r-inner);box-shadow:var(--shadow-soft), inset 0 1px 1px #ffffffe6;padding:20px}.shell>.card{box-shadow:inset 0 1px 1px #ffffffe6}.eyebrow{letter-spacing:.2em;text-transform:uppercase;color:var(--ink-2);background:var(--shell);border:1px solid var(--hairline);border-radius:999px;padding:4px 12px;font-size:10px;font-weight:700;display:inline-block}.btn{cursor:pointer;background:var(--ink);color:#fff;transition:transform .5s var(--ease), box-shadow .5s var(--ease), background .5s var(--ease), opacity .3s var(--ease);border:none;border-radius:999px;justify-content:center;align-items:center;gap:10px;padding:12px 24px;font-size:14px;font-weight:700;display:inline-flex;box-shadow:0 12px 28px -12px #17211d73}.btn:hover{transform:translateY(-1px)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.45;pointer-events:none}.btn-accent{background:var(--accent);box-shadow:0 12px 28px -12px #0e8a6b8c}.btn-accent:hover{background:var(--accent-ink)}.btn-ghost{color:var(--ink);border:1px solid var(--hairline);box-shadow:none;background:0 0}.btn-ghost:hover{background:var(--shell)}.btn-danger{background:var(--negative);box-shadow:0 12px 28px -12px #c43d3f80}.btn-sm{padding:8px 16px;font-size:13px}.field{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.field label{color:var(--ink-2);letter-spacing:.02em;font-size:12px;font-weight:700}.input,select.input,textarea.input{background:var(--surface);border:1px solid var(--hairline);width:100%;transition:border-color .4s var(--ease), box-shadow .4s var(--ease);border-radius:14px;padding:12px 16px;font-size:15px;box-shadow:inset 0 1px 2px #17211d08}.input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);outline:none}.input-error{border-color:var(--negative)}.form-error{color:var(--negative);font-size:13px;font-weight:600}.hint{color:var(--ink-3);font-size:12px}.seg{background:var(--shell);border:1px solid var(--hairline);border-radius:999px;grid-template-columns:1fr 1fr;gap:4px;padding:4px;display:grid}.seg button{color:var(--ink-2);cursor:pointer;transition:background .4s var(--ease), color .4s var(--ease), box-shadow .4s var(--ease);background:0 0;border:none;border-radius:999px;padding:9px 8px;font-size:13px;font-weight:700}.seg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-soft)}.seg button.on.neg{color:var(--negative)}.seg button.on.pos{color:var(--accent-ink)}.amount-pos{color:var(--accent-ink);font-weight:700}.amount-neg{color:var(--ink);font-weight:700}.pill{border-radius:999px;align-items:center;padding:3px 10px;font-size:12px;font-weight:700;display:inline-flex}.pill-pos{background:var(--accent-soft);color:var(--accent-ink)}.pill-neg{background:var(--negative-soft);color:var(--negative)}.pill-zero{background:var(--shell);color:var(--ink-3)}.pill-warn{background:var(--warn-soft);color:var(--warn)}.app{max-width:1160px;min-height:100dvh;margin:0 auto;display:flex}.app-main{min-width:0;padding:24px 16px calc(var(--nav-h) + 32px);flex:1}@media (width>=900px){.app-main{padding:40px 40px 64px}}.sidebar{display:none}@media (width>=900px){.sidebar{flex-direction:column;flex-shrink:0;gap:6px;width:232px;height:100dvh;padding:40px 20px;display:flex;position:sticky;top:0}.sidebar .brand{padding:0 14px 26px}.sidebar a{color:var(--ink-2);transition:background .4s var(--ease), color .4s var(--ease);border-radius:14px;align-items:center;gap:12px;padding:11px 14px;font-size:14px;font-weight:600;display:flex}.sidebar a:hover{background:var(--shell)}.sidebar a.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-soft)}.sidebar a svg{width:19px;height:19px}}.brand{letter-spacing:-.03em;font-size:19px;font-weight:800}.brand em{color:var(--accent);font-style:normal}.bottomnav{left:50%;bottom:max(14px, env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(20px);border:1px solid var(--hairline);box-shadow:var(--shadow-float);z-index:40;background:#ffffffd1;border-radius:999px;gap:2px;padding:6px;display:flex;position:fixed;transform:translate(-50%)}.bottomnav a{width:62px;color:var(--ink-3);transition:background .5s var(--ease), color .5s var(--ease);border-radius:999px;flex-direction:column;align-items:center;gap:2px;padding:8px 0 6px;font-size:10px;font-weight:700;display:flex}.bottomnav a svg{width:20px;height:20px}.bottomnav a.on{color:var(--accent-ink);background:var(--accent-soft)}@media (width>=900px){.bottomnav{display:none}}.page-head{justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:20px;display:flex}.page-head .sub{color:var(--ink-2);margin-top:4px;font-size:14px}.rowlist{flex-direction:column;display:flex}.rowlist .row{border-bottom:1px solid var(--hairline);align-items:center;gap:14px;padding:13px 4px;display:flex}.rowlist .row:last-child{border-bottom:none}.row .grow{flex:1;min-width:0}.row .title{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.row .meta{color:var(--ink-3);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.row-click{cursor:pointer;transition:background .3s var(--ease);border-radius:12px}.row-click:hover{background:var(--shell)}.datehead{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);padding:18px 4px 6px;font-size:11px;font-weight:700}.modal-backdrop{z-index:50;-webkit-backdrop-filter:blur(8px);animation:fadein .4s var(--ease) both;background:#17211d66;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}@media (width>=640px){.modal-backdrop{align-items:center;padding:24px}}@keyframes fadein{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg);width:100%;max-width:480px;max-height:92dvh;padding:24px 20px max(24px, env(safe-area-inset-bottom));animation:slideup .55s var(--ease) both;border-radius:28px 28px 0 0;overflow-y:auto}@media (width>=640px){.modal{border-radius:28px;padding:28px}}@keyframes slideup{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.modal-head{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-x{border:1px solid var(--hairline);background:var(--surface);cursor:pointer;width:34px;height:34px;transition:transform .4s var(--ease), background .4s var(--ease);border-radius:999px;justify-content:center;align-items:center;display:flex}.modal-x:hover{background:var(--shell);transform:rotate(90deg)}.toasts{left:50%;bottom:calc(var(--nav-h) + 12px);z-index:60;pointer-events:none;flex-direction:column;align-items:center;gap:8px;display:flex;position:fixed;transform:translate(-50%)}@media (width>=900px){.toasts{bottom:28px}}.toast{background:var(--ink);color:#fff;box-shadow:var(--shadow-float);animation:slideup .5s var(--ease) both;text-align:center;border-radius:999px;max-width:min(90vw,420px);padding:11px 22px;font-size:13.5px;font-weight:600}.toast.err{background:var(--negative)}.budget-group-head{justify-content:space-between;align-items:center;padding:16px 4px 8px;display:flex}.budget-group-head h3{color:var(--ink-2);letter-spacing:.1em;text-transform:uppercase;font-size:12px}.budget-cols{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);text-align:right;grid-template-columns:1fr 84px 92px;gap:8px;padding:0 4px 6px;font-size:10px;font-weight:700;display:grid}.budget-cols span:first-child{text-align:left}.budget-row{border-bottom:1px solid var(--hairline);grid-template-columns:1fr 84px 92px;align-items:center;gap:8px;padding:9px 4px;display:grid}.budget-row:last-child{border-bottom:none}.budget-row .catname{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.assign-input{text-align:right;font-variant-numeric:tabular-nums;width:84px;transition:border-color .3s var(--ease), background .3s var(--ease), box-shadow .3s var(--ease);background:0 0;border:1px solid #0000;border-radius:10px;padding:7px 8px;font-size:13.5px;font-weight:700}.assign-input:hover{background:var(--shell)}.assign-input:focus{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.budget-row .avail{text-align:right}.hero-num{letter-spacing:-.03em;font-size:clamp(2rem,7vw,2.9rem);font-weight:800;line-height:1.05}.stat-label{color:var(--ink-2);letter-spacing:.04em;font-size:12px;font-weight:700}.catbar{flex-direction:column;gap:5px;padding:9px 0;display:flex}.catbar .line1{justify-content:space-between;gap:12px;font-size:13.5px;font-weight:600;display:flex}.catbar .track{background:var(--shell);border-radius:999px;height:7px;overflow:hidden}.catbar .fill{background:var(--accent);height:100%;transition:width .9s var(--ease);border-radius:999px}.auth-wrap{background:radial-gradient(60vw 60vw at 85% -10%, #0e8a6b12, transparent 60%), radial-gradient(50vw 50vw at -10% 110%, #0e8a6b0d, transparent 60%), var(--bg);justify-content:center;align-items:center;min-height:100dvh;padding:24px 16px;display:flex}.auth-card{width:100%;max-width:400px}.auth-links{color:var(--ink-2);justify-content:space-between;margin-top:18px;font-size:13.5px;font-weight:600;display:flex}.auth-links a:hover{color:var(--accent-ink)}.steps{gap:6px;margin-bottom:20px;display:flex}.steps span{background:var(--hairline);height:4px;transition:background .5s var(--ease);border-radius:999px;flex:1}.steps span.on{background:var(--accent)}.dropzone{border:1.5px dashed var(--hairline);border-radius:var(--r-inner);text-align:center;cursor:pointer;transition:border-color .4s var(--ease), background .4s var(--ease);padding:36px 20px}.dropzone:hover{border-color:var(--accent);background:var(--accent-soft)}.table-scroll{overflow-x:auto}.mini-table{border-collapse:collapse;width:100%;font-size:12.5px}.mini-table th{text-align:left;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;padding:6px 10px;font-size:10.5px}.mini-table td{border-top:1px solid var(--hairline);white-space:nowrap;padding:7px 10px}.grid-2{grid-template-columns:1fr;gap:14px;display:grid}@media (width>=720px){.grid-2{grid-template-columns:1fr 1fr}}.stack{flex-direction:column;gap:14px;display:flex}.hstack{align-items:center;gap:10px;display:flex}.spread{justify-content:space-between;align-items:center;gap:10px;display:flex}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-16{margin-bottom:16px}.muted{color:var(--ink-3);font-size:13px}.center{text-align:center}.empty{text-align:center;color:var(--ink-3);padding:36px 16px}.empty .big{color:var(--ink-2);margin-bottom:4px;font-size:15px;font-weight:700}.splash{justify-content:center;align-items:center;min-height:100dvh;display:flex}.spinner{border:3px solid var(--hairline);border-top-color:var(--accent);border-radius:999px;width:28px;height:28px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.legend{color:var(--ink-2);gap:16px;font-size:12px;font-weight:600;display:flex}.legend .dot{border-radius:999px;width:9px;height:9px;margin-right:6px;display:inline-block}.prose{max-width:640px}.prose h2{margin:22px 0 8px}.prose p,.prose li{color:var(--ink-2);margin-bottom:10px;font-size:14.5px}.prose ul{padding-left:20px}
