*{box-sizing:border-box;margin:0;padding:0}body{background:#f0f4f8;font-family:Segoe UI,sans-serif}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:10px}.sidebar{background:#1a1f2e;display:flex;flex-direction:column;left:0;min-height:100vh;overflow-y:auto;padding:24px 16px;position:fixed;top:0;width:220px;z-index:50}.sidebar-logo{align-items:center;display:flex;gap:10px;margin-bottom:36px;padding:0 8px}.logo-icon{font-size:24px}.logo-text{color:#fff;font-size:20px;font-weight:700;letter-spacing:.5px}.sidebar-nav{display:flex;flex-direction:column;gap:4px}.nav-link{align-items:center;border-radius:10px;color:#8892a4;display:flex;font-size:15px;gap:12px;padding:11px 14px;text-decoration:none;transition:all .2s ease}.nav-link:hover{background:#252c3d;color:#fff}.nav-link.active{background:#3b82f6;color:#fff;font-weight:500}.nav-icon{font-size:18px}.sidebar-bot-hint{align-items:center;background:#252c3d;border-radius:10px;display:flex;gap:8px;margin-top:auto;padding:12px 14px}.bot-label{color:#fff;flex:1 1;font-size:14px}.bot-status{color:#10b981;font-size:11px;font-weight:600}@media (max-width:768px){.sidebar{display:none}}.logout-btn{background:none;border:1.5px solid #374151;border-radius:10px;color:#6b7280;cursor:pointer;font-size:13px;margin-top:12px;padding:10px 14px;text-align:left;transition:all .2s;width:100%}.logout-btn:hover{background:#fef2f2;border-color:#ef4444;color:#ef4444}.bottom-nav{display:none}@media (max-width:768px){.bottom-nav{-webkit-overflow-scrolling:touch;background:#1a1f2e;border-top:1px solid #252c3d;bottom:0;display:flex;height:64px;left:0;overflow-x:auto;position:fixed;right:0;z-index:100}.bottom-nav-item{align-items:center;color:#6b7280;display:flex;flex:1 1;flex-direction:column;gap:2px;justify-content:center;min-width:56px;padding:8px 4px;text-decoration:none;transition:all .2s}.bottom-nav-item.active{color:#3b82f6}.bottom-nav-icon{font-size:20px;line-height:1}.bottom-nav-label{font-size:10px;font-weight:500;white-space:nowrap}}.sync-bar{background:#1a1f2e;border-bottom:1px solid #252c3d;height:48px;justify-content:space-between;left:220px;padding:0 16px;position:fixed;right:0;top:0;z-index:40}.sync-bar,.sync-user{align-items:center;display:flex}.sync-user{gap:8px}.sync-avatar{border:2px solid #3b82f6;border-radius:50%;flex-shrink:0;height:28px;width:28px}.sync-user-info{display:flex;flex-direction:column;gap:1px}.sync-name{color:#e5e7eb;font-size:13px;font-weight:500;line-height:1}.sync-email{line-height:1}.sync-chevron,.sync-email{color:#6b7280;font-size:11px}.sync-chevron{margin-left:2px}.sync-status{border-radius:20px;font-size:12px;font-weight:500;padding:3px 10px;white-space:nowrap}.sync-status.syncing{animation:pulse 1s infinite;background:#fef3c7;color:#d97706}.sync-status.saved{background:#d1fae5;color:#065f46}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.sync-menu-overlay{inset:0;position:fixed;z-index:90}.sync-menu{animation:dropDown .15s ease;background:#fff;border-radius:14px;box-shadow:0 8px 32px #0000002e;left:224px;overflow:hidden;position:fixed;top:52px;width:240px;z-index:100}@keyframes dropDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.sync-menu-user{align-items:center;display:flex;gap:12px;padding:16px}.sync-menu-avatar{border:2px solid #e5e7eb;border-radius:50%;height:40px;width:40px}.sync-menu-name{color:#1a1f2e;font-size:14px;font-weight:600}.sync-menu-email{color:#9ca3af;font-size:12px;margin-top:2px}.sync-menu-divider{border:none;border-top:1px solid #f3f4f6;margin:0}.sync-menu-signout{background:none;border:none;color:#ef4444;cursor:pointer;font-size:14px;font-weight:500;padding:14px 16px;text-align:left;transition:background .2s;width:100%}.sync-menu-signout:hover{background:#fef2f2}@media (max-width:768px){.sync-bar{left:0}.sync-menu{left:12px;right:12px;width:auto}.sync-email{display:block}}.app-layout{background:#f0f4f8;display:flex;min-height:100vh}.main-content{align-items:center;display:flex;flex:1 1;flex-direction:column;margin-left:220px;padding:60px 32px 32px}@media (max-width:768px){.main-content{align-items:stretch;margin-left:0;padding:60px 16px 80px}}.dash-summary{grid-gap:16px;align-items:start;display:grid;gap:16px;grid-template-columns:1fr 220px;margin-bottom:24px}.balance-card,.dash-right-col{display:flex;flex-direction:column;gap:16px}.balance-card{background:#fff;border:.5px solid #e5e7eb;border-radius:16px;box-shadow:0 2px 12px #00000012;padding:24px}.balance-card-main{align-items:flex-start;display:flex;gap:12px;justify-content:space-between}.balance-card .dash-label{color:#9ca3af;display:block;font-size:12px;font-weight:500;margin-bottom:4px}.balance-val{color:#1a1f2e;font-size:36px;font-weight:700;line-height:1.1}.balance-val.negative{color:#ef4444}.balance-edit-btn{background:#f9fafb;border:.5px solid #e5e7eb;border-radius:8px;color:#6b7280;cursor:pointer;flex-shrink:0;font-family:inherit;font-size:12px;margin-top:6px;padding:7px 14px;transition:background .15s,color .15s;white-space:nowrap}.balance-edit-btn:hover{background:#f3f4f6;color:#1a1f2e}.balance-breakdown{align-items:stretch;background:#f9fafb;border:.5px solid #e5e7eb;border-radius:10px;display:flex;overflow:hidden}.breakdown-item{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0;padding:10px 14px}.breakdown-divider{background:#e5e7eb;flex-shrink:0;width:.5px}.breakdown-label{color:#9ca3af;font-size:11px;white-space:nowrap}.breakdown-val{color:#1a1f2e;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.breakdown-tag{background:#eff6ff;color:#3b82f6}.breakdown-reset,.breakdown-tag{border-radius:99px;font-size:10px;padding:2px 7px;width:fit-content}.breakdown-reset{background:none;border:.5px solid #e5e7eb;color:#9ca3af;cursor:pointer;font-family:inherit;transition:color .15s}.breakdown-reset:hover{border-color:#bfdbfe;color:#3b82f6}.balance-edit-inline{display:flex;flex-direction:column;gap:8px}.balance-edit-field{display:flex;flex-direction:column;gap:6px}.balance-edit-label{color:#9ca3af;font-size:12px}.balance-edit-row{align-items:center;display:flex;gap:8px}.balance-input{background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;color:#1a1f2e;flex:1 1;font-family:inherit;font-size:14px;min-width:0;outline:none;padding:9px 12px}.balance-input:focus{border-color:#3b82f6}.balance-save-btn{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:9px 18px;white-space:nowrap}.balance-save-btn:hover{background:#2563eb}.balance-cancel-btn{background:#f3f4f6;border:none;border-radius:8px;color:#6b7280;cursor:pointer;font-size:13px;font-weight:600;padding:9px 14px;white-space:nowrap}.balance-cancel-btn:hover{background:#e5e7eb}.balance-acc-note{color:#9ca3af;font-size:12px;line-height:1.5}.dash-card{border-radius:16px;box-shadow:0 2px 12px #0000000f;display:flex;flex-direction:column;gap:4px;padding:20px}.networth-card{background:#f0fdf4;border:.5px solid #bbf7d0}.credit-due-card{background:#fdf2f8;border:.5px solid #f5d0fe}.dash-label{color:#6b7280;font-size:12px;font-weight:500}.dash-value{color:#1a1f2e;font-size:22px;font-weight:700}.dash-card-sub{color:#9ca3af;font-size:11px;margin-top:2px}.debit-color{color:#ef4444!important}.credit-color{color:#10b981!important}.acc-balance-strip{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));margin-bottom:24px}.acc-strip-item{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;gap:10px;padding:14px 16px}.acc-strip-icon{align-items:center;border-radius:8px;display:flex;flex-shrink:0;font-size:16px;height:34px;justify-content:center;width:34px}.acc-strip-info{display:flex;flex-direction:column;gap:2px;min-width:0}.acc-strip-name{color:#6b7280;font-size:12px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.acc-strip-bal{font-size:14px;font-weight:700}.acc-strip-bal.positive{color:#1a1f2e}.acc-strip-bal.negative{color:#ef4444}.dash-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}.dash-panel{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000012;padding:24px}.panel-title{color:#1a1f2e;font-size:16px;font-weight:600;margin-bottom:16px}.panel-empty{color:#9ca3af;font-size:14px;padding:40px 0;text-align:center}.recent-list{display:flex;flex-direction:column;gap:12px}.recent-item{background:#f9fafb;border-radius:10px;justify-content:space-between;padding:10px 14px}.recent-item,.recent-title-row{align-items:center;display:flex}.recent-title-row{flex-wrap:wrap;gap:6px}.recent-title{color:#1a1f2e;font-size:14px;font-weight:500}.recent-meta{color:#9ca3af;font-size:12px;margin-top:2px}.recent-amount{font-size:14px;font-weight:600}.recent-amount.debit{color:#ef4444}.recent-amount.credit{color:#10b981}.recent-acc-badge{border-radius:10px;font-size:11px;font-weight:500;padding:2px 8px;white-space:nowrap}@media (max-width:768px){.dash-summary{gap:12px;grid-template-columns:1fr}.balance-val{font-size:28px}.balance-card-main{align-items:flex-start;flex-direction:column}.balance-edit-btn{margin-top:0}.breakdown-item{padding:10px}.breakdown-val{font-size:12px}.dash-grid{gap:16px;grid-template-columns:1fr}}.page{margin:0 auto;max-width:860px;width:100%}.page-heading{color:#1a1f2e;font-size:26px;font-weight:700;margin-bottom:24px}@media (max-width:768px){.page-heading{font-size:20px;margin-bottom:16px}}.txn-form-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000012;padding:24px}.txn-form-title{color:#1a1f2e;font-size:18px;font-weight:600;margin-bottom:20px}.txn-form{display:flex;flex-direction:column;gap:16px}.type-toggle{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.toggle-btn{align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;color:#6b7280;cursor:pointer;display:flex;flex-direction:column;font-size:15px;font-weight:600;gap:2px;padding:14px 12px;transition:all .2s}.toggle-hint{color:#9ca3af;font-size:11px;font-weight:400}.toggle-btn.debit-btn.active{background:#fef2f2;border-color:#ef9744;color:#ef9744}.toggle-btn.debit-btn.active .toggle-hint{color:#fca5a5}.toggle-btn.credit-btn.active{background:#f0fdf4;border-color:#10b981;color:#10b981}.toggle-btn.credit-btn.active .toggle-hint{color:#6ee7b7}.toggle-btn:hover{opacity:.85}.txn-form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{align-items:center;color:#6b7280;display:flex;font-size:13px;font-weight:500;gap:6px}.optional-tag{background:#f3f4f6;border-radius:10px;color:#9ca3af;font-size:11px;font-weight:400;padding:1px 8px}.form-group input,.form-group select{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;color:#1a1f2e;font-size:14px;outline:none;padding:10px 14px;transition:border .2s}.form-group input:focus,.form-group select:focus{background:#fff;border-color:#3b82f6}.notes-textarea{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;color:#1a1f2e;font-family:inherit;font-size:14px;min-height:64px;outline:none;padding:10px 14px;resize:vertical;transition:border .2s}.notes-textarea:focus{background:#fff;border-color:#3b82f6}.recurring-section{align-items:center;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;display:flex;flex-wrap:wrap;gap:16px;padding:12px 14px}.recurring-label{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:14px;gap:8px}.recurring-label input[type=checkbox]{accent-color:#3b82f6;cursor:pointer;height:16px;width:16px}.recurring-select{background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;color:#1a1f2e;font-size:13px;outline:none;padding:8px 12px}.txn-submit-btn{border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;letter-spacing:.3px;padding:14px;transition:opacity .2s}.txn-submit-btn.debit{background:#ef4444}.txn-submit-btn.credit{background:#10b981}.txn-submit-btn:hover{opacity:.88}@media (max-width:768px){.txn-form-card{border-radius:12px;padding:16px}.txn-form-title{font-size:16px;margin-bottom:14px}.txn-form-row{gap:12px;grid-template-columns:1fr}.type-toggle{gap:8px}.toggle-btn{font-size:14px;padding:10px 8px}}.txn-account-select-wrap{align-items:center;display:flex;position:relative}.txn-account-dot{align-items:center;border-radius:6px;display:flex;font-size:13px;height:24px;justify-content:center;left:10px;pointer-events:none;position:absolute;width:24px;z-index:1}.txn-account-select-wrap select{appearance:none;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;color:#1a1f2e;cursor:pointer;font-size:14px;outline:none;padding:10px 14px;transition:border .2s;width:100%}.txn-account-select-wrap select.has-account-icon{padding-left:42px}.txn-account-select-wrap select:focus{background:#fff;border-color:#3b82f6}.txn-cc-hint{background:#faf5ff;border:1px solid #e9d5ff;border-radius:8px;color:#a855f7;font-size:12px;margin-top:6px;padding:8px 12px}.txn-bill-payment-row{background:#fff7ed;border:1.5px solid #fed7aa;border-radius:10px;padding:12px 14px}.txn-bill-label{align-items:center;color:#92400e;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:8px}.txn-bill-label input[type=checkbox]{cursor:pointer;height:16px;width:16px}.modal-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.modal-box{background:#fff;border-radius:20px;box-shadow:0 20px 60px #00000026;max-width:360px;padding:32px 28px;text-align:center;width:100%}.modal-icon{font-size:36px;margin-bottom:12px}.modal-title{color:#1a1f2e;font-size:18px;font-weight:600;margin-bottom:8px}.modal-message{color:#6b7280;font-size:14px;line-height:1.6;margin-bottom:24px}.modal-actions{display:flex;gap:12px}.modal-cancel{background:#f3f4f6;border:none;border-radius:10px;color:#374151;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:11px}.modal-cancel:hover{background:#e5e7eb}.modal-confirm{background:#ef4444;border:none;border-radius:10px;color:#fff;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:11px}.modal-confirm:hover{background:#dc2626}.txn-list-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000012;margin-top:24px;padding:24px}.txn-list-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.txn-list-title{color:#1a1f2e;font-size:18px;font-weight:600}.txn-count{color:#9ca3af;display:block;font-size:12px;margin-top:2px}.export-btn{background:#f0fdf4;border:1.5px solid #6ee7b7;border-radius:10px;color:#10b981;cursor:pointer;font-size:13px;font-weight:600;padding:10px 18px;transition:all .2s;white-space:nowrap}.export-btn:hover{background:#d1fae5;border-color:#10b981}.type-filter-bar{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.type-filter-btn{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:20px;color:#6b7280;cursor:pointer;font-size:13px;font-weight:500;padding:7px 18px;transition:all .2s}.type-filter-btn.active-all{background:#1a1f2e;border-color:#1a1f2e;color:#fff}.type-filter-btn.active-debit{background:#fef2f2;border-color:#ef4444;color:#ef4444}.type-filter-btn.active-credit{background:#f0fdf4;border-color:#10b981;color:#10b981}.filtered-total{border-radius:20px;font-size:13px;font-weight:600;margin-left:auto;padding:4px 12px}.filtered-total.positive{background:#f0fdf4;color:#10b981}.filtered-total.negative{background:#fef2f2;color:#ef4444}.filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.filter-btn{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:20px;color:#6b7280;cursor:pointer;font-size:13px;padding:6px 14px;transition:all .2s}.filter-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.empty-state{color:#9ca3af;padding:48px 20px;text-align:center}.empty-state p{font-size:15px;font-weight:500;margin-bottom:6px}.empty-state span{font-size:13px}.txn-items{display:flex;flex-direction:column;gap:10px}.txn-item{align-items:center;background:#f9fafb;border-left:4px solid #0000;border-radius:12px;display:flex;justify-content:space-between;padding:14px 16px;transition:background .2s}.txn-item.debit{border-left-color:#ef4444}.txn-item.credit{border-left-color:#10b981}.txn-item:hover{background:#f3f4f6}.txn-left{align-items:flex-start;display:flex;flex:1 1;gap:12px;min-width:0}.cat-dot{margin-top:5px}.txn-info{display:flex;flex-direction:column;gap:3px;min-width:0}.txn-title-row{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.txn-title{color:#1a1f2e;font-size:14px;font-weight:500}.recurring-badge{background:#eff6ff;border-radius:10px;color:#3b82f6;font-size:11px;font-weight:500;padding:2px 8px;white-space:nowrap}.txn-meta{color:#9ca3af;font-size:12px}.txn-notes{color:#6b7280;font-size:12px;font-style:italic;word-break:break-word}.txn-right{align-items:center;display:flex;flex-shrink:0;gap:10px}.txn-amount{font-size:15px;font-weight:700;white-space:nowrap}.txn-amount.debit{color:#ef4444}.txn-amount.credit{color:#10b981}.delete-btn{background:none;border:none;border-radius:6px;color:#d1d5db;cursor:pointer;font-size:14px;padding:4px 8px;transition:all .2s}.delete-btn:hover{background:#fee2e2;color:#ef4444}@media (max-width:768px){.txn-list-card{border-radius:12px;margin-top:16px;padding:16px}.txn-list-header{align-items:flex-start;flex-direction:column;gap:10px}.export-btn{text-align:center;width:100%}.type-filter-bar{gap:6px}.type-filter-btn{font-size:12px;padding:6px 12px}.filter-bar{gap:6px}.filter-btn{font-size:12px;padding:5px 10px}.txn-item{padding:10px 12px}.txn-amount{font-size:13px}}.account-filter-bar{margin-bottom:8px}.acc-filter-btn{align-items:center;display:flex;gap:4px}.txn-acc-badge{border-radius:10px;font-size:11px;font-weight:500;padding:2px 8px;white-space:nowrap}.budget-form-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000012;padding:24px;position:relative}.budget-form-title{color:#1a1f2e;font-size:18px;font-weight:600;margin-bottom:16px}.budget-form{margin-bottom:0}.budget-form-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:12px}.budget-form-row .form-group{flex:1 1;min-width:120px}.budget-submit-btn{background:#3b82f6;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;height:42px;padding:10px 20px;transition:background .2s;white-space:nowrap}.budget-submit-btn:hover{background:#2563eb}.current-budgets{margin-top:20px}.current-label{color:#9ca3af;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.budget-tags{display:flex;flex-wrap:wrap;gap:8px}.budget-tag{align-items:center;background:#f3f4f6;border-radius:20px;color:#374151;display:flex;font-size:13px;font-weight:500;gap:6px;padding:6px 10px 6px 14px}.budget-tag-text{line-height:1}.budget-tag-delete{align-items:center;background:none;border:none;cursor:pointer;display:flex;font-size:12px;line-height:1;opacity:.6;padding:0;transition:opacity .15s,transform .15s}.budget-tag-delete:hover{opacity:1;transform:scale(1.2)}.budget-total-bar{align-items:center;background:linear-gradient(135deg,#eff6ff,#f0fdf4);border:1px solid #dbeafe;border-radius:10px;display:flex;justify-content:space-between;margin-top:16px;padding:12px 16px}.budget-total-label{color:#374151;font-size:13px;font-weight:600}.budget-total-value{color:#1d4ed8;font-size:18px;font-weight:700}.budget-confirm-backdrop{align-items:center;background:#00000059;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.budget-confirm-box{background:#fff;border-radius:16px;box-shadow:0 20px 50px #00000026;max-width:360px;padding:24px;text-align:center;width:100%}.budget-confirm-msg{color:#374151;font-size:15px;line-height:1.6;margin-bottom:20px}.budget-confirm-actions{display:flex;gap:10px;justify-content:center}.budget-confirm-cancel{background:#f3f4f6;border:none;border-radius:10px;color:#374151;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:background .2s}.budget-confirm-cancel:hover{background:#e5e7eb}.budget-confirm-delete{background:#ef4444;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:background .2s}.budget-confirm-delete:hover{background:#dc2626}.budget-progress-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000012;margin-top:24px;padding:24px}.progress-header-row{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;margin-bottom:20px}.progress-title{color:#1a1f2e;font-size:18px;font-weight:600;margin:0}.progress-month-badge{background:#eff6ff;border:1px solid #dbeafe;border-radius:20px;color:#3b82f6;font-size:12px;font-weight:600;padding:4px 12px}.budget-summary-bar{background:#f9fafb;border:1px solid #f3f4f6;border-radius:12px;display:flex;flex-direction:column;gap:10px;margin-bottom:24px;padding:16px}.budget-summary-row{align-items:center;display:flex;flex-wrap:wrap;gap:6px;justify-content:space-between}.budget-summary-label{color:#6b7280;font-size:13px;font-weight:600}.budget-summary-spent{color:#1a1f2e;font-size:15px;font-weight:700}.budget-summary-spent.over{color:#ef4444}.budget-summary-of{color:#9ca3af;font-size:13px;font-weight:400}.budget-summary-footer{display:flex;font-size:12px;justify-content:space-between}.no-budget-msg{color:#9ca3af;padding:40px;text-align:center}.progress-list{gap:20px}.progress-item,.progress-list{display:flex;flex-direction:column}.progress-item{gap:8px}.progress-header{align-items:center;display:flex;justify-content:space-between}.cat-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.cat-name{color:#1a1f2e;font-size:14px;font-weight:500}.spent-amount{color:#1a1f2e;font-weight:600}.spent-amount.over{color:#ef4444}.limit-amount{color:#9ca3af}.progress-track{background:#f3f4f6;border-radius:10px;height:10px;overflow:hidden}.progress-fill{border-radius:10px;height:100%;transition:width .5s ease}.progress-footer{display:flex;font-size:12px;justify-content:space-between}.over-budget{color:#ef4444;font-weight:500}.under-budget{color:#10b981;font-weight:500}.percent-label{color:#9ca3af}.budget-month-note{border-top:1px solid #f3f4f6;color:#9ca3af;font-size:12px;margin-top:20px;padding-top:16px;text-align:center}.goal-form-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000012;margin-bottom:24px;padding:24px}.goal-form-title{color:#1a1f2e;font-size:18px;font-weight:600;margin-bottom:20px}.goal-form-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px}.gform-group{display:flex;flex:1 1;flex-direction:column;gap:6px;min-width:140px}.gform-group label{color:#6b7280;font-size:13px;font-weight:500}.gform-group input{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;color:#1a1f2e;font-size:14px;outline:none;padding:10px 14px}.gform-group input:focus{border-color:#3b82f6}.goal-submit-btn{background:#1a1f2e;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;height:42px;padding:10px 24px}.goal-submit-btn:hover{background:#3b82f6}.goals-empty{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000012;color:#9ca3af;padding:60px;text-align:center}.goals-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.goal-card{background:#fff;border:1.5px solid #0000;border-radius:16px;box-shadow:0 2px 12px #00000012;padding:20px}.goal-card.done{border-color:#10b981}.goal-card-header{align-items:center;display:flex;gap:8px;margin-bottom:12px}.goal-name{color:#1a1f2e;flex:1 1;font-size:15px;font-weight:600}.goal-badge{background:#d1fae5;border-radius:20px;color:#065f46;font-size:11px;font-weight:600;padding:3px 10px}.goal-delete{background:none;border:none;border-radius:6px;color:#d1d5db;cursor:pointer;font-size:13px;padding:4px 6px}.goal-delete:hover{background:#fee2e2;color:#ef4444}.goal-amounts{margin-bottom:10px}.goal-saved{color:#1a1f2e;font-size:22px;font-weight:700}.goal-target{color:#9ca3af;font-size:14px}.goal-track{background:#f3f4f6;border-radius:10px;height:10px;margin-bottom:8px;overflow:hidden}.goal-fill{border-radius:10px;height:100%;transition:width .5s}.goal-footer{display:flex;font-size:12px;justify-content:space-between;margin-bottom:14px}.goal-percent{color:#3b82f6;font-weight:500}.goal-remaining{color:#9ca3af}.add-savings-row{display:flex;gap:8px}.add-savings-row input{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:8px;flex:1 1;font-size:13px;outline:none;padding:8px 12px}.add-savings-row button{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px}@media (max-width:768px){.goal-form-card{padding:16px}.goal-form-row{flex-direction:column;gap:12px}.goal-submit-btn{width:100%}.goals-grid{grid-template-columns:1fr}}.empty-reports{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000012;color:#9ca3af;padding:60px;text-align:center}.report-summary{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:24px}.summary-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000012;display:flex;flex-direction:column;gap:6px;padding:20px 24px}.summary-label{color:#6b7280;font-size:13px;font-weight:500}.summary-value{color:#1a1f2e;font-size:28px;font-weight:700}.chart-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000012;margin-bottom:24px;padding:24px}.chart-title{color:#1a1f2e;font-size:17px;font-weight:600;margin-bottom:20px}@media (max-width:768px){.report-summary{gap:10px;grid-template-columns:1fr 1fr}.summary-value{font-size:20px}.chart-card{padding:16px}}.cat-form-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000012;margin-bottom:24px;padding:24px}.cat-form-title{color:#1a1f2e;font-size:18px;font-weight:600;margin-bottom:16px}.cat-input-row{display:flex;gap:12px}.cat-input{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;color:#1a1f2e;flex:1 1;font-size:14px;outline:none;padding:10px 14px}.cat-input:focus{border-color:#3b82f6}.cat-add-btn{background:#1a1f2e;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:background .2s}.cat-add-btn:hover{background:#3b82f6}.cat-error{color:#ef4444;font-size:13px;margin-top:8px}.cat-section{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000012;margin-bottom:20px;padding:24px}.cat-section-title{color:#1a1f2e;font-size:16px;font-weight:600;margin-bottom:16px}.cat-grid{display:flex;flex-wrap:wrap;gap:10px}.cat-chip{align-items:center;border-radius:20px;display:flex;gap:8px;padding:8px 14px}.cat-chip.default{background:#f3f4f6;border:1.5px solid #e5e7eb}.cat-chip.custom{background:#eff6ff;border:1.5px solid #bfdbfe}.cat-chip-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.cat-chip-name{color:#1a1f2e;font-size:14px;font-weight:500}.cat-chip-badge{background:#e5e7eb;border-radius:10px;color:#9ca3af;font-size:11px;padding:2px 8px}.cat-chip-delete{background:none;border:none;border-radius:4px;cursor:pointer;font-size:12px;line-height:1;opacity:.7;padding:2px 4px;transition:opacity .15s,transform .15s}.cat-chip-delete:hover{opacity:1;transform:scale(1.2)}.cat-confirm-backdrop{align-items:center;background:#00000059;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.cat-confirm-box{background:#fff;border-radius:16px;box-shadow:0 20px 50px #00000026;max-width:360px;padding:28px 24px 24px;text-align:center;width:100%}.cat-confirm-msg{color:#374151;font-size:15px;line-height:1.6;margin-bottom:6px}.cat-confirm-sub{color:#9ca3af;font-size:12px}.cat-confirm-actions{display:flex;gap:10px;justify-content:center;margin-top:20px}.cat-confirm-cancel{background:#f3f4f6;border:none;border-radius:10px;color:#374151;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:background .2s}.cat-confirm-cancel:hover{background:#e5e7eb}.cat-confirm-delete{background:#ef4444;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:background .2s}.cat-confirm-delete:hover{background:#dc2626}@media (max-width:768px){.cat-form-card{padding:16px}.cat-input-row{flex-direction:column}.cat-add-btn{width:100%}}.acc-page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.acc-page-header .page-heading{margin-bottom:0}.acc-add-btn{background:#3b82f6;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:background .2s}.acc-add-btn:hover{background:#2563eb}.acc-section{margin-bottom:32px}.acc-section-title{color:#6b7280;font-size:14px;font-weight:600;letter-spacing:.5px;margin-bottom:14px;text-transform:uppercase}.acc-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.acc-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000012;display:flex;flex-direction:column;gap:12px;padding:20px;transition:box-shadow .2s}.acc-card:hover{box-shadow:0 4px 20px #0000001c}.acc-card-header{justify-content:space-between}.acc-card-header,.acc-icon{align-items:center;display:flex}.acc-icon{border-radius:12px;font-size:22px;height:44px;justify-content:center;width:44px}.acc-type-badge{border-radius:99px;font-size:11px;font-weight:600;padding:3px 10px}.acc-type-badge.bank{background:#eff6ff;color:#3b82f6}.acc-type-badge.credit{background:#fdf2f8;color:#a855f7}.acc-card-actions{display:flex;gap:4px}.acc-action-btn{background:none;border:none;border-radius:6px;cursor:pointer;font-size:15px;opacity:1;padding:4px 6px;transition:background .2s,transform .15s}.acc-action-btn:hover{background:#f3f4f6;transform:scale(1.15)}.acc-action-delete:hover{background:#fef2f2}.acc-name{color:#1a1f2e;font-size:17px;font-weight:700;margin:0}.acc-balances{background:#f9fafb;border-radius:10px;display:flex;flex-direction:column;gap:8px;padding:12px 14px}.acc-balance-row{align-items:center;display:flex;justify-content:space-between}.acc-balance-label{color:#9ca3af;font-size:12px}.acc-balance-value{color:#1a1f2e;font-size:13px;font-weight:600}.acc-balance-none{color:#d1d5db;font-style:italic;font-weight:400}.acc-balance-current{font-size:15px}.acc-balance-current.positive{color:#10b981}.acc-balance-current.negative{color:#ef4444}.acc-utilization{display:flex;flex-direction:column;gap:5px;margin-top:4px}.acc-util-track{background:#e5e7eb;border-radius:99px;height:6px;overflow:hidden}.acc-util-fill{border-radius:99px;height:100%;transition:width .4s ease}.acc-util-label{font-size:11px;font-weight:600}.acc-empty{color:#6b7280;padding:80px 20px;text-align:center}.acc-empty-icon{font-size:56px;margin-bottom:16px}.acc-empty h2{color:#1a1f2e;font-size:20px;font-weight:700;margin-bottom:8px}.acc-empty p{font-size:14px;margin-bottom:24px;margin-left:auto;margin-right:auto;max-width:360px}.acc-modal-backdrop{align-items:center;background:#0006;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.acc-modal{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0003;max-height:90vh;max-width:480px;overflow-y:auto;width:100%}.acc-modal-header{align-items:center;display:flex;justify-content:space-between;padding:20px 24px 0}.acc-modal-header h2{color:#1a1f2e;font-size:18px;font-weight:700;margin:0}.acc-modal-close{background:none;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;font-size:16px;padding:4px 8px}.acc-modal-close:hover{background:#f3f4f6;color:#1a1f2e}.acc-modal-form{display:flex;flex-direction:column;gap:18px;padding:20px 24px}.acc-type-toggle{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.acc-type-btn{background:#f9fafb;border:2px solid #e5e7eb;border-radius:10px;color:#6b7280;cursor:pointer;font-size:13px;font-weight:600;padding:10px;transition:all .15s}.acc-type-btn:hover{background:#f3f4f6;border-color:#d1d5db}.acc-type-btn.active{background:#eff6ff;border-color:#3b82f6;color:#3b82f6}.acc-type-btn.active.credit-active{background:#faf5ff;border-color:#a855f7;color:#a855f7}.acc-form-group{display:flex;flex-direction:column;gap:6px}.acc-form-group label{color:#374151;font-size:13px;font-weight:600}.acc-form-group input[type=number],.acc-form-group input[type=text]{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;color:#1a1f2e;font-size:14px;outline:none;padding:10px 14px;transition:border-color .2s}.acc-form-group input:focus{background:#fff;border-color:#3b82f6}.acc-form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.acc-optional{color:#9ca3af;font-weight:400}.acc-form-error{color:#ef4444;font-size:12px;margin:0}.acc-form-hint{color:#9ca3af;font-size:12px;line-height:1.5;margin:0}.acc-color-grid,.acc-icon-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(4,1fr)}.acc-icon-btn{align-items:center;aspect-ratio:1;background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;font-size:18px;justify-content:center;transition:border-color .15s,background .15s}.acc-icon-btn:hover{background:#f3f4f6;border-color:#d1d5db}.acc-icon-btn.selected{background:#eff6ff;border-color:#3b82f6}.acc-color-btn{aspect-ratio:1;border:3px solid #0000;border-radius:8px;cursor:pointer;transition:border-color .15s,transform .15s}.acc-color-btn:hover{transform:scale(1.1)}.acc-color-btn.selected{border-color:#1a1f2e;transform:scale(1.1)}.acc-amount-input{align-items:center;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;display:flex;overflow:hidden;transition:border-color .2s}.acc-amount-input:focus-within{background:#fff;border-color:#3b82f6}.acc-currency{background:#f3f4f6;border-right:1px solid #e5e7eb;color:#6b7280;font-size:14px;font-weight:600;padding:10px 12px}.acc-amount-input input{background:#0000!important;border:none!important;border-radius:0!important;flex:1 1;outline:none;padding:10px 14px!important}.acc-modal-footer{display:flex;gap:10px;justify-content:flex-end;padding-top:4px}.acc-btn-cancel{background:#f3f4f6;border:none;border-radius:10px;color:#374151;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:background .2s}.acc-btn-cancel:hover{background:#e5e7eb}.acc-btn-save{border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;opacity:.92;padding:10px 24px;transition:opacity .2s}.acc-btn-save:hover{opacity:1}@media (max-width:768px){.acc-form-row,.acc-grid{grid-template-columns:1fr}.acc-modal{border-radius:16px}}.login-page{align-items:center;background:linear-gradient(135deg,#f0f4f8,#e8f0fe);display:flex;justify-content:center;min-height:100vh;padding:24px}.login-card{background:#fff;border-radius:24px;box-shadow:0 8px 40px #0000001f;max-width:420px;padding:40px 36px;text-align:center;width:100%}.login-logo{font-size:52px;margin-bottom:12px}.login-title{color:#1a1f2e;font-size:26px;font-weight:700;margin-bottom:10px}.login-subtitle{color:#6b7280;font-size:14px;line-height:1.7;margin-bottom:24px}.login-features{display:flex;flex-direction:column;gap:10px;margin-bottom:28px;text-align:left}.feature-item{align-items:center;background:#f9fafb;border-radius:10px;color:#374151;display:flex;font-size:13px;gap:10px;padding:8px 12px}.feature-item span:first-child{font-size:18px}.google-signin-btn{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #0000000f;color:#374151;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:12px;justify-content:center;margin-bottom:16px;padding:14px;transition:all .2s;width:100%}.google-signin-btn:hover{border-color:#3b82f6;box-shadow:0 4px 16px #3b82f626;transform:translateY(-1px)}.google-signin-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.google-icon{height:20px;width:20px}.login-loading{color:#6b7280;font-size:14px}.login-note{color:#9ca3af;font-size:12px;line-height:1.6}.login-footer{color:#888;font-size:14px;margin-top:20px;text-align:center}@media (max-width:480px){.login-card{padding:28px 20px}.login-title{font-size:22px}}
/*# sourceMappingURL=main.ae9eef7c.css.map*/