@import url(https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500&family=Space+Grotesk:wght@300;400;500;600;700&display=swap);*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0e1a;--bg2:#0f1628;--surface:#151d35;--surface2:#1c2645;--border:#1e2d50;--text:#e2e8f0;--text2:#94a3b8;--text3:#64748b;--accent:#f97316;--accent2:#fb923c;--green:#10b981;--red:#ef4444;--blue:#3b82f6;--yellow:#f59e0b;--purple:#8b5cf6;--cyan:#06b6d4;--radius:12px;--radius-sm:8px;--shadow:0 4px 24px #00000073;--font:"Space Grotesk",sans-serif;--mono:"JetBrains Mono",monospace}body{background:#0a0e1a;background:var(--bg);color:#e2e8f0;color:var(--text);font-family:Space Grotesk,sans-serif;font-family:var(--font);min-height:100vh}.app,.sidebar{display:flex;min-height:100vh}.sidebar{background:#0f1628;background:var(--bg2);border-right:1px solid #1e2d50;border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;height:100vh;position:-webkit-sticky;position:sticky;top:0;width:260px}.brand{align-items:center;border-bottom:1px solid #1e2d50;border-bottom:1px solid var(--border);display:flex;gap:12px;padding:28px 20px 24px}.brand-icon{font-size:28px}.brand-name{color:#f97316;color:var(--accent);font-size:16px;font-weight:700;letter-spacing:.5px}.brand-sub{color:#64748b;color:var(--text3);font-family:JetBrains Mono,monospace;font-family:var(--mono);font-size:11px}.nav{display:flex;flex:1 1;flex-direction:column;gap:4px;padding:16px 12px}.nav-item{align-items:center;background:#0000;border:none;border-radius:8px;border-radius:var(--radius-sm);color:#94a3b8;color:var(--text2);cursor:pointer;display:flex;font-family:Space Grotesk,sans-serif;font-family:var(--font);font-size:14px;font-weight:500;gap:12px;padding:12px 16px;text-align:left;transition:all .2s;width:100%}.nav-item:hover{background:#151d35;background:var(--surface);color:#e2e8f0;color:var(--text)}.nav-item.active{background:linear-gradient(135deg,#f97316,#ea580c);background:linear-gradient(135deg,var(--accent) 0,#ea580c 100%);box-shadow:0 4px 14px #f9731659;color:#fff}.nav-icon{font-size:18px}.sidebar-footer{border-top:1px solid #1e2d50;border-top:1px solid var(--border);padding:16px 12px 24px}.full-btn{width:100%}.main{flex:1 1;min-width:0;overflow-y:auto;padding:0}.page{max-width:1200px;padding:32px}.page-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:28px}.page-header h1{color:#e2e8f0;color:var(--text);font-size:28px;font-weight:700}.subtitle{color:#64748b;color:var(--text3);font-size:13px;margin-top:4px}.card{background:#151d35;background:var(--surface);border:1px solid #1e2d50;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);margin-bottom:20px;padding:24px}.card h3{color:#94a3b8;color:var(--text2);font-size:15px;font-weight:600;margin-bottom:16px}.two-col{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:20px}@media (max-width:900px){.two-col{grid-template-columns:1fr}}.stat-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}@media (max-width:1100px){.stat-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.stat-grid{grid-template-columns:1fr}}.stat-card{align-items:center;background:#151d35;background:var(--surface);border:1px solid #1e2d50;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);display:flex;gap:16px;padding:20px 24px;transition:transform .2s,box-shadow .2s}.stat-card:hover{box-shadow:0 4px 24px #00000073;box-shadow:var(--shadow);transform:translateY(-2px)}.stat-budget{border-left:4px solid #f59e0b;border-left:4px solid var(--yellow)}.stat-credit{border-left:4px solid #10b981;border-left:4px solid var(--green)}.stat-debit{border-left:4px solid #ef4444;border-left:4px solid var(--red)}.stat-today{border-left:4px solid #06b6d4;border-left:4px solid var(--cyan)}.stat-danger{border-left:4px solid #ef4444;border-left:4px solid var(--red)}.stat-icon{font-size:28px}.stat-info{display:flex;flex-direction:column;gap:4px}.stat-label{color:#64748b;color:var(--text3);font-size:12px;font-weight:500;letter-spacing:.8px;text-transform:uppercase}.stat-value{color:#e2e8f0;color:var(--text);font-family:JetBrains Mono,monospace;font-family:var(--mono);font-size:22px;font-weight:700}.progress-bar-wrap{align-items:center;display:flex;gap:12px;margin-bottom:12px}.progress-bar-track{background:#1c2645;background:var(--surface2);border-radius:99px;flex:1 1;height:10px;overflow:hidden}.progress-bar-fill{border-radius:99px;height:100%;transition:width .5s ease}.fill-ok{background:linear-gradient(90deg,#10b981,#059669);background:linear-gradient(90deg,var(--green),#059669)}.fill-warn{background:linear-gradient(90deg,#f59e0b,#d97706);background:linear-gradient(90deg,var(--yellow),#d97706)}.fill-danger{background:linear-gradient(90deg,#ef4444,#dc2626);background:linear-gradient(90deg,var(--red),#dc2626)}.progress-label{color:#94a3b8;color:var(--text2);font-family:JetBrains Mono,monospace;font-family:var(--mono);font-size:13px;min-width:40px;text-align:right}.budget-row{color:#64748b;color:var(--text3);display:flex;flex-wrap:wrap;font-size:13px;gap:24px}.mini-bar-wrap{align-items:center;display:flex;gap:8px}.mini-bar-track{background:#1c2645;background:var(--surface2);border-radius:99px;height:6px;overflow:hidden;width:80px}.mini-bar-fill{background:#f97316;background:var(--accent);border-radius:99px;height:100%}.txn-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}.txn-row{background:#1c2645;background:var(--surface2);border:1px solid #1e2d50;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius-sm);justify-content:space-between;padding:10px 12px}.txn-left,.txn-row{align-items:center;display:flex}.txn-left{gap:12px}.txn-icon{font-size:20px}.txn-name{color:#e2e8f0;color:var(--text);font-size:14px;font-weight:500}.txn-meta{color:#64748b;color:var(--text3);font-size:11px;margin-top:2px}.txn-amount{font-family:JetBrains Mono,monospace;font-family:var(--mono);font-size:14px;font-weight:600}.txn-amount.credit{color:#10b981;color:var(--green)}.txn-amount.debit{color:#ef4444;color:var(--red)}.table-card{overflow:hidden;padding:0}.table-card h3{padding:20px 24px 0}.expense-table{border-collapse:collapse;font-size:13px;width:100%}.expense-table thead th{background:#1c2645;background:var(--surface2);color:#64748b;color:var(--text3);font-size:11px;letter-spacing:.8px;padding:12px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.expense-table tbody tr,.expense-table thead th{border-bottom:1px solid #1e2d50;border-bottom:1px solid var(--border)}.expense-table tbody tr:hover{background:#1c2645;background:var(--surface2)}.expense-table tbody td{padding:12px 16px;vertical-align:middle}.expense-table tfoot td{background:#1c2645;background:var(--surface2);border-top:1px solid #1e2d50;border-top:1px solid var(--border);font-weight:600;padding:12px 16px}.foot-label{color:#94a3b8;color:var(--text2)}.num{font-family:JetBrains Mono,monospace;font-family:var(--mono);text-align:right}.credit-text{color:#10b981;color:var(--green)}.debit-text{color:#ef4444;color:var(--red)}.date-cell{font-family:JetBrains Mono,monospace;font-family:var(--mono)}.date-cell,.remarks-cell{font-size:12px;white-space:nowrap}.remarks-cell{max-width:140px;overflow:hidden;text-overflow:ellipsis}.empty-cell,.remarks-cell{color:#64748b;color:var(--text3)}.empty-cell{padding:40px!important;text-align:center}.cat-chip{align-items:center;background:#1c2645;background:var(--surface2);border:1px solid #1e2d50;border:1px solid var(--border);display:inline-flex;font-size:12px;gap:4px;padding:3px 10px;white-space:nowrap}.badge,.cat-chip{border-radius:99px}.badge{display:inline-block;font-size:11px;font-weight:500;padding:3px 8px}.badge-food{background:#10b98126;border:1px solid #10b9814d;color:#10b981;color:var(--green)}.badge-nonfood{background:#3b82f626;border:1px solid #3b82f64d;color:#3b82f6;color:var(--blue)}.action-btns{display:flex;gap:6px}.icon-btn{background:none;border:1px solid #1e2d50;border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:14px;padding:4px 8px;transition:all .15s}.icon-btn:hover{background:#1c2645;background:var(--surface2)}.filter-bar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;padding:16px 20px}.filter-bar input,.filter-bar select{background:#1c2645;background:var(--surface2);border:1px solid #1e2d50;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius-sm);color:#e2e8f0;color:var(--text);font-family:Space Grotesk,sans-serif;font-family:var(--font);font-size:13px;outline:none;padding:8px 12px}.filter-bar input:focus,.filter-bar select:focus{border-color:#f97316;border-color:var(--accent)}.month-picker{display:flex;gap:10px}.month-picker select{background:#151d35;background:var(--surface);border:1px solid #1e2d50;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius-sm);color:#e2e8f0;color:var(--text);font-family:Space Grotesk,sans-serif;font-family:var(--font);font-size:14px;padding:8px 14px}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.modal{animation:slideUp .2s ease;background:#151d35;background:var(--surface);border:1px solid #1e2d50;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 4px 24px #00000073;box-shadow:var(--shadow);max-width:95vw;width:540px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;display:flex;justify-content:space-between;padding:24px 24px 0}.modal-header h2{font-size:18px;font-weight:700}.close-btn{background:none;border:none;border-radius:6px;color:#64748b;color:var(--text3);cursor:pointer;font-size:18px;padding:4px 8px}.close-btn:hover{background:#1c2645;background:var(--surface2);color:#e2e8f0;color:var(--text)}.form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;padding:20px 24px}.form-group{display:flex;flex-direction:column;gap:6px}.span2{grid-column:span 2}.form-group label{color:#64748b;color:var(--text3);font-size:12px;font-weight:500;letter-spacing:.6px;text-transform:uppercase}.form-group input,.form-group select,.form-group textarea{background:#1c2645;background:var(--surface2);border:1px solid #1e2d50;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius-sm);color:#e2e8f0;color:var(--text);font-family:Space Grotesk,sans-serif;font-family:var(--font);font-size:14px;outline:none;padding:10px 14px;resize:none;transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#f97316;border-color:var(--accent);box-shadow:0 0 0 3px #f973161f}.form-group select option{background:#151d35;background:var(--surface)}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:0 24px 24px}.btn{align-items:center;border:none;border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-family:Space Grotesk,sans-serif;font-family:var(--font);font-size:14px;font-weight:600;gap:6px;padding:10px 22px;transition:all .15s}.btn-primary{background:linear-gradient(135deg,#f97316,#ea580c);background:linear-gradient(135deg,var(--accent),#ea580c);box-shadow:0 4px 14px #f9731659;color:#fff}.btn-primary:hover{box-shadow:0 6px 20px #f9731680;transform:translateY(-1px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-ghost{background:#1c2645;background:var(--surface2);border:1px solid #1e2d50;border:1px solid var(--border);color:#94a3b8;color:var(--text2)}.btn-ghost:hover{background:#1e2d50;background:var(--border);color:#e2e8f0;color:var(--text)}.toast{align-items:center;animation:slideUp .2s ease;background:#151d35;background:var(--surface);border:1px solid #1e2d50;border:1px solid var(--border);border-radius:8px;border-radius:var(--radius-sm);bottom:24px;box-shadow:0 4px 24px #00000073;box-shadow:var(--shadow);display:flex;font-size:14px;gap:12px;padding:14px 20px;position:fixed;right:24px;z-index:2000}.toast-success{border-left:4px solid #10b981;border-left:4px solid var(--green)}.toast-error{border-left:4px solid #ef4444;border-left:4px solid var(--red)}.toast button{background:none;border:none;cursor:pointer;font-size:16px}.loading,.toast button{color:#64748b;color:var(--text3)}.loading{align-items:center;display:flex;font-size:14px;height:200px;justify-content:center}.empty{color:#64748b;color:var(--text3);font-size:13px;padding:20px 0;text-align:center}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0f1628;background:var(--bg2)}::-webkit-scrollbar-thumb{background:#1e2d50;background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#64748b;background:var(--text3)}
/*# sourceMappingURL=main.979ec387.css.map*/