*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #6366F1;--primary-deep: #4F46E5;--primary-end: #7C3AED;--primary-gradient: linear-gradient(135deg, #4F46E5, #7C3AED);--primary-light: #EDE9FE;--danger: #e74c3c;--warning: #f39c12;--income: #10b981;--expense: #ef4444;--bg: #F7F7FB;--card: #FFFFFF;--text: #1E1B4B;--text-muted: #6B7280;--border: #ECEAF5;--radius: 14px;--tab-h: 64px;--header-h: 56px}html,body{height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang TC,Microsoft JhengHei,sans-serif;font-size:15px;-webkit-tap-highlight-color:transparent;overscroll-behavior:none}@media (max-width: 480px){html,body{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;overflow:hidden;touch-action:pan-y}}button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit}input{font-family:inherit;font-size:inherit}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}#app{display:flex;flex-direction:column;height:100svh;height:100dvh;max-width:480px;margin:0 auto;background:var(--card);box-shadow:0 0 30px #00000014;position:relative}@media (max-width: 480px){#app{position:absolute;top:0;right:0;bottom:0;left:0;height:100%;max-width:none;box-shadow:none}}.app-header{height:var(--header-h);background:var(--primary-gradient);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 18px;flex-shrink:0}.app-brand{display:flex;align-items:center;gap:8px}.app-logo{width:30px;height:30px;background:#ffffff2e;border-radius:9px;display:flex;align-items:center;justify-content:center}.app-title{font-size:19px;font-weight:800;letter-spacing:-.3px}.app-header .header-balance{font-size:13px;opacity:.9}.app-header .income{color:#a8f0c6}.app-header .expense{color:#ffb3b3}.page-container{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.page{display:none;padding:16px;min-height:100%}.page.active{display:block}.tab-bar{height:var(--tab-h);display:flex;background:var(--card);border-top:1px solid var(--border);flex-shrink:0;padding-bottom:env(safe-area-inset-bottom)}.tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--text-muted);transition:color .15s}.tab-btn.active{color:var(--primary)}.tab-icon{font-size:22px;line-height:1}.tab-label{font-size:11px}.add-form-card{display:flex;flex-direction:column;gap:16px}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:8px}.quick-actions.hidden{display:none}.quick-chip{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 8px;background:var(--card);border:2px solid var(--border);border-radius:12px;font-size:12px;font-weight:600;color:var(--text);transition:transform .1s,border-color .15s}.quick-chip:active{transform:scale(.96)}.quick-chip-emoji{font-size:22px;line-height:1}.quick-chip-name{font-size:11px;color:var(--text-muted)}.quick-chip-amount{font-size:14px;font-weight:800;color:var(--primary-deep)}.ocr-btn{width:100%;padding:14px 16px;background:linear-gradient(135deg,#f5f3ff,#ede9fe);border:2px dashed var(--primary);color:var(--primary-deep);border-radius:14px;font-weight:700;font-size:15px;display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;align-items:center;column-gap:12px;text-align:left;transition:transform .1s,box-shadow .2s}.ocr-btn:active{transform:scale(.98)}.ocr-btn:hover{box-shadow:0 4px 16px #6366f126}.ocr-icon{grid-row:1 / 3;font-size:28px;line-height:1}.ocr-text{font-size:15px;font-weight:700}.ocr-sub{font-size:11px;font-weight:500;color:var(--primary);opacity:.75}.ocr-loading{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e1b4b8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:300;animation:fadeIn .15s ease}.ocr-loading.hidden{display:none}.ocr-loading-card{background:#fff;padding:28px 32px;border-radius:18px;text-align:center;min-width:200px;box-shadow:0 16px 48px #0003}.ocr-loading-title{font-size:15px;font-weight:700;color:var(--text)}.ocr-loading-sub{font-size:12px;color:var(--text-muted);margin-top:4px}.ocr-spinner{width:38px;height:38px;margin:0 auto 14px;border:3px solid var(--primary-light);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.type-toggle{display:flex;background:var(--bg);border-radius:10px;padding:4px}.type-btn{flex:1;padding:10px;border-radius:8px;font-weight:600;color:var(--text-muted);transition:all .2s}.type-btn.active{background:var(--primary-gradient);color:#fff;box-shadow:0 2px 8px #4f46e54d}.field-label{display:block;font-size:13px;color:var(--text-muted);margin-bottom:8px}.amount-input-wrap{display:flex;align-items:center;background:var(--bg);border-radius:10px;padding:0 14px;border:2px solid transparent;transition:border-color .2s}.amount-input-wrap:focus-within{border-color:var(--primary)}.currency-sign{font-size:20px;color:var(--text-muted);margin-right:6px}.amount-input-wrap input{flex:1;background:none;border:none;outline:none;font-size:28px;font-weight:700;color:var(--text);padding:10px 0}.category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.cat-chip{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 4px;border-radius:12px;border:2px solid var(--border);font-size:12px;color:var(--text);transition:all .15s;background:var(--card)}.cat-chip span:first-child{font-size:20px}.cat-chip.selected{font-weight:600}.cat-chip:active{transform:scale(.95)}.date-picker-btn{width:100%;display:flex;align-items:center;justify-content:space-between;background:var(--bg);border-radius:10px;padding:12px 14px;font-size:15px;color:var(--text)}.date-picker-btn .icon{font-size:18px}.note-section input{width:100%;background:var(--bg);border:2px solid transparent;border-radius:10px;padding:12px 14px;outline:none;color:var(--text);transition:border-color .2s}.note-section input:focus{border-color:var(--primary)}.budget-alert{padding:10px 14px;border-radius:10px;font-size:13px;font-weight:600}.budget-alert.warning{background:#fff3cd;color:#856404}.budget-alert.over{background:#f8d7da;color:#721c24}.budget-alert.hidden{display:none}.submit-btn{width:100%;padding:16px;background:var(--primary-gradient);color:#fff;border-radius:14px;font-size:17px;font-weight:700;box-shadow:0 4px 15px #4f46e559;transition:transform .1s,box-shadow .1s}.submit-btn:active{transform:scale(.98);box-shadow:0 2px 8px #4f46e533}.records-header{margin-bottom:14px}.records-filters{display:flex;gap:8px;margin-bottom:10px}.filter-select{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 10px;color:var(--text);outline:none}.records-summary{display:flex;gap:16px;margin-bottom:10px;font-size:13px}.summary-item.expense strong{color:var(--expense)}.summary-item.income strong{color:var(--income)}.export-btn{width:100%;padding:10px;background:var(--primary-light);color:var(--primary);border-radius:8px;font-weight:600;font-size:13px}.records-empty{text-align:center;padding:40px 0;color:var(--text-muted);font-size:15px}.record-day-group{margin-bottom:12px}.record-day-header{display:flex;justify-content:space-between;padding:6px 4px;font-size:13px;color:var(--text-muted);border-bottom:1px solid var(--border);margin-bottom:4px}.record-day-total.income{color:var(--income)}.record-day-total.expense{color:var(--expense)}.record-item{display:flex;align-items:center;gap:12px;padding:10px 4px;border-bottom:1px solid var(--bg)}.record-cat-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.record-info{flex:1;min-width:0}.record-cat-name{font-weight:600;font-size:14px}.record-note{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.record-amount{font-weight:700;font-size:15px;flex-shrink:0}.record-amount.expense{color:var(--expense)}.record-amount.income{color:var(--income)}.delete-record-btn{color:var(--text-muted);font-size:16px;padding:4px 6px;border-radius:6px;flex-shrink:0}.delete-record-btn:hover{background:#fee;color:var(--danger)}.stats-month-selector{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.month-nav-btn{font-size:24px;color:var(--primary);padding:4px 12px;border-radius:8px}.month-label{font-size:17px;font-weight:700}.stats-summary-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}.stats-card{background:var(--bg);border-radius:12px;padding:12px;text-align:center}.stats-card-label{font-size:12px;color:var(--text-muted);margin-bottom:4px}.stats-card-value{font-size:16px;font-weight:700}.stats-card-value.income{color:var(--income)}.stats-card-value.expense{color:var(--expense)}.chart-empty{text-align:center;color:var(--text-muted);font-size:14px;padding:32px 0}.chart-section{margin-bottom:24px}.chart-title{font-size:15px;font-weight:700;margin-bottom:12px}.pie-container{max-width:280px;margin:0 auto}.bar-container{width:100%}.settings-list{display:flex;flex-direction:column;gap:16px}.settings-group{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);padding:16px}.settings-group-title{font-size:13px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px}.settings-item{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.settings-item-label{font-weight:600}.settings-item-sub{font-size:12px;color:var(--text-muted);margin-top:2px}.budget-input-wrap{display:flex;align-items:center;background:var(--bg);border-radius:8px;padding:0 10px;border:2px solid transparent;transition:border-color .2s}.budget-input-wrap:focus-within{border-color:var(--primary)}.budget-input-wrap input{width:110px;background:none;border:none;outline:none;font-size:16px;font-weight:700;padding:8px 4px;color:var(--text);text-align:right}.save-btn{width:100%;padding:11px;background:var(--primary-gradient);color:#fff;border-radius:10px;font-weight:600;margin-bottom:12px}.budget-progress-wrap{margin-top:4px}.budget-progress-label{display:flex;justify-content:space-between;font-size:13px;color:var(--text-muted);margin-bottom:6px}.budget-progress-bar{height:8px;background:var(--bg);border-radius:4px;overflow:hidden}.budget-progress-fill{height:100%;border-radius:4px;transition:width .4s ease}.category-type-tabs{display:flex;gap:8px;margin-bottom:12px}.cat-tab{flex:1;padding:8px;border-radius:8px;background:var(--bg);color:var(--text-muted);font-weight:600;font-size:13px}.cat-tab.active{background:var(--primary-gradient);color:#fff}.custom-category-list{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.cat-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg);border-radius:10px}.cat-item.default{opacity:.75}.cat-emoji{font-size:20px}.cat-name{flex:1;font-weight:600;font-size:14px}.cat-badge{font-size:11px;background:var(--border);border-radius:6px;padding:2px 7px;color:var(--text-muted)}.cat-empty{text-align:center;color:var(--text-muted);font-size:13px;padding:10px}.delete-cat-btn{color:var(--text-muted);font-size:14px;padding:4px 6px}.delete-cat-btn:hover{color:var(--danger)}.add-category-btn{width:100%;padding:11px;border:2px dashed var(--border);border-radius:10px;color:var(--primary);font-weight:600;font-size:14px}.danger-btn{width:100%;padding:12px;background:#fff0f0;color:var(--danger);border-radius:10px;font-weight:600;border:1px solid #fdd}.changelog-version{margin-bottom:10px}.changelog-version-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.changelog-date{font-size:12px;color:var(--text-muted)}.changelog-notes{list-style:none}.changelog-notes li{font-size:13px;color:var(--text-muted);padding:2px 0}.changelog-notes li:before{content:"• ";color:var(--primary)}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:flex-end;justify-content:center}.modal.hidden{display:none}.modal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006}.modal-content{position:relative;background:var(--card);border-radius:20px 20px 0 0;width:100%;max-width:480px;padding:20px;z-index:1;max-height:85vh;overflow-y:auto}.modal-title{font-size:17px;font-weight:700;margin-bottom:16px;text-align:center}.date-picker-modal .modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.modal-prev,.modal-next{font-size:22px;color:var(--primary);padding:4px 12px}.modal-month-label{font-size:16px;font-weight:700}.cal-header{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:6px}.cal-day-label{font-size:12px;color:var(--text-muted);padding:4px 0}.cal-body{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-cell{aspect-ratio:1;min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:14px;cursor:pointer}.cal-cell.empty{cursor:default}.cal-cell.today{font-weight:700;color:var(--primary)}.cal-cell.selected{background:var(--primary);color:#fff;font-weight:700}.cal-cell:not(.empty):not(.selected):hover{background:var(--primary-light)}.modal-footer{display:flex;gap:10px;margin-top:16px}.modal-cancel-btn{flex:1;padding:12px;background:var(--bg);border-radius:10px;font-weight:600;color:var(--text-muted)}.modal-confirm-btn{flex:1;padding:12px;background:var(--primary-gradient);border-radius:10px;font-weight:600;color:#fff}.form-field{margin-bottom:14px}.form-field label{display:block;font-size:13px;color:var(--text-muted);margin-bottom:6px}.form-field input[type=text],.form-field input[type=color]{width:100%;background:var(--bg);border:2px solid transparent;border-radius:10px;padding:11px 14px;outline:none;color:var(--text);transition:border-color .2s}.form-field input:focus{border-color:var(--primary)}.form-field input[type=color]{height:48px;padding:4px 10px;cursor:pointer}.modal-actions{display:flex;gap:10px;margin-top:4px}.report-modal{border-radius:24px 24px 0 0;padding:0;overflow:hidden;max-height:90vh}.report-header{background:var(--primary-gradient);color:#fff;padding:28px 24px 24px;text-align:center}.report-icon{font-size:36px;margin-bottom:8px}.report-title{font-size:22px;font-weight:800;letter-spacing:-.5px}.report-month{font-size:14px;opacity:.85;margin-top:2px}.report-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:18px 16px 12px}.report-stat{background:var(--bg);border-radius:12px;padding:12px 8px;text-align:center}.report-stat-label{font-size:11px;color:var(--text-muted);margin-bottom:4px}.report-stat-value{font-size:16px;font-weight:800}.report-stat-value.expense{color:var(--expense)}.report-stat-value.income{color:var(--income)}.report-comparison,.report-budget{margin:6px 16px 4px;padding:10px 14px;border-radius:10px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px}.report-comparison.hidden,.report-budget.hidden{display:none}.report-comparison{background:var(--primary-light);color:var(--primary-deep)}.report-comparison.positive{background:#d1fae5;color:#065f46}.report-comparison.negative{background:#fef3c7;color:#92400e}.report-budget.ok{background:#d1fae5;color:#065f46}.report-budget.warn{background:#fef3c7;color:#92400e}.report-budget.over{background:#fee2e2;color:#991b1b}.report-section-title{font-size:12px;letter-spacing:1px;color:var(--text-muted);font-weight:700;text-transform:uppercase;padding:14px 20px 6px}.report-top-list{padding:0 16px 16px;display:flex;flex-direction:column;gap:8px}.report-top-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg);border-radius:12px}.report-top-emoji{font-size:22px}.report-top-info{flex:1}.report-top-name{font-size:14px;font-weight:700}.report-top-pct{font-size:11px;color:var(--text-muted)}.report-top-amount{font-size:15px;font-weight:800;color:var(--expense)}.report-close-btn{margin:4px 16px 20px;width:calc(100% - 32px);padding:14px;background:var(--primary-gradient);color:#fff;border-radius:12px;font-size:15px;font-weight:700;box-shadow:0 4px 15px #4f46e54d}.report-close-btn:active{transform:scale(.98)}.toast{position:fixed;bottom:calc(var(--tab-h) + env(safe-area-inset-bottom,0px) + 16px);left:50%;transform:translate(-50%) translateY(20px);background:#2d3436;color:#fff;padding:10px 20px;border-radius:22px;font-size:14px;font-weight:600;z-index:200;opacity:0;transition:opacity .25s,transform .25s;pointer-events:none;white-space:nowrap}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.toast.hidden{display:none}.hidden{display:none!important}.income{color:var(--income)}.expense{color:var(--expense)}@media (min-width: 480px){#app{border-radius:24px;margin-top:20px;margin-bottom:20px;height:calc(100dvh - 40px)}}
