*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #3157D5;--primary-deep: #203E9F;--primary-end: #00A676;--primary-gradient: linear-gradient(135deg, #233B8F 0%, #3157D5 52%, #00A676 100%);--primary-light: #E8EEFF;--brand-ink: #111827;--brand-mint: #00A676;--brand-gold: #F7B32B;--brand-coral: #F9735B;--danger: #e74c3c;--warning: #f39c12;--income: #10b981;--expense: #ef4444;--bg: #F5F7FB;--card: #FFFFFF;--text: #18223A;--text-muted: #6B7280;--border: #E5EAF4;--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{min-height:var(--header-h);background:radial-gradient(circle at 18% -20%,rgba(247,179,43,.42),transparent 34%),radial-gradient(circle at 100% 0%,rgba(0,166,118,.34),transparent 36%),linear-gradient(135deg,#101827,#1c2d62 54%,#123d3b);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:10px 18px;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.12)}.app-brand{display:flex;align-items:center;gap:8px}.app-logo{width:34px;height:34px;background:linear-gradient(135deg,#ffffff3d,#ffffff14);border:1px solid rgba(255,255,255,.22);border-radius:11px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 24px #0000002e}.brand-copy{display:flex;flex-direction:column;line-height:1.05}.app-title{font-size:19px;font-weight:850}.app-subtitle{margin-top:2px;font-size:10px;font-weight:700;letter-spacing:.9px;text-transform:uppercase;color:#ffffffad}.app-header .header-balance{font-size:12px;font-weight:750;background:#ffffff21;border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:7px 10px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.app-header .income{color:#a8f0c6}.app-header .expense{color:#ffb3b3}.page-container{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;background:linear-gradient(180deg,#f6f8fc,#fff 120px)}.page{display:none;padding:18px;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);box-shadow:0 -10px 26px #18223a0f}.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:20px}.onboarding-card{background:linear-gradient(135deg,#f8faff,#ecfdf5);border:1px solid #DDE7F6;border-left:4px solid var(--brand-mint);border-radius:12px;padding:14px;box-shadow:0 10px 28px #18223a0f}.onboarding-title{font-size:15px;font-weight:700;color:var(--primary-deep)}.onboarding-steps{margin-top:6px;font-size:13px;color:var(--text-muted)}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:10px}.quick-actions.hidden{display:none}.quick-chip{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 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,#fffffff0,#e8eeffb8),linear-gradient(135deg,#3157d529,#00a6761f);border:1px solid #DCE5F5;color:var(--brand-ink);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,border-color .2s;box-shadow:0 12px 30px #18223a14}.ocr-btn:active{transform:scale(.98)}.ocr-btn:hover{border-color:#3157d552;box-shadow:0 14px 34px #18223a1f}.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:650;color:var(--primary);opacity:.82}.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:#eef2f8;border-radius:12px;padding:4px;border:1px solid #E3E9F3;margin-top:2px}.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 8px 18px #3157d538}.ledger-toggle{display:flex;background:#eef2f8;border-radius:12px;padding:4px;border:1px solid #E3E9F3;margin-top:2px}.ledger-btn{flex:1;padding:9px;border-radius:8px;font-weight:700;color:var(--text-muted);transition:all .2s}.ledger-btn.active{background:linear-gradient(135deg,#111827,#0f766e);color:#fff;box-shadow:0 8px 18px #1118272e}.field-label{display:block;font-size:13px;color:var(--text-muted);margin-bottom:10px}.amount-input-wrap{display:flex;align-items:center;background:#fff;border-radius:14px;padding:0 14px;border:1px solid #DDE5F1;transition:border-color .2s,box-shadow .2s;box-shadow:0 10px 24px #18223a0d}.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}.quick-amounts{margin-top:10px;display:flex;gap:9px;overflow-x:auto;padding-bottom:2px}.quick-amount-btn{flex:0 0 auto;background:#eef3ff;color:var(--primary-deep);border:1px solid #D9E3FF;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:700}.quick-amount-btn.smart{background:#e8faf2;color:#057a55;border-color:#b5efd7}.quick-amount-btn:active{transform:scale(.97)}.field-error{margin-top:6px;color:var(--expense);font-size:12px;font-weight:600}.tax-panel{border:1px solid #BCEBD6;background:linear-gradient(135deg,#f0fdf4,#f8faff);border-radius:14px;padding:14px;box-shadow:0 12px 26px #00a67614}.tax-panel-head{display:flex;align-items:center;gap:10px}.tax-check{flex:1;display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:#047857}.tax-mode-select{background:#fff;border:1px solid #a7f3d0;border-radius:8px;padding:7px 8px;color:#065f46;font-size:12px;outline:none}.tax-preview{margin-top:9px;font-size:12px;font-weight:700;color:#065f46}.category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.cat-chip{display:flex;flex-direction:column;align-items:center;gap:5px;padding:12px 4px;border-radius:12px;border:1px solid var(--border);font-size:12px;color:var(--text);transition:all .15s;background:var(--card);box-shadow:0 7px 18px #18223a0a}.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:800;box-shadow:0 14px 28px #3157d547;transition:transform .1s,box-shadow .1s}.submit-btn:active{transform:scale(.98);box-shadow:0 7px 16px #3157d533}.records-header{margin-bottom:14px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px;box-shadow:0 10px 26px #18223a0d}.record-search-wrap{display:flex;align-items:center;gap:8px;margin-bottom:12px}.record-search-input{flex:1;min-width:0;background:#f8fafc;border:1px solid #DEE7F2;border-radius:10px;padding:10px 12px;color:var(--text);outline:none}.record-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3157d514}.record-search-clear{flex:0 0 auto;background:#eef3ff;color:var(--primary-deep);border:1px solid #D9E3FF;border-radius:999px;padding:8px 10px;font-size:12px;font-weight:700}.records-filters{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap}.filter-select{flex:1;min-width:0;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:14px;font-size:13px}.summary-item.expense strong{color:var(--expense)}.summary-item.income strong{color:var(--income)}.export-btn{width:100%;padding:10px;background:#e8f0ff;color:var(--primary-deep);border-radius:9px;font-weight:700;font-size:13px;border:1px solid #D8E3FF}.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:13px 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-meta{display:flex;gap:5px;flex-wrap:wrap;margin-top:3px}.record-badge{font-size:10px;font-weight:700;padding:2px 6px;border-radius:999px;background:var(--bg);color:var(--text-muted)}.record-badge.business{background:#ecfdf5;color:#047857}.record-badge.tax{background:#eff6ff;color:#2563eb}.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)}.edit-record-btn{color:var(--primary-deep);background:#eef3ff;border:1px solid #D9E3FF;font-size:12px;font-weight:700;padding:5px 8px;border-radius:999px;flex-shrink:0}.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:#fff;border:1px solid var(--border);border-radius:12px;padding:12px;text-align:center;box-shadow:0 8px 20px #18223a0d}.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:20px}.settings-group{background:var(--card);border-radius:14px;border:1px solid var(--border);padding:18px;box-shadow:0 10px 28px #18223a0d}.settings-group-title{font-size:12px;font-weight:850;color:var(--primary-deep);text-transform:uppercase;letter-spacing:.7px;margin-bottom:16px;display:flex;align-items:center;gap:8px}.settings-group-title:before{content:"";width:7px;height:18px;border-radius:999px;background:linear-gradient(180deg,var(--primary),var(--brand-mint))}.settings-item{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.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:#f8fafc;border-radius:9px;padding:0 10px;border:1px solid #DEE7F2;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}.tax-rate-input-wrap{display:flex;align-items:center;background:#f8fafc;border-radius:9px;padding:0 10px;border:1px solid #DEE7F2;transition:border-color .2s;font-weight:700;color:var(--text-muted)}.tax-rate-input-wrap:focus-within{border-color:var(--primary)}.tax-rate-input-wrap input{width:74px;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:11px;font-weight:750;margin-bottom:12px;box-shadow:0 10px 20px #3157d52e}.payroll-grid{display:grid;grid-template-columns:1fr;gap:13px;margin-bottom:16px}.payroll-field{display:flex;flex-direction:column;gap:6px}.payroll-field.wide{grid-column:1 / -1}.payroll-field span{font-size:12px;color:var(--text-muted);font-weight:700}.payroll-field input{width:100%;background:#f8fafc;border:1px solid #DEE7F2;border-radius:9px;padding:9px 10px;outline:none;color:var(--text);font-weight:700}.payroll-field input:focus{border-color:var(--primary)}.payroll-preview{display:grid;gap:10px;background:radial-gradient(circle at 0% 0%,rgba(247,179,43,.16),transparent 32%),linear-gradient(135deg,#111827,#173a59 58%,#0f766e);border:1px solid rgba(255,255,255,.16);border-radius:14px;padding:15px;margin-bottom:16px;box-shadow:0 14px 32px #11182729}.payroll-preview div{display:flex;align-items:center;justify-content:space-between;font-size:13px;color:#ffffffad}.payroll-preview strong{font-size:15px;color:#fff}.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:10px;margin-bottom:16px}.cat-tab{flex:1;padding:8px;border-radius:8px;background:#eef2f8;color:var(--text-muted);font-weight:650;font-size:13px}.cat-tab.active{background:var(--primary-gradient);color:#fff}.custom-category-list{display:flex;flex-direction:column;gap:9px;margin-bottom:14px}.cat-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f8fafc;border:1px solid #EEF2F8;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:#fff1f0;color:var(--danger);border-radius:11px;font-weight:700;border:1px solid #FFD9D4}.secondary-btn{width:100%;padding:11px;margin-bottom:10px;background:#f8fafc;color:var(--primary-deep);border:1px solid #DDE7F6;border-radius:11px;font-weight:700}.trust-note{display:grid;gap:6px;margin-bottom:14px;padding:12px;border-radius:12px;background:#f8fafc;border:1px solid #E4ECF7;color:var(--text-muted);font-size:12px;line-height:1.45}.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}.feedback-btn{width:100%;padding:12px;background:var(--primary-light);color:var(--primary-deep);border-radius:10px;font-weight:700;font-size:14px;border:2px dashed var(--primary)}.feedback-btn:active{transform:scale(.98)}.feedback-modal textarea{width:100%;background:var(--bg);border:2px solid transparent;border-radius:10px;padding:12px 14px;outline:none;color:var(--text);font-size:14px;font-family:inherit;resize:vertical;min-height:100px;transition:border-color .2s}.feedback-modal textarea:focus{border-color:var(--primary)}.feedback-diag{margin:14px 0 8px;padding:10px 12px;background:var(--bg);border-radius:10px;font-size:12px}.feedback-diag summary{cursor:pointer;font-weight:600;color:var(--primary-deep);outline:none}.feedback-diag pre{margin-top:10px;font-size:11px;color:var(--text-muted);white-space:pre-wrap;word-break:break-all;max-height:200px;overflow-y:auto;background:#fff;padding:8px;border-radius:6px}.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)}.payroll-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.payroll-field.wide{grid-column:1 / -1}}
