*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #F7F7F5;--bg-card: #FFFFFF;--border: #EBEBEA;--text: #1C1C1E;--text-2: #636366;--text-3: #AEAEB2;--accent: #2D5A3D;--accent-light: #E8F0EC;--green: #2D5A3D;--red: #B5494B;--r-lg: 20px;--r-md: 14px;--r-sm: 10px;--r-xs: 6px;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 2px 8px rgba(0,0,0,.06);--shadow-lg: 0 4px 20px rgba(0,0,0,.08);--bg-muted: #EDEDEC;--bg-hover: #F5F5F3;--bg-input: #F7F7F5;--bg-danger-light: #FDF2F2;--toggle-bg: #E5E5E3;--transition: .3s ease}[data-theme=dark]{--bg: #1C1C1E;--bg-card: #2C2C2E;--border: #3A3A3C;--text: #F2F2F7;--text-2: #AEAEB2;--text-3: #636366;--accent: #4ADE80;--accent-light: #1A3D2A;--green: #4ADE80;--red: #FF6B6B;--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 2px 8px rgba(0,0,0,.4);--shadow-lg: 0 4px 20px rgba(0,0,0,.5);--bg-muted: #3A3A3C;--bg-hover: #3A3A3C;--bg-input: #2C2C2E;--bg-danger-light: #3D1F1F;--toggle-bg: #48484A}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){--bg: #1C1C1E;--bg-card: #2C2C2E;--border: #3A3A3C;--text: #F2F2F7;--text-2: #AEAEB2;--text-3: #636366;--accent: #4ADE80;--accent-light: #1A3D2A;--green: #4ADE80;--red: #FF6B6B;--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 2px 8px rgba(0,0,0,.4);--shadow-lg: 0 4px 20px rgba(0,0,0,.5);--bg-muted: #3A3A3C;--bg-hover: #3A3A3C;--bg-input: #2C2C2E;--bg-danger-light: #3D1F1F;--toggle-bg: #48484A}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,PingFang SC,Microsoft YaHei,sans-serif;background:var(--bg);color:var(--text);max-width:480px;margin:0 auto;padding-bottom:calc(56px + env(safe-area-inset-bottom,0px));min-height:100vh;min-height:100dvh;position:relative;font-size:15px;-webkit-font-smoothing:antialiased;padding-left:env(safe-area-inset-left,0);padding-right:env(safe-area-inset-right,0)}body.has-input-bar{padding-bottom:calc(110px + env(safe-area-inset-bottom,0px))}.header{display:none}.savings-bar{background:var(--bg-card);margin:0 16px;border-radius:var(--r-lg);padding:16px 20px;box-shadow:var(--shadow-sm)}.savings-label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.savings-label-left{font-size:11px;color:var(--red);letter-spacing:.04em;text-transform:uppercase;font-weight:500}.savings-label-right{font-size:11px;color:var(--accent);letter-spacing:.04em;text-transform:uppercase;font-weight:500}.savings-dual-bar{position:relative;height:8px;border-radius:4px;overflow:hidden;background:var(--accent)}.savings-exp-bar{position:absolute;top:0;left:0;height:100%;background:var(--red);transition:width .5s ease;border-radius:4px 0 0 4px}.savings-values{display:flex;justify-content:space-between;margin-top:10px}.savings-exp-val,.savings-inc-val{font-size:13px;font-weight:600;font-variant-numeric:tabular-nums}.savings-exp-val{color:var(--red)}.savings-inc-val{color:var(--accent)}.month-compare{font-size:11px;color:var(--text-3);margin-top:8px;text-align:center}.budget-card{background:var(--bg-card);border-radius:var(--r-lg);padding:16px 20px;margin:12px 16px;box-shadow:var(--shadow-sm)}.budget-card-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}.budget-card-label{font-size:12px;color:var(--text-2);font-weight:600}.budget-progress-wrap{flex:1;height:4px;background:var(--bg-muted);border-radius:2px;overflow:hidden}.budget-progress{height:100%;background:var(--accent);border-radius:2px;transition:width .4s ease}.budget-progress.over{background:var(--red)}.budget-bottom{display:flex;justify-content:space-between;align-items:center}.budget-text{font-size:12px;color:var(--text-2)}.budget-compare{font-size:11px;color:var(--text-3)}.bottom-nav{display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;background:var(--bg-card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 -1px 0 var(--border);z-index:9999;padding:8px 0;padding-bottom:max(8px,env(safe-area-inset-bottom,8px));touch-action:manipulation}.tab{flex:1;text-align:center;padding:6px 4px;font-size:10px;color:var(--text-3);cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent;font-weight:500;letter-spacing:.02em}.tab.active{color:var(--accent);font-weight:600}.page{display:none;padding:16px;animation:fadeIn .25s ease}.page.active{display:block}#page-bill,#page-chart,#page-goal,#page-setting{padding-bottom:24px}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.bill-item{position:relative;overflow:hidden;transition:transform .3s cubic-bezier(.4,0,.2,1),background .15s;display:flex;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--bg-card);cursor:pointer}.bill-item.swiped{transform:translate(-80px)}.bill-swipe-actions{position:absolute;right:0;top:0;bottom:0;width:80px;display:flex;flex-direction:column;opacity:0;pointer-events:none;transition:opacity .2s}.bill-item.swiped .bill-swipe-actions{opacity:1;pointer-events:auto}.bill-swipe-actions button{width:100%;flex:1;border:none;font-size:12px;font-weight:600;cursor:pointer;color:#fff}.bill-swipe-del{background:var(--red)}.bill-swipe-edit{background:var(--accent)}.filter-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-bottom:16px}.filter-row::-webkit-scrollbar{display:none}.filter-btn{padding:8px 16px;font-size:12px;border-radius:20px;background:var(--bg-card);color:var(--text-2);border:1px solid var(--border);cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .2s;font-weight:500}.filter-btn.active{background:var(--accent);color:#fff;border-color:transparent}.filter-btn:not(.active):hover{background:var(--accent-light);color:var(--accent);border-color:transparent}.custom-date-picker{display:none;background:var(--bg-card);border-radius:var(--r-lg);padding:16px;margin:0 0 16px;box-shadow:var(--shadow-sm);align-items:center;gap:10px}.custom-date-picker input{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:14px;outline:none;background:var(--bg-card);color:var(--text);min-width:0}.custom-date-picker input:focus{border-color:var(--accent)}.custom-date-picker span{color:var(--text-2);font-size:14px}.month-picker{display:none;background:var(--bg-card);border-radius:var(--r-lg);padding:16px;margin:0 0 16px;box-shadow:var(--shadow-sm)}.mp-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.mp-nav{width:32px;height:32px;border-radius:50%;border:none;background:var(--bg-hover);color:var(--text);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.mp-nav:hover{background:var(--accent);color:#fff}.mp-year{font-size:15px;font-weight:700;color:var(--text)}.mp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.mp-grid button{padding:10px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-card);color:var(--text);font-size:14px;cursor:pointer;font-weight:500;transition:all .15s}.mp-grid button:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.mp-grid button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.apply-btn{padding:10px 20px;background:var(--accent);color:#fff;border:none;border-radius:var(--r-sm);font-size:14px;font-weight:600;cursor:pointer}.chart-card{background:var(--bg-card);border-radius:var(--r-lg);padding:20px;margin-bottom:16px;box-shadow:var(--shadow-sm)}.chart-card:last-child{margin-bottom:20px}.chart-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:16px;letter-spacing:-.2px}.chart-container{position:relative;min-height:160px}.pie-container{display:flex;align-items:flex-start;justify-content:center;gap:20px;flex-wrap:wrap}.pie-svg{width:160px;height:160px;flex-shrink:0}.pie-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}.pie-card{background:var(--bg);border-radius:var(--r-sm);padding:10px 12px;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;gap:4px;border:1px solid transparent}.pie-card:hover{background:var(--bg-hover);border-color:var(--border)}.pie-card-header{display:flex;align-items:center;gap:6px}.pie-card-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.pie-card-name{font-size:13px;font-weight:600;color:var(--text)}.pie-card-body{display:flex;justify-content:space-between;align-items:baseline}.pie-card-amount{font-size:15px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.pie-card-pct{font-size:12px;color:var(--text-3)}.bar-chart{display:flex;align-items:flex-end;height:140px;padding:0;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none}.bar-chart::-webkit-scrollbar{display:none}.bar-col{display:flex;flex-direction:column;align-items:center;flex:1;cursor:pointer;padding:0 3px}.bar{width:24px;background:var(--accent);border-radius:6px 6px 4px 4px;min-height:3px;transition:all .3s cubic-bezier(.4,0,.2,1)}.bar-col:hover .bar{background:#1c3d2a;transform:scaleX(1.05)}.bar-label{font-size:10px;color:var(--text-3);margin-top:8px;text-align:center}.line-chart{position:relative;height:140px;overflow:hidden}.line-chart svg{width:100%;height:100%;overflow:visible}.line-path{fill:none;stroke:var(--accent);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.line-area{fill:url(#greenGrad);opacity:.15}.chart-dot{fill:var(--accent);cursor:pointer}.chart-dot:hover{fill:#1c3d2a}.grid-line{stroke:var(--bg-muted);stroke-width:1}#page-chat{display:none;flex-direction:column;padding:0}#page-chat.active{display:flex;flex:1;min-height:0}#page-chat .chat-box{flex:1;overflow-y:auto;padding:12px 16px 160px;min-height:0;scroll-behavior:smooth;scroll-padding-bottom:160px}.fixed-input-bar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;background:var(--bg-card);border-top:1px solid var(--border);z-index:9998;padding-bottom:56px}.fixed-input-bar.hide{display:none}.input-bar-inner{display:flex;gap:10px;padding:10px 16px;align-items:flex-end}.input-bar-inner textarea{flex:1;padding:12px 16px;border:1px solid var(--border);border-radius:24px;resize:none;font-size:15px;outline:none;max-height:120px;line-height:1.4;background:var(--bg);transition:border-color .2s;font-family:inherit}.input-bar-inner textarea:focus{border-color:var(--accent)}.msg{margin:10px 0;padding:12px 16px;border-radius:16px;line-height:1.6;font-size:14px;max-width:82%}.msg.ai{background:var(--bg-card);color:var(--text);border-bottom-left-radius:5px;box-shadow:var(--shadow-sm);align-self:flex-start}.msg.user{background:var(--accent);color:#fff;border-bottom-right-radius:5px;align-self:flex-end;margin-left:auto}.msg.ai .label{font-size:11px;color:var(--text-3);margin-bottom:6px;font-weight:500}.msg.user .label{display:none}.send-btn{padding:12px 22px;background:var(--accent);color:#fff;border:none;border-radius:24px;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:opacity .2s;letter-spacing:-.2px}.send-btn:hover{opacity:.88}.send-btn:disabled{background:var(--text-3);cursor:not-allowed}.ocr-btn{padding:10px 8px;background:none;border:none;border-radius:24px;font-size:22px;color:var(--text-2);cursor:pointer;flex-shrink:0;transition:all .2s;line-height:1}.ocr-btn:hover{color:var(--accent)}.camera-menu{position:absolute;bottom:100%;left:0;margin-bottom:4px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-lg);z-index:10000;overflow:hidden;display:none;min-width:120px}.camera-menu.show{display:block}.camera-menu button{display:block;width:100%;padding:12px 18px;border:none;background:none;font-size:14px;color:var(--text);cursor:pointer;text-align:left;white-space:nowrap}.camera-menu button:hover{background:var(--bg-hover)}.camera-menu button:first-child{border-bottom:1px solid var(--border)}.ocr-loading{display:none;text-align:center;padding:24px;color:var(--text-2)}.bill-filter-row{display:flex;gap:6px;overflow-x:auto;padding:4px 0;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-bottom:8px}.bill-filter-row::-webkit-scrollbar{display:none}.bill-chip{padding:7px 14px;font-size:12px;border-radius:16px;background:var(--bg-card);color:var(--text-2);border:1px solid var(--border);cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .15s;font-weight:500}.bill-chip.active{background:var(--accent);color:#fff;border-color:transparent}.bill-chip:not(.active):hover{background:var(--accent-light);color:var(--accent)}.bill-chip-sep{width:1px;height:16px;background:var(--border);align-self:center;flex-shrink:0;margin:0 2px;border-radius:1px}.bill-month-panel{background:var(--bg-card);border-radius:var(--r-md);padding:8px;margin-bottom:8px;display:grid;grid-template-columns:repeat(3,1fr);gap:6px;max-height:200px;overflow-y:auto;box-shadow:var(--shadow-sm)}.bill-chip-sep{color:var(--border);font-size:14px;padding:7px 2px;flex-shrink:0;user-select:none}.bill-date{font-size:11px;color:var(--text-3);margin:20px 20px 8px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.bill-list{background:var(--bg-card);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);margin:0}.bill-item:last-child{border-bottom:none}.bill-item:hover{background:var(--bg-hover)}.bill-icon{width:40px;height:40px;background:var(--bg-hover);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-right:14px;font-size:18px;flex-shrink:0}.bill-info{flex:1;min-width:0}.bill-name{font-size:15px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bill-type{font-size:12px;color:var(--text-3);margin-top:2px}.bill-amount{font-size:16px;font-weight:700;flex-shrink:0;margin-left:12px;color:var(--text);letter-spacing:-.3px;font-variant-numeric:tabular-nums}.bill-amount.exp{color:var(--red)}.bill-amount.inc{color:var(--accent)}.bill-actions{display:none}.bill-del,.bill-edit{width:32px;height:32px;border-radius:50%;border:none;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;background:var(--bg-hover);color:var(--text-2)}.bill-del{color:var(--red)}.bill-edit{color:var(--accent)}.bill-empty{text-align:center;padding:64px 24px;color:var(--text-3);font-size:14px}.bill-empty-icon{font-size:48px;margin-bottom:16px;opacity:.4}.bill-search-wrap{padding:0 0 4px}.bill-search{flex:1;padding:12px 16px;border:1px solid var(--border);border-radius:24px;font-size:14px;outline:none;background:var(--bg-card);transition:border-color .2s;font-family:inherit;width:100%}.bill-search:focus{border-color:var(--accent)}.export-row{display:flex;gap:10px;align-items:center;margin:16px 0 0;padding:0 4px}.export-btn{padding:12px 20px;background:var(--bg-card);color:var(--text-2);border:1px solid var(--border);border-radius:24px;font-size:13px;font-weight:600;cursor:pointer;text-align:center;transition:all .2s;margin-bottom:16px}.export-btn:hover{border-color:var(--accent);color:var(--accent)}.export-menu{display:none;position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-lg);z-index:10000;min-width:140px;overflow:hidden}.export-menu button{width:100%;padding:12px 16px;text-align:center;font-size:14px;color:var(--text);background:none;border:none;cursor:pointer;transition:background .15s}.export-menu button:hover{background:var(--bg-hover)}.export-menu button+button{border-top:1px solid var(--border)}.settings-page{padding:0}.setting-section{margin-bottom:28px}.setting-section-title{font-size:11px;color:var(--text-3);font-weight:600;margin-bottom:10px;padding-left:4px;text-transform:uppercase;letter-spacing:.06em}.setting-card{background:var(--bg-card);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm);margin-bottom:12px}.setting-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.setting-label{font-size:15px;color:var(--text)}.setting-desc{font-size:12px;color:var(--text-3);margin-top:4px}.setting-input{flex:1;padding:10px 14px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:14px;outline:none;background:var(--bg-card);transition:border-color .2s;width:100%}.setting-input:focus{border-color:var(--accent)}textarea.setting-input{resize:none;min-height:80px;line-height:1.5}.setting-hint{font-size:12px;color:var(--text-3);margin-top:8px}.setting-btn{padding:10px 20px;background:var(--accent);color:#fff;border:none;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .2s}.setting-btn:hover{opacity:.85}.setting-btn.gray{background:var(--bg-hover);color:var(--text-2)}.setting-btn.danger{background:var(--red)}.setting-card-row{display:flex;gap:10px;margin-top:12px}.toggle-switch{width:44px;height:26px;background:var(--toggle-bg);border-radius:13px;position:relative;cursor:pointer;transition:background .25s;flex-shrink:0}.toggle-switch.on{background:var(--accent)}.toggle-switch:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .25s;box-shadow:0 1px 3px #00000026}.toggle-switch.on:after{transform:translate(18px)}.detail-panel{position:fixed;inset:0;background:#00000059;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:none;align-items:flex-end;z-index:10000;justify-content:center;padding:20px;box-sizing:border-box}.detail-panel.open{display:flex}.detail-content{background:var(--bg-card);width:100%;max-width:480px;margin:0 auto;border-radius:24px 24px 0 0;padding:28px 24px;max-height:80vh;overflow-y:auto;box-shadow:0 -8px 32px #0000001f;box-sizing:border-box}.detail-title{font-size:18px;font-weight:700;margin-bottom:20px;text-align:center;color:var(--text);letter-spacing:-.3px}.detail-list{font-size:15px}.detail-row{display:flex;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border)}.detail-row:last-child{border-bottom:none}.close-panel{width:100%;margin-top:20px;padding:14px;background:var(--bg-hover);border:none;border-radius:var(--r-md);font-size:15px;font-weight:600;cursor:pointer;color:var(--text-2);transition:all .2s}.close-panel:hover{background:var(--bg-muted);color:var(--text)}.modal-overlay{position:fixed;inset:0;background:#00000059;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:10000;padding:20px;box-sizing:border-box}.modal-overlay.open{display:flex}.modal-box{background:var(--bg-card);border-radius:24px;padding:28px 24px;width:100%;max-width:360px;box-shadow:var(--shadow-lg);box-sizing:border-box}.modal-title{font-size:18px;font-weight:700;text-align:center;margin-bottom:24px;color:var(--text);letter-spacing:-.3px}.form-row{margin-bottom:16px}.form-label{font-size:12px;color:var(--text-3);margin-bottom:8px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.form-input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:15px;outline:none;transition:border-color .2s;background:var(--bg)}.form-input:focus{border-color:var(--accent)}.form-select{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:15px;outline:none;background:var(--bg-card);color:var(--text)}.form-actions{display:flex;gap:12px;margin-top:24px}.form-actions button{flex:1;padding:14px;border-radius:14px;font-size:15px;font-weight:600;cursor:pointer;border:none;transition:opacity .2s}.form-actions button:hover{opacity:.88}.form-actions .btn-primary{background:var(--accent);color:#fff}.form-actions .btn-secondary{background:var(--bg-hover);color:var(--text-2)}.form-actions .btn-danger{background:var(--red);color:#fff}.img-confirm-modal{position:fixed;inset:0;background:#0006;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;z-index:10001;padding:20px;box-sizing:border-box}.img-confirm-modal.open{display:flex}.img-confirm-box{background:var(--bg-card);border-radius:24px;padding:28px 24px;width:100%;max-width:360px;text-align:center;box-shadow:var(--shadow-lg);box-sizing:border-box}.img-confirm-title{font-size:17px;font-weight:700;margin-bottom:8px;color:var(--text)}.img-confirm-hint{font-size:13px;color:var(--text-3);margin-bottom:16px}.img-confirm-result{background:var(--bg-input);border-radius:var(--r-md);padding:16px;margin-bottom:16px;text-align:left}.img-confirm-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px}.img-confirm-row span:first-child{color:var(--text-2)}.img-confirm-row span:last-child{font-weight:600;color:var(--text)}.img-confirm-actions{display:flex;gap:12px}.img-confirm-actions button{flex:1;padding:14px;border-radius:14px;font-size:15px;font-weight:600;cursor:pointer;border:none}.img-confirm-actions .confirm-yes{background:var(--accent);color:#fff}.img-confirm-actions .confirm-no{background:var(--bg-hover);color:var(--text-2)}.toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%) translateY(12px);background:#1c1c1e;color:#fff;padding:12px 20px;border-radius:20px;font-size:14px;opacity:0;transition:all .3s;z-index:3000;white-space:nowrap;box-shadow:0 4px 16px #0003}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}#toastUndo{background:#ffffff26;border:none;color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;cursor:pointer;margin-left:10px;font-weight:500}#toastUndo:hover{background:#ffffff40}.goals-list{margin-top:4px;padding-bottom:16px}.surplus-bar{background:var(--accent-light);color:var(--accent);padding:10px 16px;border-radius:var(--r-sm);margin-bottom:16px;font-size:13px;text-align:center}.surplus-bar.overspent{background:var(--bg-danger-light);color:var(--red)}.goal-templates{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:8px}.goal-tmpl-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:14px 10px;text-align:center;cursor:pointer;transition:all .2s}.goal-tmpl-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent)}.goal-tmpl-icon{font-size:28px;margin-bottom:6px}.goal-tmpl-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px}.goal-tmpl-hint{font-size:10px;color:var(--text-3)}.goal-item{background:var(--bg-card);border-radius:var(--r-lg);padding:20px;margin-bottom:12px;box-shadow:var(--shadow-sm);transition:box-shadow .3s}.goal-item.goal-done{box-shadow:0 0 0 2px var(--accent);animation:goalGlow 2s ease-in-out infinite}@keyframes goalGlow{0%,to{box-shadow:0 0 0 2px var(--accent)}50%{box-shadow:0 0 12px 4px #4ade804d}}.goal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.goal-name{font-size:16px;font-weight:700;color:var(--text)}.goal-amount-range{font-size:13px;color:var(--text-2)}.goal-progress-wrap{height:6px;background:var(--bg-muted);border-radius:3px;overflow:hidden;margin:12px 0}.goal-progress{height:100%;border-radius:3px;transition:width .5s ease;background:var(--accent)}.goal-progress.done{background:#1c3d2a}.goal-bottom{display:flex;justify-content:space-between;font-size:13px;color:var(--text-2);font-weight:500}.goal-actions{display:flex;gap:10px;margin-top:14px}.goal-actions button{flex:1;padding:10px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:opacity .15s}.goal-actions button:hover{opacity:.85}.goal-actions .goal-save-btn{background:var(--accent);color:#fff}.goal-actions .goal-del-btn{background:var(--bg-danger-light);color:var(--red)}.goal-actions .goal-edit-btn{background:var(--accent-light);color:var(--accent)}.goal-pct{font-size:22px;font-weight:700;color:var(--text)}.goal-monthly{font-size:11px;color:var(--accent)}.goal-done-badge{color:var(--accent);font-weight:600}.goal-empty{text-align:center;padding:56px 24px;color:var(--text-3);font-size:14px}.goal-empty-icon{font-size:40px;margin-bottom:16px;opacity:.4}.recurring-section{margin-top:4px}.recurring-item{background:var(--bg-card);border-radius:var(--r-lg);padding:16px 20px;margin-bottom:10px;box-shadow:var(--shadow-sm)}.recurring-row{display:flex;justify-content:space-between;align-items:center}.recurringName{font-size:15px;font-weight:600;color:var(--text)}.recurring-info{font-size:12px;color:var(--text-3);margin-top:3px}.recurring-amount{font-size:16px;font-weight:700;color:var(--red);font-variant-numeric:tabular-nums}.recurring-actions{display:flex;gap:10px;margin-top:12px}.recurring-actions button{flex:1;padding:9px;border-radius:10px;font-size:13px;cursor:pointer;border:none;font-weight:600}.recurring-actions .rec-del{background:var(--bg-danger-light);color:var(--red)}.recurring-actions .rec-edit{background:var(--accent-light);color:var(--accent)}.recurring-add{margin-top:12px}.recurring-add button{width:100%;padding:14px;background:var(--bg-card);border:1.5px dashed var(--border);border-radius:var(--r-lg);font-size:14px;color:var(--text-3);cursor:pointer;font-weight:600;transition:all .2s}.recurring-add button:hover{border-color:var(--accent);color:var(--accent);border-style:solid}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.cat-edit-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border)}.cat-edit-row:last-child{border-bottom:none}.cat-edit-preview{width:28px;text-align:center;font-size:16px;flex-shrink:0}.cat-edit-name{flex:1;padding:6px 8px;border:1px solid var(--border);border-radius:6px;font-size:13px;outline:none;background:var(--bg-input);color:var(--text)}.cat-edit-name:focus,.cat-edit-icon:focus{border-color:var(--accent)}.cat-edit-icon{padding:6px 4px;border:1px solid var(--border);border-radius:6px;font-size:16px;outline:none;background:var(--bg-input)}.cat-edit-del{width:24px;height:24px;border:none;background:var(--bg-danger-light);color:var(--red);border-radius:50%;cursor:pointer;font-size:12px;flex-shrink:0;line-height:1}
