:root{--blue: #4066F2;--green: #26BF8C;--red: #FF5959;--orange: #FF8C42;--yellow: #F9A825;--bg: #F2F2F7;--card: #ffffff;--text: #1C1C1E;--text2: #6C6C70;--border: #E5E5EA;--radius: 16px;--radius-sm: 10px;--shadow: 0 2px 12px rgba(0,0,0,.07);--tab-h: 80px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.4;-webkit-font-smoothing:antialiased;height:100%}#root{height:100%}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}a{color:inherit;text-decoration:none}.app{max-width:430px;margin:0 auto;min-height:100dvh;position:relative;background:var(--bg);display:flex;flex-direction:column}.main-content{flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:var(--tab-h);scroll-behavior:smooth}@media (min-width: 768px){body{background:#1c1c2e;display:flex;align-items:flex-start;justify-content:center;padding:20px;min-height:100vh}.app{min-height:calc(100vh - 40px);border-radius:40px;overflow:hidden;box-shadow:0 30px 80px #00000080}}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow)}.card-pad{padding:16px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-title{font-size:17px;font-weight:600}.see-all{font-size:14px;color:var(--blue);background:none;border:none;font-weight:500}.nav-header{display:flex;align-items:flex-end;justify-content:space-between;padding:16px 20px 8px;background:var(--bg);position:sticky;top:0;z-index:10}.nav-title{font-size:28px;font-weight:700}.nav-actions{display:flex;gap:8px;align-items:center}.icon-btn{width:36px;height:36px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;font-size:18px;background:var(--card);box-shadow:var(--shadow);color:var(--text2)}.icon-btn-primary{background:var(--blue);color:#fff;box-shadow:0 4px 12px #4066f266}.period-scroll{overflow-x:auto;padding:0 20px 4px;scrollbar-width:none}.period-scroll::-webkit-scrollbar{display:none}.period-chips{display:flex;gap:8px;width:max-content}.period-chip{padding:7px 16px;border-radius:999px;border:none;font-size:14px;font-weight:500;background:var(--card);color:var(--text2);white-space:nowrap}.period-chip.active{background:var(--blue);color:#fff;box-shadow:0 3px 8px #4066f259}.divider{height:1px;background:var(--border);margin:0 0 0 58px}.empty-state{text-align:center;padding:32px 20px;color:var(--text2)}.empty-state .icon{font-size:40px;margin-bottom:12px}.empty-state h3{font-size:16px;font-weight:600;color:var(--text);margin-bottom:6px}.empty-state p{font-size:14px}.btn{border:none;border-radius:var(--radius-sm);padding:12px 20px;font-size:16px;font-weight:600;cursor:pointer}.btn-primary{background:var(--blue);color:#fff}.btn-secondary{background:var(--bg);color:var(--blue)}.btn-danger{background:#fff0f0;color:var(--red)}.btn-full{width:100%;border-radius:12px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:100;display:flex;align-items:flex-end;justify-content:center}@media (min-width: 768px){.modal-overlay{align-items:center}}.modal-sheet{background:var(--card);border-radius:24px 24px 0 0;width:100%;max-width:430px;max-height:92dvh;overflow-y:auto;padding:0 0 env(safe-area-inset-bottom,16px)}@media (min-width: 768px){.modal-sheet{border-radius:24px;max-height:80vh}}.modal-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:10px auto 0}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--card);z-index:1}.modal-title{font-size:17px;font-weight:600}.modal-body{padding:16px 20px}.modal-close{background:var(--bg);border:none;border-radius:50%;width:28px;height:28px;font-size:14px;color:var(--text2);display:flex;align-items:center;justify-content:center}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:500;color:var(--text2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.03em}.form-input,.form-select,.form-textarea{width:100%;padding:12px 14px;background:var(--bg);border:1.5px solid transparent;border-radius:var(--radius-sm);font-size:16px;color:var(--text);outline:none;transition:border-color .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--blue)}.form-textarea{resize:none;height:80px}.type-toggle{display:flex;background:var(--bg);border-radius:var(--radius-sm);padding:4px;gap:4px}.type-toggle-btn{flex:1;padding:10px;border:none;border-radius:8px;font-size:15px;font-weight:600;background:transparent;color:var(--text2);transition:background .15s,color .15s}.type-toggle-btn.active-income{background:#e8f8f2;color:var(--green)}.type-toggle-btn.active-expense{background:#fff0f0;color:var(--red)}.amount-wrapper{position:relative}.amount-prefix{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:20px;font-weight:600;color:var(--text2)}.form-input-amount{padding-left:28px;font-size:24px;font-weight:700}.tx-row{display:flex;align-items:center;gap:12px;padding:10px 0}.tx-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.tx-info{flex:1;min-width:0}.tx-desc{font-size:15px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx-meta{font-size:12px;color:var(--text2);margin-top:2px}.tx-amount{font-size:15px;font-weight:600;text-align:right}.tx-amount.income{color:var(--green)}.tx-amount.expense{color:var(--text)}.tx-date{font-size:11px;color:var(--text2);text-align:right;margin-top:2px}.acc-row{display:flex;align-items:center;gap:12px;padding:10px 0}.acc-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.acc-info{flex:1}.acc-name{font-size:15px;font-weight:500}.acc-type{font-size:12px;color:var(--text2);margin-top:2px}.acc-balance{text-align:right}.acc-balance-amount{font-size:15px;font-weight:600}.acc-balance-label{font-size:11px;color:var(--text2);margin-top:2px}.nw-card{background:linear-gradient(135deg,#4066f2,#7b50e8);color:#fff;border-radius:var(--radius);padding:20px;box-shadow:0 8px 24px #4066f259}.nw-label{font-size:13px;opacity:.8;font-weight:500}.nw-amount{font-size:36px;font-weight:700;margin:6px 0 16px;letter-spacing:-.5px}.nw-row{display:flex;gap:0}.nw-col{flex:1;text-align:center}.nw-col+.nw-col{border-left:1px solid rgba(255,255,255,.25)}.nw-col-label{font-size:11px;opacity:.75;margin-bottom:4px}.nw-col-value{font-size:15px;font-weight:600}.cf-card{padding:14px 16px;flex:1}.cf-label{font-size:12px;color:var(--text2);font-weight:500;margin-bottom:6px;display:flex;align-items:center;gap:4px}.cf-amount{font-size:20px;font-weight:700}.cf-amount.green{color:var(--green)}.cf-amount.red{color:var(--red)}.stat-pill{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--card);border-radius:12px;box-shadow:var(--shadow);flex:1}.stat-pill-icon{font-size:22px}.stat-pill-label{font-size:12px;color:var(--text2);margin-bottom:2px}.stat-pill-value{font-size:17px;font-weight:700}.section-group{padding:0 20px;margin-bottom:16px}.date-group{margin-bottom:16px}.date-group-header{display:flex;justify-content:space-between;align-items:center;padding:8px 0 4px;font-size:13px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.05em}.search-bar{display:flex;align-items:center;background:var(--card);border-radius:12px;padding:10px 14px;gap:8px;box-shadow:var(--shadow)}.search-icon{font-size:16px;color:var(--text2)}.search-input{flex:1;border:none;background:none;font-size:16px;outline:none;color:var(--text)}.filter-chip{padding:6px 14px;border-radius:999px;border:none;font-size:13px;font-weight:500;background:var(--card);color:var(--text2);white-space:nowrap;box-shadow:var(--shadow)}.filter-chip.active{background:var(--blue);color:#fff}.filter-chip.income.active{background:#e8f8f2;color:var(--green)}.filter-chip.expense.active{background:#fff0f0;color:var(--red)}.settings-section{margin-bottom:24px}.settings-section-title{font-size:13px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.05em;padding:0 4px;margin-bottom:8px}.settings-card{background:var(--card);border-radius:var(--radius);overflow:hidden}.settings-row{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}.settings-row:last-child{border-bottom:none}.settings-row-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.settings-row-text{flex:1}.settings-row-title{font-size:15px;font-weight:500}.settings-row-sub{font-size:12px;color:var(--text2);margin-top:2px}.settings-row-action{flex-shrink:0}.toggle{position:relative;width:51px;height:31px;display:inline-block}.toggle input{opacity:0;width:0;height:0}.toggle-track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border);border-radius:999px;transition:background .2s;cursor:pointer}.toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:25px;height:25px;border-radius:50%;background:#fff;box-shadow:0 2px 4px #0003;transition:transform .2s}.toggle input:checked+.toggle-track{background:var(--green)}.toggle input:checked+.toggle-track:after{transform:translate(20px)}.demo-banner{background:var(--orange);color:#fff;display:flex;align-items:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:500;position:sticky;top:0;z-index:50}.demo-banner-text{flex:1}.demo-banner-exit{background:#ffffff40;border:none;border-radius:999px;color:#fff;font-size:12px;font-weight:700;padding:4px 12px}.tab-bar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;display:flex;align-items:center;padding:12px 8px max(20px,env(safe-area-inset-bottom,20px));background:var(--card);border-radius:28px 28px 0 0;box-shadow:0 -4px 24px #0000001a;z-index:20;height:var(--tab-h)}.tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;border:none;background:none;color:#c7c7cc;font-size:10px;font-weight:500;padding:4px 0;transition:color .15s}.tab-btn.active{color:var(--blue)}.tab-btn svg,.tab-btn .tab-icon{font-size:22px}.tab-fab{width:52px;height:52px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--blue) 0%,#7B50E8 100%);color:#fff;font-size:24px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #4066f273;margin-top:-16px;flex-shrink:0}.progress-bar{height:6px;background:var(--bg);border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:width .3s}.recharts-wrapper{overflow:visible!important}.recharts-cartesian-axis-tick text{fill:var(--text2);font-size:11px}.recharts-tooltip-wrapper{z-index:10}.chart-card{padding:16px}.chart-card-title{font-size:15px;font-weight:600;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}.page{padding-top:0}.page-content{padding:0 20px 8px;display:flex;flex-direction:column;gap:16px}
