:root{--bg:#0f172a;--bg-card:#1e293b;--bg-input:#334155;--bg-hover:#475569;--text:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--accent:#6366f1;--accent-light:#818cf8;--green:#22c55e;--green-bg:#22c55e26;--red:#ef4444;--red-bg:#ef444426;--yellow:#f59e0b;--yellow-bg:#f59e0b26;--border:#334155;--radius:12px;--radius-sm:8px;--shadow:0 4px 24px #0000004d;--font:"DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--tab-height:64px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overflow:hidden}#root{flex-direction:column;display:flex}.page{padding:16px 16px calc(var(--tab-height) + 16px);-webkit-overflow-scrolling:touch;flex:1;overflow:hidden auto}.page-title{letter-spacing:-.02em;margin-bottom:16px;font-size:1.5rem;font-weight:700}.card{background:var(--bg-card);border-radius:var(--radius);margin-bottom:12px;padding:16px}.card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.card-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:600}.btn{border-radius:var(--radius-sm);font-family:var(--font);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;justify-content:center;align-items:center;gap:8px;padding:12px 20px;font-size:.9rem;font-weight:600;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:active{background:var(--accent-light);transform:scale(.97)}.btn-secondary{background:var(--bg-input);color:var(--text)}.btn-secondary:active{background:var(--bg-hover)}.btn-danger{background:var(--red-bg);color:var(--red)}.btn-sm{padding:8px 14px;font-size:.8rem}.btn-block{width:100%}.btn-icon{border-radius:50%;width:44px;height:44px;padding:0;font-size:1.2rem}.input,select,textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);font-family:var(--font);outline:none;padding:12px 14px;font-size:1rem;transition:border-color .15s}.input:focus,select:focus,textarea:focus{border-color:var(--accent)}select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%2394a3b8'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}select option{background:var(--bg-card);color:var(--text)}.form-group{margin-bottom:14px}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:.8rem;font-weight:600;display:block}.amount{font-variant-numeric:tabular-nums;font-weight:600}.amount-positive{color:var(--green)}.amount-negative{color:var(--red)}.tag{border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.progress-bar{background:var(--bg-input);border-radius:4px;height:8px;overflow:hidden}.progress-fill{border-radius:4px;height:100%;transition:width .4s}.tab-bar{height:var(--tab-height);background:var(--bg-card);border-top:1px solid var(--border);z-index:100;padding-bottom:env(safe-area-inset-bottom,0);justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.tab-item{color:var(--text-muted);font-family:var(--font);cursor:pointer;-webkit-tap-highlight-color:transparent;text-transform:uppercase;letter-spacing:.04em;background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;padding:8px 12px;font-size:.65rem;font-weight:600;transition:color .15s;display:flex}.tab-item.active{color:var(--accent-light)}.tab-item .tab-icon{font-size:1.4rem;line-height:1}.quick-amount-input{text-align:center;color:var(--text);width:100%;font-size:3rem;font-weight:700;font-family:var(--font);letter-spacing:-.02em;background:0 0;border:none;outline:none;padding:16px 0}.quick-amount-input::placeholder{color:var(--text-muted)}.category-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.category-btn{background:var(--bg-input);border-radius:var(--radius-sm);cursor:pointer;-webkit-tap-highlight-color:transparent;border:2px solid #0000;flex-direction:column;align-items:center;gap:4px;padding:12px 4px;transition:all .15s;display:flex}.category-btn.selected{border-color:var(--accent);background:#6366f126}.category-btn .cat-icon{font-size:1.5rem}.category-btn .cat-name{color:var(--text-secondary);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:.65rem;font-weight:500;line-height:1.2;overflow:hidden}.type-switch{background:var(--bg-input);border-radius:var(--radius-sm);margin-bottom:16px;padding:3px;display:flex}.type-switch button{color:var(--text-muted);font-family:var(--font);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;padding:10px;font-size:.85rem;font-weight:600;transition:all .15s}.type-switch button.active-expense{background:var(--red-bg);color:var(--red)}.type-switch button.active-income{background:var(--green-bg);color:var(--green)}.type-switch button.active-transfer{color:var(--accent-light);background:#6366f126}.save-success{z-index:200;background:#0f172ad9;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.save-success .checkmark{font-size:4rem;animation:.3s popIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.tx-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 0;display:flex}.tx-item:last-child{border-bottom:none}.tx-icon{background:var(--bg-input);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.3rem;display:flex}.tx-details{flex:1;min-width:0}.tx-cat{font-size:.9rem;font-weight:600}.tx-desc{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.78rem;overflow:hidden}.tx-amount{white-space:nowrap;font-size:1rem;font-weight:700}.tx-date{color:var(--text-muted);text-align:right;font-size:.7rem}.modal-overlay{z-index:150;background:#0009;align-items:flex-end;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-card);border-radius:16px 16px 0 0;width:100%;max-height:85vh;padding:20px 16px;animation:.25s slideUp;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.modal-title{font-size:1.1rem;font-weight:700}.modal-close{background:var(--bg-input);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.budget-row{margin-bottom:14px}.budget-row-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.budget-row-label{align-items:center;gap:8px;font-size:.85rem;font-weight:600;display:flex}.budget-row-amounts{color:var(--text-secondary);font-variant-numeric:tabular-nums;font-size:.8rem}.empty-state{text-align:center;color:var(--text-muted);padding:40px 20px}.empty-state .empty-icon{margin-bottom:12px;font-size:3rem}.empty-state p{font-size:.9rem}@media (width>=768px){.page{max-width:600px;padding-bottom:calc(var(--tab-height) + 24px);margin:0 auto}.tab-bar{border-radius:16px 16px 0 0;max-width:600px;margin:0 auto;left:50%;transform:translate(-50%)}}.flex{display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.gap-8{gap:8px}.gap-12{gap:12px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-muted)}.text-center{text-align:center}.fw-600{font-weight:600}.fw-700{font-weight:700}
