:root{color-scheme:light;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;color:#222721;background:#f8f5ee;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--bg: #f8f5ee;--surface: rgba(255, 255, 255, .88);--surface-solid: #fffdf8;--surface-muted: #f3efe6;--text: #20231f;--muted: #777a73;--soft-text: #9a9a91;--line: rgba(92, 88, 78, .12);--green: #6baa5b;--green-deep: #4f8d45;--green-soft: #e8f2df;--amber: #efb852;--orange-soft: #fff0d3;--spent: #ff704d;--spent-deep: #e85a37;--spent-soft: #fff0ea;--rose: #ee7777;--shadow: 0 18px 42px rgba(65, 71, 56, .1);--small-shadow: 0 8px 24px rgba(65, 71, 56, .08);--radius-lg: 24px;--radius-md: 18px;--radius-sm: 12px}@media(prefers-color-scheme:dark){:root{color-scheme:dark;--bg: #171b16;--surface: rgba(33, 38, 31, .9);--surface-solid: #22271f;--surface-muted: #2b3028;--text: #f3f0e8;--muted: #bab8ad;--soft-text: #8f9589;--line: rgba(238, 234, 220, .12);--green: #8ac777;--green-deep: #6baa5b;--green-soft: #263823;--amber: #f2c46d;--orange-soft: #3b3323;--spent: #ff8a69;--spent-deep: #ff704d;--spent-soft: #3d2922;--rose: #ff9a9a;--shadow: 0 18px 44px rgba(0, 0, 0, .34);--small-shadow: 0 8px 26px rgba(0, 0, 0, .25)}}*{box-sizing:border-box}html{min-height:100%;background:var(--bg)}body{min-width:320px;min-height:100%;margin:0;color:var(--text);background:linear-gradient(180deg,rgba(255,253,248,.86),rgba(248,245,238,.96) 38%,var(--bg)),var(--bg)}button,input{font:inherit}button{border:0;color:inherit;background:transparent;cursor:pointer;-webkit-tap-highlight-color:transparent}button:disabled{cursor:not-allowed;opacity:.52}button:active{transform:translateY(1px) scale(.99)}input{width:100%;border:0;outline:0;color:var(--text);background:transparent}input::placeholder{color:var(--soft-text)}#root{min-height:100svh}.app-shell{position:relative;width:min(100vw,480px);min-height:100svh;margin:0 auto;overflow-x:hidden;background:linear-gradient(180deg,rgba(255,254,250,.94),rgba(248,245,238,.96) 58%,var(--bg));box-shadow:0 0 0 1px #6e5f440d}@media(prefers-color-scheme:dark){body{background:#111410}.app-shell{background:linear-gradient(180deg,#1d231b,var(--bg))}}.screen{min-height:100svh;padding:max(20px,env(safe-area-inset-top)) 18px 118px}.page{animation:pageIn .22s ease both}@keyframes pageIn{0%{opacity:0}to{opacity:1}}.home-hero{position:relative;display:grid;grid-template-columns:minmax(0,1fr) 172px;align-items:center;min-height:270px;padding:18px 8px 6px}.brand-copy{position:relative;z-index:2}.brand-copy .sparkle{margin:0 0 8px 126px;color:#efcf7c;font-size:18px}.brand-copy h1{position:relative;width:max-content;margin:0 0 28px;font-family:Kaiti SC,STKaiti,KaiTi,serif;font-size:clamp(44px,12vw,62px);font-weight:800;line-height:1;letter-spacing:0}.brand-copy h1:after{position:absolute;left:2px;bottom:-16px;width:42px;height:4px;border-radius:999px;background:var(--green);content:""}.brand-copy p:last-child{max-width:190px;margin:0;color:var(--muted);font-size:18px;font-weight:500;line-height:1.6}.jar-art{position:relative;width:172px;height:220px}.jar-art:before{position:absolute;top:18px;right:0;bottom:8px;left:0;border-radius:48% 52% 45% 55%;background:#e9f2dfc2;content:""}.jar-art:after{position:absolute;right:6px;top:8px;width:102px;height:112px;border-radius:52% 48% 46% 54%;background:#f6e7b494;content:""}.stem{position:absolute;left:84px;top:20px;z-index:2;width:5px;height:126px;border-radius:999px;background:var(--green-deep);transform:rotate(-14deg);transform-origin:bottom}.leaf{position:absolute;z-index:3;width:36px;height:21px;border-radius:100% 0;background:#93c96b}.leaf-a{left:56px;top:16px;transform:rotate(38deg)}.leaf-b{left:92px;top:48px;transform:rotate(-28deg)}.leaf-c{left:60px;top:82px;transform:rotate(22deg);background:#78b966}.jar-neck{position:absolute;left:45px;top:88px;z-index:4;width:86px;height:23px;border:4px solid #9b6631;border-radius:999px;background:repeating-linear-gradient(90deg,#bd7d3a 0,#bd7d3a 8px,#dfac65 8px,#dfac65 14px)}.jar-body{position:absolute;left:38px;top:102px;z-index:2;width:102px;height:92px;border:4px solid rgba(72,130,78,.76);border-radius:16px 16px 32px 32px;background:#eefaec80;box-shadow:inset 13px 0 #ffffff80}.coin{position:absolute;z-index:5;display:grid;place-items:center;border-radius:50%;color:#b26d20;font-weight:800;box-shadow:0 8px 14px #b26d201f}.coin-a{left:25px;bottom:22px;width:54px;height:54px;border:4px solid #e99b30;background:#ffd879;font-size:24px}.coin-b,.coin-c{border:4px solid #e19d30;background:#ffc957}.coin-b{left:78px;bottom:28px;width:48px;height:48px}.coin-c{right:15px;bottom:30px;width:42px;height:42px}.today-card,.overview-card,.stat-card,.record-card,.stats-hero,.category-panel,.backup-section{border:1px solid rgba(255,255,255,.62);background:var(--surface);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.today-card{position:relative;margin-top:4px;padding:24px 24px 22px;border-radius:var(--radius-lg)}.overview-card{margin-top:14px;padding:19px 18px 17px;border-radius:var(--radius-lg)}.overview-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0}.overview-grid>div{min-width:0;padding:4px 14px 2px 0}.overview-grid>div+div{padding-left:16px;border-left:1px solid var(--line)}.overview-grid span{display:block;margin-bottom:10px;color:var(--muted);font-size:14px;font-weight:750}.overview-grid strong{display:block;overflow-wrap:anywhere;font-size:clamp(19px,6vw,25px);line-height:1.15}.saved-text{color:var(--green-deep)}.spent-text{color:var(--spent-deep)}.section-label{margin:0 0 14px;color:var(--text);font-size:17px;font-weight:700}.today-card>strong{display:block;color:var(--green-deep);font-size:clamp(42px,12vw,58px);line-height:1;letter-spacing:0}.divider{height:1px;margin:28px 0 20px;background:var(--line)}.mini-stats{display:grid;grid-template-columns:1fr 1fr;gap:18px}.mini-stats>div+div{padding-left:18px;border-left:1px solid var(--line)}.mini-stats span,.record-main p,.record-side span,.stat-card span,.stat-card p,.stats-hero span,.category-row-title span,.empty-state p{color:var(--muted)}.mini-stats span{display:block;margin-bottom:9px;font-size:15px;font-weight:700}.mini-stats b{display:block;font-size:25px;line-height:1.1;letter-spacing:0;white-space:nowrap}.streak-card{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;width:100%;min-height:70px;margin:18px 0;padding:0 20px;border-radius:18px;background:linear-gradient(90deg,var(--green-soft),rgba(247,241,223,.72));box-shadow:var(--small-shadow);text-align:left}.streak-card .trophy{margin-right:16px;font-size:28px}.streak-card span:nth-child(2){min-width:0;overflow-wrap:anywhere;color:var(--text);font-size:17px;font-weight:700}.streak-card small{display:block;margin-top:2px;color:var(--muted);font-size:12px;font-weight:700}.streak-card b{color:var(--green-deep);font-size:25px}.chevron{font-size:32px}.primary-button{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:62px;border-radius:20px;color:#fff;background:linear-gradient(180deg,#78b968,var(--green-deep));box-shadow:0 12px 22px #508d453d;font-size:20px;font-weight:800}.primary-button span{font-size:26px;line-height:1}.add-button,.save-button{width:100%}.home-actions{display:grid;grid-template-columns:1fr 1fr;gap:14px}.home-actions .primary-button{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;min-height:76px;column-gap:8px;row-gap:1px;padding:0 14px;text-align:left}.home-actions .primary-button>span{grid-row:1 / 3}.home-actions b{font-size:18px;line-height:1.1}.home-actions small{opacity:.86;font-size:12px;font-weight:650}.spent-button{background:linear-gradient(180deg,#ff8d69,var(--spent-deep));box-shadow:0 12px 22px #e85a373d}.encouragement{display:flex;align-items:center;justify-content:center;gap:8px;margin:16px 6px 30px;color:var(--muted);font-size:15px;text-align:center}.encouragement span{color:var(--rose)}.section-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-title-row h2,.category-section h2,.backup-section h2{margin:0;font-size:18px;letter-spacing:0}.section-title-row button{color:var(--green-deep);font-weight:800}.simple-header{display:flex;align-items:center;justify-content:center;min-height:56px}.simple-header h1{margin:0;font-size:21px;font-weight:900;letter-spacing:0}.filter-strip,.range-tabs{display:flex;gap:10px;margin:14px -18px 18px;padding:0 18px 8px;overflow-x:auto;scrollbar-width:none}.filter-strip::-webkit-scrollbar,.range-tabs::-webkit-scrollbar{display:none}.filter-strip button,.range-tabs button{flex:0 0 auto;min-height:40px;padding:0 18px;border-radius:999px;color:var(--muted);background:#ffffffb8;box-shadow:0 8px 18px #4147380d;font-weight:800;white-space:nowrap}.filter-strip button.active,.range-tabs button.active{color:#fff;background:var(--green)}.filter-strip button.spent-filter.active{background:var(--spent)}.record-list{display:grid;gap:12px}.compact-list{gap:10px}.record-card{display:grid;grid-template-columns:48px minmax(0,1fr) auto;gap:13px;align-items:center;padding:14px;border-radius:18px}.record-card.spent-record{border-color:#ff704d24}.category-icon{display:grid;place-items:center;width:44px;height:44px;border-radius:16px;font-size:23px}.category-icon.mini{width:32px;height:32px;border-radius:12px;font-size:17px}.record-main{min-width:0}.record-main h3{margin:4px 0 5px;overflow:hidden;font-size:16px;font-weight:850;text-overflow:ellipsis;white-space:nowrap}.type-badge{display:inline-flex;align-items:center;min-height:22px;padding:0 8px;border-radius:999px;font-size:12px;font-weight:850}.type-badge.saved{color:var(--green-deep);background:var(--green-soft)}.type-badge.spent{color:var(--spent-deep);background:var(--spent-soft)}.record-main p{margin:0;overflow:hidden;font-size:13px;line-height:1.35;text-overflow:ellipsis;white-space:nowrap}.record-side{min-width:74px;text-align:right}.record-side strong{display:block;font-size:14px;white-space:nowrap}.record-side span{display:block;margin-top:6px;font-size:12px}.record-actions{grid-column:2 / 4;display:flex;justify-content:flex-end;gap:8px;padding-top:4px}.record-actions button{min-height:30px;padding:0 12px;border-radius:999px;color:var(--muted);background:var(--surface-muted);font-size:12px;font-weight:800}.record-actions button:last-child{color:#c76161;background:#ee77771f}.floating-add{position:fixed;right:max(20px,calc((100vw - 480px)/2 + 20px));bottom:calc(92px + env(safe-area-inset-bottom));z-index:12;display:grid;place-items:center;width:60px;height:60px;border-radius:50%;color:#fff;background:linear-gradient(180deg,#78b968,var(--green-deep));box-shadow:0 12px 22px #508d454d;font-size:38px;line-height:1}.stats-hero{display:grid;grid-template-columns:minmax(0,1fr) 132px;align-items:center;min-height:136px;margin-bottom:14px;padding:22px 18px;border-radius:var(--radius-lg)}.stats-hero strong{display:block;margin-bottom:8px;color:var(--green-deep);font-size:clamp(35px,10vw,46px);line-height:1}.sparkline svg{width:100%;height:82px}.sparkline path{fill:none;stroke:var(--green-deep);stroke-linecap:round;stroke-width:5}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.stat-card{min-height:92px;padding:15px;border-radius:16px}.stat-card span{display:block;margin-bottom:10px;font-size:14px;font-weight:700}.stat-card strong{display:block;font-size:clamp(18px,5vw,24px);line-height:1.2;overflow-wrap:anywhere}.stat-card p{margin:8px 0 0;font-size:12px}.category-section,.backup-section{margin-top:18px}.category-section h2,.backup-section h2{margin-bottom:12px}.category-panel{display:grid;grid-template-columns:142px minmax(0,1fr);gap:18px;align-items:center;padding:18px;border-radius:var(--radius-lg)}.category-panel-wide{grid-template-columns:1fr}.donut{position:relative;display:grid;place-items:center;width:132px;height:132px;border-radius:50%}.donut:after{position:absolute;top:26px;right:26px;bottom:26px;left:26px;border-radius:50%;background:var(--surface-solid);content:""}.donut>div{position:relative;z-index:2;text-align:center}.donut strong{display:block;max-width:74px;overflow-wrap:anywhere;font-size:18px;line-height:1.1}.donut span{color:var(--muted);font-size:12px}.category-bars{display:grid;gap:13px;min-width:0}.category-row{display:grid;gap:10px}.category-row+.category-row{padding-top:14px;border-top:1px solid var(--line)}.category-row-head{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center}.category-row-head b{overflow:hidden;font-size:14px;text-overflow:ellipsis;white-space:nowrap}.category-row-head>span:last-child{color:var(--muted);font-size:12px;font-weight:750}.triple-bars{display:grid;gap:8px}.triple-bars>div{display:grid;grid-template-columns:38px minmax(0,1fr) 72px;gap:9px;align-items:center}.triple-bars span{color:var(--muted);font-size:12px}.triple-bars em{overflow:hidden;font-style:normal;font-size:12px;font-weight:850;text-align:right;text-overflow:ellipsis;white-space:nowrap}.category-row-title{display:grid;grid-template-columns:auto minmax(48px,1fr) max-content max-content;gap:6px;align-items:center;margin-bottom:7px;font-size:13px}.category-row-title b,.category-row-title em{overflow:hidden;font-style:normal;text-overflow:ellipsis;white-space:nowrap}.category-row-title em{text-align:right;font-weight:800}.dot{width:9px;height:9px;border-radius:50%}.progress{height:8px;overflow:hidden;border-radius:999px;background:var(--surface-muted)}.progress span,.progress i{display:block;height:100%;min-width:4px;border-radius:999px}.saved-bar{background:var(--green-deep)}.spent-bar{background:var(--spent)}.backup-section{padding:18px;border-radius:var(--radius-lg)}.backup-actions{display:grid;grid-template-columns:1fr;gap:10px}.backup-actions button{min-height:46px;border-radius:14px;color:var(--green-deep);background:var(--green-soft);font-weight:850}.backup-actions button.danger{color:#c76161;background:#ee77771f}.empty-state{display:grid;justify-items:center;min-height:330px;padding:46px 16px 22px;text-align:center}.empty-illustration{position:relative;width:130px;height:116px;margin-bottom:22px}.box-body{position:absolute;left:23px;bottom:7px;width:84px;height:61px;border-radius:0 0 9px 9px;background:linear-gradient(135deg,#79ac72 0,#79ac72 50%,#5e9657 50%,#5e9657)}.box-lid{position:absolute;left:14px;bottom:62px;width:102px;height:42px;clip-path:polygon(50% 0,100% 45%,82% 100%,50% 60%,18% 100%,0 45%);background:#9cca91}.empty-leaf{position:absolute;right:24px;top:7px;width:18px;height:28px;border-radius:100% 0;background:#86b982;transform:rotate(28deg)}.empty-state h3{margin:0 0 10px;font-size:19px}.empty-state p{max-width:236px;margin:0;font-size:15px;line-height:1.7}.empty-button{width:min(100%,330px);min-height:54px;margin-top:26px;font-size:17px}.bottom-nav{position:fixed;left:50%;bottom:0;z-index:20;display:grid;grid-template-columns:repeat(3,1fr);width:min(100vw,480px);min-height:calc(78px + env(safe-area-inset-bottom));padding:9px 26px calc(8px + env(safe-area-inset-bottom));border-top:1px solid var(--line);background:#fffdf8e0;box-shadow:0 -12px 28px #45443b12;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);transform:translate(-50%)}@media(prefers-color-scheme:dark){.bottom-nav{background:#1a1f18e0}}.nav-button{display:grid;justify-items:center;gap:5px;min-width:0;color:#747871;font-size:12px;font-weight:800}.nav-button svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8}.nav-button svg path:first-child{fill:currentColor;fill-opacity:.06}.nav-button .nav-line{fill:none}.nav-button.active{color:var(--green-deep)}.nav-button.active svg path:first-child{fill-opacity:.24}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;align-items:end;justify-items:center;padding:16px 0 0;background:#1d1f1942;animation:fadeIn .16s ease both}.record-sheet{width:min(100vw,480px);max-height:min(90svh,760px);overflow-y:auto;padding:8px 18px calc(22px + env(safe-area-inset-bottom));border-radius:30px 30px 0 0;background:var(--surface-solid);box-shadow:0 -22px 44px #232a212e;animation:sheetIn .22s ease both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes sheetIn{0%{transform:translateY(24px)}to{transform:translateY(0)}}.sheet-handle{width:42px;height:5px;margin:2px auto 12px;border-radius:999px;background:var(--line)}.sheet-header{display:grid;grid-template-columns:42px 1fr 42px;align-items:center;margin-bottom:8px}.sheet-header h2{margin:0;font-size:19px;text-align:center}.icon-button{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;font-size:31px}.record-form{display:grid;gap:17px}.type-switch{display:grid;grid-template-columns:1fr 1fr;gap:9px;padding:5px;border-radius:18px;background:var(--surface-muted)}.type-switch button{min-height:42px;border-radius:14px;color:var(--muted);font-weight:900}.type-switch button.active.saved{color:#fff;background:var(--green);box-shadow:0 8px 18px #508d452e}.type-switch button.active.spent{color:#fff;background:var(--spent);box-shadow:0 8px 18px #e85a372e}.record-form label,.record-form fieldset{display:grid;gap:8px;min-width:0;margin:0;padding:0;border:0}.record-form label>span,.record-form legend{color:var(--text);font-size:14px;font-weight:850}.record-form b{color:var(--rose)}.record-form input,.money-input{min-height:52px;border-radius:14px;background:var(--surface-muted)}.record-form input{padding:0 16px}.money-input{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;padding-left:16px}.money-input span{margin-right:10px;font-weight:850}.money-input input{padding-left:0;background:transparent}.category-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.category-grid button{display:flex;align-items:center;justify-content:center;gap:7px;min-height:42px;padding:0 10px;border:1px solid transparent;border-radius:999px;color:var(--muted);background:var(--surface-muted);font-size:13px;font-weight:850;white-space:nowrap}.category-grid button.selected{border-color:var(--chip-color);color:var(--chip-color);background:var(--chip-bg)}.toast{position:fixed;left:50%;bottom:calc(92px + env(safe-area-inset-bottom));z-index:60;max-width:min(88vw,390px);padding:12px 18px;border-radius:999px;color:#fff;background:#1f241de6;box-shadow:0 14px 34px #1f241d3d;font-size:14px;font-weight:800;text-align:center;transform:translate(-50%);animation:toastIn .18s ease both}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;clip-path:inset(50%)}@media(max-width:430px){.category-panel{grid-template-columns:122px minmax(0,1fr);gap:12px;padding:16px}.donut{width:112px;height:112px}.donut:after{top:22px;right:22px;bottom:22px;left:22px}.donut strong{max-width:62px;font-size:16px}.category-row-title{font-size:12px}}@media(max-width:380px){.screen{padding-right:14px;padding-left:14px}.home-hero{grid-template-columns:minmax(0,1fr) 138px;min-height:248px}.jar-art{width:142px;height:198px;transform:scale(.88);transform-origin:right center}.brand-copy p:last-child{max-width:168px;font-size:16px}.mini-stats{gap:10px}.mini-stats>div+div{padding-left:10px}.mini-stats b{font-size:21px}.overview-grid>div{padding-right:8px}.overview-grid>div+div{padding-left:9px}.home-actions{grid-template-columns:1fr}.category-panel{grid-template-columns:1fr;justify-items:center}.category-bars{width:100%}}
