:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;width:100%;min-width:320px;min-height:100vh}#root{width:100%}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-container{display:flex!important;justify-content:center!important;align-items:center!important;width:100vw!important;height:100vh!important;position:fixed!important;top:0!important;left:0!important;background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.login-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;padding:40px;width:90%;max-width:450px;height:100vh;display:flex;flex-direction:column;justify-content:center;margin:0 auto}.login-title{margin:0 0 48px!important;font-size:32px;font-weight:700;color:#667eea;text-align:center}.login-form{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:24px}.form-group{display:flex;flex-direction:column;gap:10px}.form-group label{font-size:15px;font-weight:600;color:#1f2937;letter-spacing:.3px}.form-group input{width:100%;padding:16px 18px;height:48px;border:2px solid #e5e7eb;border-radius:8px;font-size:15px;font-family:inherit;transition:all .3s ease;background-color:#fafbfc;color:#1f2937;-webkit-appearance:none;-moz-appearance:none;appearance:none;box-sizing:border-box}.form-group input::placeholder{color:#9ca3af;font-weight:400}.form-group input:hover{border-color:#d1d5db;background-color:#f9fafb}.form-group input:focus{outline:none;border-color:#667eea;background-color:#fff;box-shadow:0 0 0 4px #667eea26,0 0 0 2px #667eea4d}.form-group input:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.6}#username,#password{width:50%!important;margin-left:auto!important;margin-right:auto!important;display:block!important}.form-group input:-webkit-autofill,.form-group input:-webkit-autofill:hover,.form-group input:-webkit-autofill:focus,.form-group input:-webkit-autofill:active,.form-group input:-webkit-autofill:disabled{-webkit-box-shadow:0 0 0 30px white inset!important;-webkit-text-fill-color:#333!important;border:1px solid #ddd!important;border-radius:6px!important;font-size:14px!important;padding:12px!important}.form-group input:-webkit-autofill{-webkit-transition:background-color 5000s ease-in-out 0s;transition:background-color 5000s ease-in-out 0s}.error-message{padding:12px;background-color:#fee;color:#c33;border-radius:6px;font-size:14px;border:1px solid #fcc}.login-button{width:50%!important;margin-left:auto!important;margin-right:auto!important;display:block!important;padding:16px!important;background:linear-gradient(135deg,#667eea,#764ba2)!important;color:#fff!important;border:none!important;border-radius:8px!important;font-size:16px!important;font-weight:600!important;cursor:pointer!important;transition:all .3s ease!important;margin-top:8px!important;box-shadow:0 4px 12px #667eea4d!important}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #667eea66}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:32px;margin-bottom:24px;text-align:center;font-size:14px;color:#666}.login-footer p{margin:0}.toggle-button{background:none;border:none;color:#667eea;cursor:pointer;font-weight:600;text-decoration:none;transition:color .2s;font-size:14px}.toggle-button:hover:not(:disabled){color:#764ba2}.toggle-button:disabled{opacity:.7;cursor:not-allowed}.divider{display:flex;align-items:center;margin:32px 0;color:#999;font-size:14px;width:100%}.divider:before{content:"";flex:1;height:1px;background-color:#ddd;margin-right:12px}.divider:after{content:"";flex:1;height:1px;background-color:#ddd;margin-left:12px}.google-button-wrapper{width:100%;display:flex;justify-content:center;margin-top:16px;margin-bottom:24px}.google-login-button{display:flex!important;align-items:center!important;justify-content:center!important;gap:10px!important;width:50%!important;padding:12px!important;background-color:#fff!important;border:1px solid #ddd!important;border-radius:6px!important;font-size:14px!important;font-weight:500!important;color:#333!important;text-decoration:none!important;text-align:center!important;cursor:pointer!important;transition:all .2s!important}.google-login-button:hover{background-color:#f8f8f8;border-color:#bbb}.google-login-button:active{background-color:#f0f0f0}@media(max-width:480px){.login-card{padding:24px}.login-title{font-size:28px}.login-subtitle{margin-bottom:24px}}.transaction-form-container{background-color:#fff;border-bottom:1px solid #e5e7eb;padding:10px;width:100%;box-sizing:border-box}.transaction-form{display:flex!important;flex-wrap:wrap!important;flex-direction:row!important;align-items:flex-end!important;gap:4px!important;width:100%!important;box-sizing:border-box!important}.transaction-form-container .transaction-form .form-group{display:flex!important;flex-direction:column!important;gap:2px!important;margin:0!important;padding:0!important;flex:0 0 calc(25% - 4px)!important;min-width:0!important;width:calc(25% - 4px)!important}.submit-btn{flex:0 0 calc(25% - 4px)!important;height:34px!important;background-color:#10b981!important;color:#fff!important;border:none!important;border-radius:4px!important;font-size:.85rem!important;font-weight:600!important;cursor:pointer!important;white-space:nowrap!important;transition:background-color .2s!important;padding:0 4px!important}@media(min-width:1024px){.transaction-form{flex-wrap:nowrap}.transaction-form-container .transaction-form .form-group{flex:1!important;min-width:0!important}.transaction-form-container .transaction-form .form-group:nth-child(6){flex:1!important}.submit-btn{flex:0 0 auto!important;width:auto!important;padding:0 20px}}.form-group label{font-size:.7rem;font-weight:600;color:#4b5563;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.transaction-form input[type=date],.transaction-form input[type=number],.transaction-form input[type=text],.transaction-form select{width:100%!important;height:34px!important;padding:0 4px!important;border:1px solid #d1d5db!important;border-radius:4px!important;font-size:.8rem!important;background-color:#fff!important;color:#1f2937!important;box-sizing:border-box!important}*{margin:0!important;padding:0!important;box-sizing:border-box}html{margin:0!important;padding:4px!important;width:100%;height:100%;overflow:hidden;box-sizing:border-box}body{margin:0!important;padding:0;width:100%;height:100%;overflow:hidden;border:0}#root{width:100%;height:100%;margin:0!important;padding:0;display:flex;overflow:hidden}.layout{display:flex;height:100%;width:calc(100% - 8px);background-color:#f9fafb;margin:0 4px!important;padding:0;overflow:hidden;position:relative}.sidebar{background-color:#2563eb;color:#fff;display:flex;flex-direction:column;border-right:1px solid #1e40af;transition:transform .3s ease;overflow-y:auto;position:fixed;left:0;top:0;height:100%;width:200px;z-index:40}.sidebar.open{transform:translate(0)}.sidebar.closed{transform:translate(-200px)}.sidebar-header{height:64px;display:flex;align-items:center;justify-content:center;padding:0 .5rem;border-bottom:1px solid #1e40af;flex-shrink:0;margin:0;position:relative}.sidebar-header h1{font-size:1.25rem;font-weight:700;text-align:center;flex:1}.sidebar-header .toggle-btn{position:absolute;right:.5rem}.toggle-btn{background:none;border:none;color:#fff;cursor:pointer;padding:.25rem;font-size:1.25rem;transition:background-color .2s;border-radius:.375rem}.toggle-btn:hover{background-color:#ffffff1a}.sidebar-nav{flex:1;padding:.5rem 0;space-y:.5rem;display:flex;flex-direction:column;gap:0}.nav-link{display:flex;align-items:center;gap:1rem;padding:.5rem .75rem;color:#fff;text-decoration:none;border-radius:0;transition:background-color .2s;font-size:.95rem;margin:0}.nav-link:hover,.nav-link.active{background-color:#1e40af}.nav-link .icon{font-size:1.25rem;min-width:1.5rem}.sidebar.closed .nav-link{padding:.5rem;justify-content:center}.sidebar-groups{border-top:1px solid #1e40af;padding:1rem .5rem;flex-shrink:0}.groups-label{font-size:.75rem;font-weight:600;color:#bfdbfe;padding:.5rem 1rem;margin-bottom:.5rem}.groups-list{display:flex;flex-direction:column;gap:.5rem;max-height:160px;overflow-y:auto;margin-bottom:.75rem}.group-item{display:flex;align-items:center;gap:.25rem;width:100%}.invite-btn{flex:1;background-color:#3b82f6;border:none;color:#fff;cursor:pointer;padding:.5rem .75rem;border-radius:.375rem;font-size:.875rem;font-weight:500;transition:background-color .2s;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.invite-btn:hover{background-color:#2563eb}.create-group-btn{width:100%;padding:.5rem .75rem;background-color:#10b981;border:none;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;border-radius:.375rem;transition:background-color .2s}.create-group-btn:hover{background-color:#059669}.sidebar-subcategories{border-top:1px solid #1e40af;padding:1rem .5rem;flex:1;overflow-y:auto;display:flex;flex-direction:column}.subcategories-label{font-size:.75rem;font-weight:600;color:#bfdbfe;padding:.5rem 1rem;margin-bottom:.5rem}.main-categories-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.main-cat-btn{text-align:left;padding:.5rem .75rem;background:none;border:none;color:#fff;font-size:.875rem;cursor:pointer;border-radius:.375rem;transition:background-color .2s;font-weight:500}.main-cat-btn:hover{background-color:#1e40af}.main-cat-btn.active{background-color:#3b82f6;font-weight:600}.sub-categories-section{display:flex;flex-direction:column;gap:.75rem;flex:1;min-height:0}.sub-cat-header{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.sub-cat-header h4{margin:0;font-size:.875rem;font-weight:600;color:#bfdbfe;text-transform:uppercase;letter-spacing:.5px}.add-sub-cat-btn{background-color:#10b981;border:none;color:#fff;cursor:pointer;padding:.25rem .5rem;border-radius:.375rem;font-size:.875rem;font-weight:600;transition:background-color .2s}.add-sub-cat-btn:hover{background-color:#059669}.sub-categories-list{display:flex;flex-direction:column;gap:.5rem;overflow-y:auto;flex:1}.sub-cat-item{display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding:.5rem;background-color:#ffffff1a;border-radius:.375rem;transition:background-color .2s}.sub-cat-item:hover{background-color:#ffffff26}.sub-cat-name{font-size:.875rem;color:#fff;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.edit-btn,.delete-btn{background:none;border:none;color:#fff;cursor:pointer;font-size:.75rem;padding:.25rem;transition:opacity .2s}.edit-btn:hover,.delete-btn:hover{opacity:.7}.no-subcategories{font-size:.875rem;color:#9ca3af;text-align:center;padding:1rem .5rem;margin:0}.sidebar-footer{border-top:1px solid #1e40af;padding:1rem .5rem;flex-shrink:0}.logout-btn{width:100%;padding:.5rem .75rem;background-color:#ef4444;border:none;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;border-radius:.375rem;transition:background-color .2s}.logout-btn:hover{background-color:#dc2626}.main-content{flex:1;display:flex;flex-direction:column;align-items:center;overflow-y:auto;overflow-x:hidden;width:100%;min-height:0;margin:0!important}.page-header{background:linear-gradient(135deg,#f4a460,#daa520);border-bottom:2px solid #CD853F;display:flex;flex-direction:column;gap:1rem;padding:1.25rem 2rem;flex-shrink:0;width:100%;max-width:1400px;box-sizing:border-box}.page-header-nav{display:flex;align-items:center;justify-content:center;gap:.75rem;flex-wrap:wrap;width:100%}.page-nav-link{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;color:#475569;text-decoration:none;border-radius:.5rem;transition:all .3s ease;font-size:.95rem;font-weight:500;white-space:nowrap;border:1.5px solid transparent}.page-nav-link:hover{background-color:#e0e7ff;color:#2563eb;transform:translateY(-1px)}.page-nav-link.active{background-color:#2563eb;color:#fff;border-color:#1d4ed8;box-shadow:0 2px 8px #2563eb33}.page-nav-link .icon{font-size:1.25rem;display:flex;align-items:center;justify-content:center;min-width:1.5rem}.page-nav-link span:last-child{text-align:center}.page-title{font-size:1.75rem;font-weight:700;color:#1e293b;margin:0;display:flex;align-items:center;height:2.25rem;border-left:4px solid #2563eb;padding-left:1rem}.expand-btn{background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;color:#fff;cursor:pointer;width:3rem;height:3rem;padding:0;font-size:1.5rem;transition:all .3s ease;border-radius:50%;flex-shrink:0;box-shadow:0 2px 8px #2563eb4d;display:flex;align-items:center;justify-content:center}.expand-btn:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);box-shadow:0 4px 12px #2563eb66;transform:scale(1.1)}.expand-btn:active{transform:scale(.95)}.page-header h2{font-size:0;font-weight:700;color:#1f2937;display:none}.current-group{text-align:right}.group-label{font-size:.75rem;color:#6b7280;margin-bottom:.25rem}.current-group .group-name{font-size:1.125rem;font-weight:600;color:#2563eb;background:none;border:none;padding:0;cursor:default}.page-content{flex:1;overflow:visible;padding:2rem 0;width:100%;max-width:1400px;box-sizing:border-box;display:flex;flex-direction:column}.page-footer{width:100%;height:200px;background-color:#1f2937;border-top:1px solid #374151;padding:1rem 2rem;text-align:center;color:#9ca3af;font-size:.875rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.page-footer p{margin:0}@media(max-width:768px){.page-footer{height:auto;flex-shrink:1;padding:1.5rem 1rem}.page-content{padding:1rem 0;margin:0;overflow:auto}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background-color:#fff;border-radius:.5rem;box-shadow:0 10px 25px #0000001a;padding:1.5rem;width:100%;max-width:384px}.modal h3{font-size:1.125rem;font-weight:700;color:#1f2937;margin-bottom:1rem}.form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column}.form-group label{font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.25rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-info{background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:.375rem;padding:.75rem}.form-info p{font-size:.875rem;color:#1f2937}.btn{padding:.5rem 1rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-primary{background-color:#2563eb;color:#fff}.btn-primary:hover:not(:disabled){background-color:#1d4ed8}.btn-primary:disabled{background-color:#9ca3af;cursor:not-allowed}.btn-secondary{background-color:#e5e7eb;color:#374151}.btn-secondary:hover{background-color:#d1d5db}.sidebar::-webkit-scrollbar,.groups-list::-webkit-scrollbar,.page-content::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track,.groups-list::-webkit-scrollbar-track,.page-content::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb,.groups-list::-webkit-scrollbar-thumb,.page-content::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}.page-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover,.groups-list::-webkit-scrollbar-thumb:hover,.page-content::-webkit-scrollbar-thumb:hover{background:#ffffff80}.page-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}.dashboard-container{min-height:100vh;background:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.dashboard-header{display:flex;justify-content:space-between;align-items:center;padding:20px 40px;background:#fff;border-bottom:1px solid #eee;box-shadow:0 2px 8px #0000000d}.header-left{display:flex;align-items:center;gap:16px}.back-button{padding:8px 12px;background:none;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:20px;transition:all .2s}.back-button:hover{background:#f5f5f5;border-color:#667eea;color:#667eea}.dashboard-header h1{margin:0;font-size:28px;font-weight:600;color:#333}.logout-button{padding:8px 16px;background:#e0e0e0;color:#333;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.logout-button:hover{background:#d0d0d0}.dashboard-content{max-width:1200px;margin:0 auto;padding:40px 20px}.month-selector{display:flex;justify-content:center;align-items:center;gap:2rem;margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:.5rem;border-bottom:2px solid #e5e7eb}.dashboard{padding:0 1.5rem}.dashboard-title{text-align:center;font-size:1.875rem;font-weight:600;color:#1f2937;margin:0 0 1.5rem}.loading{text-align:center;padding:40px;color:#999;font-size:16px}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.card{padding:.75rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;background:#fff;border-left:4px solid #ddd}.card-label{margin:0;font-size:.65rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.card-amount{margin:0;font-size:1rem;font-weight:700;color:#1f2937}.card.income{border-left-color:#10b981}.card.income .card-amount{color:#10b981}.card.expense{border-left-color:#ef4444}.card.expense .card-amount{color:#ef4444}.card.balance{border-left-color:#2563eb}.card.balance.positive .card-amount{color:#10b981}.card.balance.negative .card-amount{color:#ef4444}.card.credit-card{border-left-color:#f97316}.card.credit-card.neutral .card-amount{color:#6b7280}.card.credit-card.warning .card-amount{color:#f97316}.card.debit-card{border-left-color:#3b82f6}.card.debit-card.positive .card-amount{color:#10b981}.card.debit-card.negative .card-amount{color:#ef4444}.card.transfer{border-left-color:#3b82f6}.card.transfer .card-amount{color:#3b82f6}.card.loan{border-left-color:#ca8a04}.card.loan .card-amount{color:#ca8a04}.card.asset{border-left-color:#7c3aed}.card.asset .card-amount{color:#7c3aed}.transactions-section{background:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;width:100%}.transactions-section h3{margin:0;font-size:1.25rem;font-weight:600;color:#1f2937}.transactions-header h3{margin:0}.clear-filters-btn{padding:.5rem 1rem;background:#ef4444;color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s}.transaction-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.add-transaction-button{padding:10px 16px;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.add-transaction-button:hover{background:#764ba2}.transaction-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;padding:20px;background:#f9f9f9;border-radius:8px;margin-bottom:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:#333}.form-group input,.form-group select{padding:10px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled,.form-group select:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{grid-column:1 / -1;padding:12px;background-color:#fee;color:#c33;border-radius:6px;font-size:14px;border:1px solid #fcc}.submit-button{grid-column:1 / -1;padding:10px;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:all .2s}.submit-button:hover:not(:disabled){background:#764ba2}.submit-button:disabled{opacity:.7;cursor:not-allowed}.no-transactions{text-align:center;color:#999;padding:40px;margin:0}.transactions-list{display:flex;flex-direction:column;gap:1rem;width:100%}.transaction-row:hover{background:#f0f0f0;box-shadow:0 2px 8px #0000000d}.transaction-row.income{border-left-color:#10b981}.transaction-row.expense{border-left-color:#ef4444}.transaction-row.transfer{border-left-color:#3b82f6}.transaction-cell{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.transaction-date{font-size:.875rem;font-weight:500;color:#6b7280}.transaction-type-badge{font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:.25rem;text-transform:uppercase;letter-spacing:.5px;text-align:center}.transaction-type-badge.income{background-color:#d1fae5;color:#059669}.transaction-type-badge.expense{background-color:#fee2e2;color:#991b1b}.transaction-type-badge.transfer{background-color:#dbeafe;color:#0c4a6e}.transaction-type-badge.loan{background-color:#fef08a;color:#92400e}.transaction-type-badge.asset{background-color:#ddd6fe;color:#5b21b6}.transaction-main-category{font-size:.95rem;font-weight:600;color:#1f2937;background:#e5e7eb;padding:.25rem .5rem;border-radius:.25rem}.transaction-sub-category{font-size:.8rem;font-weight:600;color:#1f2937;background:#dbeafe;padding:.25rem .5rem;border-radius:.25rem}.transaction-description-cell{font-size:.875rem;color:#6b7280}.transaction-payment-cell{font-size:.85rem;color:#2563eb;font-weight:500}.transaction-amount{font-size:1rem;font-weight:700;text-align:right}.transaction-amount.income{color:#10b981}.transaction-amount.expense{color:#ef4444}.transaction-amount.transfer{color:#3b82f6}.transaction-amount.loan{color:#ca8a04}.transaction-amount.asset{color:#7c3aed}.transaction-actions{display:flex;justify-content:center;align-items:center;gap:.5rem}.action-btn{background:none;border:none;cursor:pointer;font-size:1rem;padding:.25rem;opacity:.6;transition:opacity .2s}.action-btn:hover,.delete-btn:hover{opacity:1}@media(max-width:1200px){.transaction-row{grid-template-columns:minmax(70px,1fr) minmax(60px,1fr) minmax(75px,1.1fr) minmax(80px,1.2fr) minmax(70px,1fr) minmax(120px,1.8fr) minmax(60px,1fr) minmax(50px,.9fr);gap:.5rem;padding:.5rem}.transaction-cell{font-size:.85rem}.transaction-type-badge{padding:.2rem .4rem;font-size:.7rem}}@media(max-width:768px){.transaction-row{grid-template-columns:minmax(50px,50px) minmax(60px,60px) minmax(80px,.7fr) .6fr minmax(70px,70px) minmax(70px,70px) minmax(35px,35px);gap:.5rem;padding:.5rem .6rem}.transaction-cell{font-size:.75rem;white-space:nowrap}.transaction-date{font-size:.75rem}.transaction-type-badge{padding:.15rem .3rem;font-size:.65rem}.transaction-main-category{font-size:.8rem}.transaction-description-cell,.transaction-payment-cell{font-size:.75rem}.transaction-amount{font-size:.9rem}}@media(max-width:768px){.dashboard-header{padding:16px 20px;flex-direction:column;gap:12px;text-align:center}.header-left{width:100%;justify-content:center}.dashboard-header h1{font-size:24px}.month-selector{flex-wrap:wrap;gap:.75rem;padding:1rem}.month-selector h3{flex-basis:100%;order:-1;margin:0 0 .5rem}.month-selector .month-btn{flex:1 1 calc(50% - .375rem);padding:.875rem 1.25rem;min-width:calc(50% - .375rem)}.summary-cards{display:flex;flex-wrap:wrap;gap:.75rem}.card{flex:0 1 calc(50% - .375rem);min-width:120px}.transaction-form{grid-template-columns:1fr}.submit-button{grid-column:1}.transactions-section{overflow-x:auto!important;-webkit-overflow-scrolling:touch;padding:0!important}.transactions-list{display:flex!important;flex-direction:column!important;gap:.5rem;width:max-content;min-width:100%}.transaction-row{display:grid!important;grid-template-columns:50px 50px 65px 65px 55px 90px 50px 40px;gap:.3rem;padding:.5rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;align-items:center;flex-shrink:0;white-space:nowrap;width:fit-content;min-width:fit-content}.transaction-cell{font-size:.65rem;white-space:nowrap!important;overflow:hidden;text-overflow:ellipsis}.transaction-type-badge{padding:.1rem .2rem;font-size:.55rem}.transaction-main-category,.transaction-sub-category{font-size:.65rem;padding:.1rem .2rem}.transaction-description-cell{font-size:.65rem}.transaction-amount{font-size:.7rem}}.transactions-page{display:flex;flex-direction:column;gap:2rem;padding:2rem;margin:0;width:100%}.transactions-title{font-size:1.875rem;font-weight:600;color:#000;text-align:center;margin:0 0 1.5rem}.transactions-form-section{background:#fff;padding:2rem;border-radius:0;box-shadow:none;width:100%}.transactions-form-section h3{margin:0 0 1.5rem;font-size:1.25rem;font-weight:600;color:#1f2937}.transactions-list-section{background:#fff;padding:2rem;border-radius:0;box-shadow:none;width:100%}.transactions-list-section h3{margin:0 0 1.5rem;font-size:1.25rem;font-weight:600;color:#1f2937}.transactions-list{display:flex;flex-direction:column;gap:.5rem;width:100%}.transaction-row{display:grid;grid-template-columns:minmax(80px,1fr) minmax(70px,1fr) minmax(90px,1.2fr) minmax(100px,1.3fr) minmax(80px,1fr) minmax(150px,2.2fr) minmax(70px,1.1fr) minmax(60px,1fr);gap:.75rem;padding:.75rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;transition:all .2s;align-items:center;width:100%}.transaction-row:hover{background-color:#f3f4f6;border-color:#d1d5db}.transaction-row.editing{background-color:#eff6ff;border-color:#2563eb}.col{display:flex;align-items:center;font-size:.8rem;color:#1f2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-date{font-weight:600;color:#6b7280;flex-shrink:0}.col-date input{width:100%;padding:.3rem;font-size:.75rem;border:1px solid #2563eb;border-radius:.25rem;background:#fff}.col-type{font-size:.75rem;background:#f0f0f0;padding:.25rem .5rem;border-radius:.25rem;text-align:center;flex-shrink:0}.col-main-cat{background:#e5e7eb;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;flex-shrink:0}.col-sub-cat{background:#dbeafe;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;flex-shrink:0}.col-card{background:#f3e8ff;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;flex-shrink:0}.col-desc{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-desc input{width:100%;padding:.3rem;font-size:.8rem;border:1px solid #2563eb;border-radius:.25rem;background:#fff}.col-amount{font-weight:700;color:#ef4444;text-align:right;justify-content:flex-end;flex-shrink:0}.col-amount input{width:100%;padding:.3rem;font-size:.8rem;font-weight:700;border:1px solid #2563eb;border-radius:.25rem;background:#fff;text-align:right}.col-actions{display:flex;gap:.25rem;justify-content:center;flex-shrink:0}.btn{padding:.4rem .6rem;border:none;border-radius:.375rem;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-edit,.btn-delete{padding:.4rem;font-size:.9rem;width:28px;height:28px;min-width:28px}.btn-edit{background-color:#2563eb;color:#fff}.btn-edit:hover{background-color:#1d4ed8}.btn-delete{background-color:#ef4444;color:#fff}.btn-delete:hover:not(:disabled){background-color:#dc2626}.btn-delete:disabled{background-color:#fecaca;cursor:not-allowed}.btn-save{background-color:#10b981;color:#fff;padding:.4rem;width:28px;height:28px;min-width:28px}.btn-save:hover:not(:disabled){background-color:#059669}.btn-save:disabled{background-color:#a7f3d0;cursor:not-allowed}.btn-cancel{background-color:#6b7280;color:#fff;padding:.4rem;width:28px;height:28px;min-width:28px}.btn-cancel:hover:not(:disabled){background-color:#4b5563}.btn-cancel:disabled{background-color:#d1d5db;cursor:not-allowed}.edit-input,.edit-select{padding:.4rem;border:1px solid #2563eb;border-radius:.25rem;font-size:.75rem;background:#fff;width:100%;color:#1f2937}.edit-input:focus,.edit-select:focus{outline:none;box-shadow:0 0 0 2px #2563eb33}.edit-select{cursor:pointer}.empty-state{padding:3rem 2rem;text-align:center;color:#6b7280}.empty-state p{font-size:1rem;margin:0}@media(max-width:1200px){.transaction-row{grid-template-columns:minmax(70px,1fr) minmax(60px,1fr) minmax(75px,1.1fr) minmax(80px,1.2fr) minmax(70px,1fr) minmax(120px,1.8fr) minmax(60px,1fr) minmax(50px,.9fr);gap:.5rem;padding:.5rem}}@media(max-width:768px){.transactions-page{padding:.75rem;margin:0!important;gap:.75rem}.month-selector{flex-wrap:wrap;gap:.75rem;padding:1rem}.month-selector h3{flex-basis:100%;order:-1;margin:0 0 .5rem}.month-selector .month-btn{flex:1 1 calc(50% - .375rem);padding:.875rem 1.25rem;min-width:calc(50% - .375rem)}.transactions-form-section,.transactions-list-section{padding:.75rem;margin:0!important;border-radius:0;box-shadow:none}.transaction-row{display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem;margin:0;width:100%;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;align-items:center}.col{padding:0;border-bottom:none;display:flex;align-items:center;font-size:.75rem;color:#1f2937;flex:0 1 auto;min-width:fit-content}.col:before{content:none}.col-date{flex:0 1 70px}.col-date:before{content:none}.col-type{flex:0 1 60px}.col-type:before{content:none}.col-main-cat{flex:0 1 70px}.col-main-cat:before{content:none}.col-sub-cat{flex:0 1 70px}.col-sub-cat:before{content:none}.col-card{flex:0 1 60px}.col-card:before{content:none}.col-desc{flex:1 1 150px;min-width:0}.col-desc:before{content:none}.col-amount{flex:0 1 60px;text-align:right;justify-content:flex-end}.col-amount:before{content:none}.col-actions{display:flex;flex:0 1 auto;grid-column:auto;justify-content:center;align-items:center;padding:0;border:none;gap:.25rem}.col-actions:before{content:none}.col-actions .btn{padding:.3rem;width:24px;height:24px;min-width:24px;font-size:.8rem}.col-date input,.col-desc input,.col-amount input{width:100%}.transactions-list{max-height:none}}.transaction-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem;padding:1.5rem;background:#fff;border-bottom:1px solid #e5e7eb;border-radius:0}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.875rem;font-weight:500;color:#374151}.filter-group input,.filter-group select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;transition:border-color .2s}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.clear-filters-btn{padding:.5rem 1rem;background:#ef4444;color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s;align-self:flex-end}.clear-filters-btn:hover{background:#dc2626}.transactions-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-top:1.5rem;padding:1.5rem;background-color:#f9fafb;border-top:2px solid #e5e7eb;border-radius:0}.summary-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#fff;border-left:4px solid #ddd;border-radius:.375rem}.summary-item.income{border-left-color:#10b981}.summary-item.expense{border-left-color:#ef4444}.summary-item.balance.positive{border-left-color:#10b981}.summary-item.balance.negative{border-left-color:#ef4444}.summary-label{font-size:.75rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.summary-amount{font-size:1.25rem;font-weight:700;color:#1f2937}.summary-item.income .summary-amount{color:#10b981}.summary-item.expense .summary-amount{color:#ef4444}.summary-item.balance.positive .summary-amount{color:#10b981}.summary-item.balance.negative .summary-amount{color:#ef4444}.categories-container{display:flex;flex-direction:column;gap:1.5rem}.categories-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.categories-header h3{font-size:1.5rem;font-weight:700;color:#1f2937}.form-title{margin:0 0 1rem;font-size:1rem;font-weight:600;color:#1f2937}.form-group input[type=color]{padding:.25rem;height:2.5rem;cursor:pointer}.categories-tabs{display:flex;gap:.5rem;border-bottom:1px solid #e5e7eb;margin-bottom:1rem}.tab{padding:.75rem 1rem;background:none;border:none;border-bottom:2px solid transparent;color:#6b7280;font-weight:500;cursor:pointer;transition:all .2s}.tab:hover{color:#1f2937}.tab.active{color:#2563eb;border-bottom-color:#2563eb}.categories-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.category-item{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;transition:all .2s;display:flex;align-items:center;gap:1rem;cursor:pointer}.category-item:hover{border-color:#2563eb;box-shadow:0 4px 6px #0000001a}.category-item.active{border-color:#2563eb;background-color:#f0f9ff}.category-actions{display:flex;align-items:center;gap:.5rem;margin-left:auto}.expand-icon{font-size:.75rem;color:#6b7280}.edit-main-btn,.delete-main-btn{background:none;border:none;color:#6b7280;cursor:pointer;font-size:.875rem;padding:.25rem;transition:opacity .2s;display:flex;align-items:center;justify-content:center}.edit-main-btn:hover{opacity:.7;color:#2563eb}.delete-main-btn:hover{opacity:.7;color:#ef4444}.category-color-indicator{width:40px;height:40px;border-radius:.375rem;flex-shrink:0}.category-info{flex:1}.category-info h4{font-size:1rem;font-weight:600;color:#1f2937;margin:0 0 .25rem}.category-details{display:flex;align-items:center;gap:.75rem;margin-top:.25rem}.category-type{font-size:.875rem;color:#6b7280;text-transform:capitalize;margin:0}.category-balance{font-size:.875rem;color:#2563eb;font-weight:600;margin:0;white-space:nowrap}.no-categories{text-align:center;color:#6b7280;padding:2rem;background-color:#fff;border-radius:.5rem;border:1px solid #e5e7eb}.sub-categories-container{background-color:#f9fafb;padding:1rem;border-radius:.375rem;margin-top:.5rem;border-left:3px solid #2563eb}.sub-categories-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.sub-categories-header h5{font-size:.875rem;font-weight:600;color:#1f2937;margin:0;text-transform:uppercase;letter-spacing:.5px}.add-sub-btn{padding:.25rem .5rem;background-color:#10b981;color:#fff;border:none;border-radius:.375rem;font-size:.75rem;font-weight:600;cursor:pointer;transition:background-color .2s}.add-sub-btn:hover{background-color:#059669}.sub-category-form{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.sub-category-form input{flex:1;min-width:200px;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem}.sub-category-form input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.sub-category-form .form-buttons{display:flex;gap:.5rem}.sub-categories-list{display:flex;flex-direction:column;gap:.5rem}.sub-category-item{display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding:.75rem;background-color:#fff;border-radius:.375rem;border:1px solid #e5e7eb;transition:all .2s}.sub-category-item:hover{background-color:#f0f9ff;border-color:#2563eb}.sub-cat-name{font-size:.875rem;color:#1f2937;flex:1}.sub-cat-actions{display:flex;gap:.25rem}.edit-btn,.delete-btn{background:none;border:none;color:#6b7280;cursor:pointer;font-size:.875rem;padding:.25rem;transition:opacity .2s}.edit-btn:hover,.delete-btn:hover{opacity:.7;color:#1f2937}.no-sub-categories{text-align:center;color:#9ca3af;font-size:.875rem;padding:1rem;margin:0}.payment-cards-container{display:flex;flex-direction:column;gap:1.5rem}.cards-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.cards-header h3{font-size:1.5rem;font-weight:700;color:#1f2937}.form-row{display:flex;gap:1rem;flex-wrap:wrap}.form-buttons{display:flex;gap:.75rem;justify-content:flex-end}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.card-item{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-radius:.5rem;padding:1rem;color:#0c4a6e;box-shadow:0 2px 4px #0000000d;border:1px solid #7dd3fc;transition:all .2s;display:flex;flex-direction:column;gap:.75rem;min-height:auto}.card-item:hover{transform:translateY(-4px);box-shadow:0 8px 12px #00000026}.card-visual{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.card-name-top{font-size:1rem;font-weight:600;color:#0c4a6e;flex:1}.card-actions{display:flex;gap:.5rem}.card-type{font-size:1.5rem;margin-top:.5rem}.edit-card-btn,.delete-card-btn{background:none;border:none;cursor:pointer;font-size:1rem;padding:.25rem;opacity:.8;transition:opacity .2s}.edit-card-btn:hover,.delete-card-btn:hover{opacity:1}.card-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.card-info h4{font-size:.9rem;font-weight:600;margin:0 0 .15rem}.card-issuer{font-size:.8rem;opacity:.8;margin:0 0 .1rem}.card-balance{font-size:.95rem;font-weight:600;margin:.1rem 0}.card-limit{font-size:.8rem;opacity:.8;margin:.1rem 0}.card-type-label{font-size:.7rem;opacity:.7;text-transform:capitalize;margin:.1rem 0 0}.no-cards{text-align:center;color:#6b7280;padding:2rem;background-color:#fff;border-radius:.5rem;border:1px solid #e5e7eb;grid-column:1 / -1}.section{display:flex;flex-direction:column;gap:1.25rem;margin-top:1.5rem;padding:0}.section-header{display:flex;align-items:center;margin-bottom:.5rem;border-bottom:2px solid #e5e7eb;padding-bottom:.75rem}.section-header h4{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0}.section-summary{display:flex;gap:1.5rem;flex-wrap:wrap;align-items:stretch}.summary-card{flex:1;min-width:150px;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:.375rem;padding:1.25rem 1rem;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;transition:all .2s}.summary-card:hover{background-color:#e5e7eb;border-color:#9ca3af;transform:translateY(-2px)}.summary-label{font-size:.875rem;font-weight:500;color:#6b7280;text-align:center;text-transform:uppercase;letter-spacing:.025em}.summary-amount{font-size:1.5rem;font-weight:700;color:#059669;text-align:center}.budgets-container{display:flex;flex-direction:column;gap:1.5rem}.budgets-title{font-size:1.875rem;font-weight:600;color:#000;text-align:center;margin:0 0 1.5rem}.month-selector{display:flex;justify-content:center;align-items:center;gap:2rem;margin-bottom:1rem;padding:1.5rem;background:#fff;border-radius:.5rem;border-bottom:2px solid #e5e7eb}.month-selector h3{margin:0;font-size:1.5rem;font-weight:600;color:#1f2937;min-width:180px;text-align:center}.month-btn{padding:.75rem 1rem;background:#2563eb;color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-weight:500;font-size:.875rem;transition:all .2s;line-height:1.5;display:inline-flex;align-items:center;justify-content:center}.month-btn:hover{background:#1d4ed8;box-shadow:0 2px 8px #2563eb4d}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.summary-card{padding:1.5rem;border-radius:.5rem;background:#fff;border-left:4px solid #ddd;box-shadow:0 1px 3px #0000001a}.summary-card.budget{border-left-color:#2563eb}.summary-card.spent{border-left-color:#ef4444}.summary-card.remaining{border-left-color:#10b981}.summary-card.remaining.negative{border-left-color:#ef4444}.summary-card.balance{border-left-color:#3b82f6}.summary-card.balance.negative{border-left-color:#ef4444}.summary-card .card-label{font-size:.65rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.summary-card .card-amount{font-size:1.5rem;font-weight:700;color:#1f2937}.summary-card.spent .card-amount{color:#ef4444}.summary-card.remaining.positive .card-amount{color:#10b981}.summary-card.remaining.negative .card-amount{color:#ef4444}.summary-card.balance.positive .card-amount{color:#10b981}.summary-card.balance.negative .card-amount{color:#ef4444}.budgets-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.budgets-header h3{font-size:1.5rem;font-weight:700;color:#1f2937}.add-btn{padding:.5rem 1rem;background-color:#10b981;color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.add-btn:hover{background-color:#059669}.add-form-container{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;margin-bottom:1.5rem}.add-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end}.form-group{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:150px}.form-group label{font-size:.875rem;font-weight:500;color:#374151}.form-group.checkbox-group{gap:.25rem;flex:0 1 auto;min-width:auto}.form-group.checkbox-group label{display:flex;align-items:center;gap:.5rem;font-weight:400;cursor:pointer;white-space:nowrap}.form-group.checkbox-group input[type=checkbox]{width:1.125rem;height:1.125rem;cursor:pointer;accent-color:#2563eb}.form-group.checkbox-group small{font-size:.75rem;color:#6b7280;margin-left:0;font-weight:400}.form-group input,.form-group select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-buttons{display:flex;gap:.5rem;justify-content:flex-end;align-items:flex-end;flex:0 1 auto}.form-row .form-buttons{margin-left:auto}.btn-cancel,.btn-submit{padding:.5rem 1rem;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.add-form-container .form-buttons .btn-cancel,.add-form-container .form-buttons .btn-submit{padding:0;font-size:1rem;width:1.75rem;height:1.75rem;display:flex;align-items:center;justify-content:center;line-height:1}.btn-cancel:hover{background-color:#d1d5db}.btn-submit{background-color:#2563eb;color:#fff}.btn-submit:hover:not(:disabled){background-color:#1d4ed8}.btn-submit:disabled{background-color:#9ca3af;cursor:not-allowed}.error-message{background-color:#fee2e2;color:#991b1b;padding:.75rem;border-radius:.375rem;font-size:.875rem;border:1px solid #fecaca;margin-top:1rem}.budget-sections{display:flex;flex-direction:column;gap:2.5rem}.budget-section{display:flex;flex-direction:column;gap:1rem}.section-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.section-header h4{margin:0;font-size:1.25rem;font-weight:600;color:#1f2937;min-width:150px}.section-totals{display:flex;gap:2rem;flex-wrap:wrap;justify-content:flex-end}.total-item{font-size:.875rem;font-weight:500;color:#6b7280}.total-item.spent{color:#ef4444;font-weight:600}.total-item.remaining{font-weight:600}.total-item.remaining.positive{color:#10b981}.total-item.remaining.negative{color:#ef4444}.budgets-grid{display:flex;flex-direction:column;gap:.75rem}.budget-item{background-color:#fff;border:1px solid #e5e7eb;border-radius:.375rem;padding:1rem 1.5rem;transition:all .2s;display:flex;flex-direction:column}.budget-item:hover{background-color:#f9fafb;border-color:#d1d5db}.budget-header{display:grid;grid-template-columns:repeat(7,1fr);gap:1rem;align-items:center;margin-bottom:0;width:100%;justify-items:stretch;background:linear-gradient(135deg,#f8fafc,#f0f4f8);margin:-1rem -1.5rem 0;padding:1rem 1.5rem;border-radius:.375rem .375rem 0 0}.header-title{display:flex;align-items:center;gap:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.budget-header h4{font-size:1rem;font-weight:600;color:#1f2937;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.budget-header .budget-summary{display:flex;gap:.75rem;justify-content:center;flex-direction:row;align-items:center;grid-column:4 / 7}.budget-header .budget-summary-item{display:flex;flex-direction:column;gap:.25rem;font-size:.75rem;text-align:center;flex:1;min-width:0}.budget-header .budget-summary-item label{color:#6b7280;font-weight:500;text-transform:uppercase}.budget-header .budget-summary-item span{color:#1f2937;font-weight:600;font-size:.9rem}.budget-header .budget-summary-item span.spent{color:#ef4444}.budget-header .budget-summary-item span.remaining{color:#10b981}.budget-header .budget-summary-item span.over-budget{color:#ef4444}.recurring-column{display:flex;justify-content:center;align-items:center;min-height:2rem}.recurring-badge{display:inline-block;background-color:#dbeafe;color:#0c4a6e;padding:.25rem .75rem;border-radius:.375rem;font-size:.75rem;font-weight:600;white-space:nowrap}.budget-month{font-size:.875rem;color:#6b7280;background-color:transparent;padding:0;border-radius:0;font-weight:600;order:-5}.budget-amounts{display:none}.amount{display:flex;flex-direction:column;gap:.25rem}.amount label{font-size:.75rem;color:#6b7280;font-weight:500;text-transform:uppercase}.amount span{font-size:1rem;font-weight:600;color:#1f2937}.amount span.spent{color:#ef4444}.amount span.remaining{color:#10b981}.amount span.over-budget{color:#ef4444}.budget-progress{display:none}.progress-bar{height:8px;background-color:#e5e7eb;border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;transition:width .3s ease}.progress-fill.ok{background-color:#10b981}.progress-fill.warning{background-color:#f59e0b}.progress-fill.over-budget{background-color:#ef4444}.progress-text{font-size:.875rem;color:#6b7280;margin:0}.no-budgets{text-align:center;color:#6b7280;padding:2rem;background-color:#fff;border-radius:.5rem;border:1px solid #e5e7eb;grid-column:1 / -1}.budget-item.editing{background-color:#f9fafb;border-color:#2563eb}.budget-item.editing .budget-header{border-bottom:1px solid #e5e7eb;padding-bottom:1rem;margin-bottom:1rem}.budget-actions{display:flex;gap:.5rem;justify-content:center;align-items:center}.action-btn{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .2s}.action-btn:hover{background-color:#0000000d;transform:scale(1.1)}.action-btn.edit-btn:hover{background-color:#2563eb1a}.action-btn.delete-btn:hover{background-color:#ef44441a}.budget-edit-form{display:flex;flex-direction:row;gap:.75rem;padding:1rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:.375rem;margin-top:1rem;align-items:flex-end;flex-wrap:wrap;width:100%;justify-content:space-evenly}.edit-field{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:120px}.edit-field label{font-size:.75rem;font-weight:500;color:#6b7280;text-transform:uppercase;margin-bottom:.125rem}.edit-field input[type=number],.edit-field select{padding:2px;border:1px solid #d1d5db;border-radius:.375rem;font-size:.8rem;transition:border-color .2s;min-width:120px;width:100%}.edit-field input[type=number]:focus,.edit-field select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.edit-field.checkbox-field{gap:.25rem}.edit-field.checkbox-field label{display:flex;align-items:center;gap:.5rem;font-weight:400;cursor:pointer;margin:0}.edit-field.checkbox-field input[type=checkbox]{width:1.125rem;height:1.125rem;cursor:pointer;accent-color:#2563eb}.edit-buttons{display:flex;gap:.5rem;justify-content:flex-end;align-self:flex-end;margin:0;padding:0;border:none}.btn-save,.btn-cancel{padding:0;border:none;border-radius:.375rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;width:1.75rem;height:1.75rem;display:flex;align-items:center;justify-content:center;line-height:1}.btn-save{background-color:#2563eb;color:#fff}.btn-save:hover:not(:disabled){background-color:#1d4ed8;box-shadow:0 2px 8px #2563eb4d}.btn-save:disabled{background-color:#9ca3af;cursor:not-allowed}.btn-cancel{background-color:#e5e7eb;color:#374151}.btn-cancel:hover:not(:disabled){background-color:#d1d5db}.btn-cancel:disabled{cursor:not-allowed;opacity:.6}.expand-icon{display:inline-block;transition:transform .3s ease;font-size:.875rem;margin-right:.25rem}.expand-icon.open{transform:rotate(90deg)}.budget-item.expanded{border-bottom:none;border-radius:.375rem}.transaction-list-container{border-top:1px solid #e5e7eb;padding:1rem;background-color:#f9fafb;margin-top:1rem;border-radius:0}.transaction-list-header{margin-bottom:1rem}.transaction-list-header h5{margin:0;font-size:.875rem;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px}.transaction-items{display:flex;flex-direction:column;gap:.75rem}.transaction-item{display:grid;grid-template-columns:80px 120px 1fr 120px;gap:1rem;padding:.75rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:.375rem;align-items:center;font-size:.875rem}.transaction-date{color:#6b7280;font-weight:500;white-space:nowrap}.transaction-category{color:#374151;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transaction-description{color:#6b7280;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transaction-amount{text-align:right;font-weight:600}.transaction-amount .amount{display:inline-block}.transaction-amount .amount.expense{color:#ef4444}.transaction-amount .amount.income{color:#10b981}.no-transactions{text-align:center;color:#9ca3af;padding:1rem;font-size:.875rem;margin:0}@media(max-width:768px){.budgets-container{padding:0 1rem}.month-selector{flex-wrap:wrap;gap:.75rem;padding:1rem}.month-selector h3{flex-basis:100%;order:-1;margin:0 0 .5rem}.month-selector .month-btn{flex:1 1 calc(50% - .375rem);padding:.875rem 1.25rem;min-width:calc(50% - .375rem)}.budget-header{grid-template-columns:80px 1fr 60px;gap:.5rem}.budget-header .budget-summary{grid-column:1 / -1;gap:.75rem;order:1;padding-top:.75rem;border-top:1px solid #e5e7eb;justify-content:space-between}.budget-header .budget-summary-item{width:auto;flex:1;text-align:center}.budget-header .budget-actions{order:0;grid-column:3;justify-self:end}.summary-cards{grid-template-columns:repeat(2,1fr)}}.import-container{width:100%;max-width:1400px;display:flex;flex-direction:column}.import-section{background:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;width:100%;display:flex;flex-direction:column;flex:1;min-height:0}.import-section h3{margin:0 0 1.5rem;font-size:1.25rem;font-weight:600;color:#1f2937}.tab-navigation{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid #e5e7eb}.tab-btn{padding:.75rem 1rem;border:none;background:transparent;cursor:pointer;font-size:.875rem;font-weight:500;color:#6b7280;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .2s}.tab-btn:hover{color:#374151}.tab-btn.active{color:#2563eb;border-bottom-color:#2563eb}.card-selection{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #e5e7eb}.card-selection label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.card-selection select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;transition:border-color .2s}.card-selection select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.card-selection select:disabled{background-color:#f3f4f6;cursor:not-allowed}.warning{color:#dc2626;font-size:.875rem;margin-top:.5rem}.category-selection{margin-bottom:1.5rem;padding:1rem;background-color:#f9fafb;border-radius:.375rem;border:1px solid #e5e7eb}.category-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.category-field{display:flex;flex-direction:column}.category-field label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.category-field select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;transition:border-color .2s}.category-field select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.category-field select:disabled{background-color:#f3f4f6;cursor:not-allowed;color:#9ca3af}.text-input-section{margin-bottom:1.5rem}.text-input-section label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.parse-debug{margin-top:.75rem;padding:.75rem;background-color:#f0fdf4;border:1px solid #86efac;border-radius:.375rem;color:#15803d;font-size:.875rem}.text-input-section textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;font-family:monospace;transition:border-color .2s}.text-input-section textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.parse-btn{margin-top:.75rem;padding:.75rem 1.5rem;background-color:#2563eb;color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.parse-btn:hover:not(:disabled){background-color:#1d4ed8}.parse-btn:disabled{background-color:#d1d5db;cursor:not-allowed}.parsed-transactions{margin-top:1.5rem;display:flex;flex-direction:column;flex:1;min-height:0}.transactions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.transactions-header h4{margin:0;font-size:1rem;font-weight:600;color:#1f2937}.import-all-btn{padding:.5rem 1rem;background-color:#10b981;color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.import-all-btn:hover:not(:disabled){background-color:#059669}.import-all-btn:disabled{background-color:#d1d5db;cursor:not-allowed}.transactions-list{display:flex;flex-direction:column;gap:.75rem;flex:1;overflow-y:auto;min-height:0}.transaction-card{display:grid;grid-template-columns:auto auto auto auto 1fr auto auto;gap:.75rem;padding:.75rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;transition:all .2s;align-items:center}.transaction-card:hover{background-color:#f3f4f6;border-color:#d1d5db}.transaction-card.success{background-color:#d1fae5;border-color:#6ee7b7}.transaction-card.error{background-color:#fee2e2;border-color:#fecaca}.transaction-card.duplicate{background-color:#fef3c7;border-color:#fcd34d}.transaction-date{font-size:.875rem;color:#6b7280;font-weight:600;min-width:75px;flex-shrink:0}.transaction-amount{font-size:.975rem;font-weight:700;color:#ef4444;text-align:right;min-width:65px;flex-shrink:0}.transaction-description{font-size:.925rem;color:#1f2937;font-weight:500;flex:1;display:flex;flex-direction:column;gap:.25rem;cursor:help;min-width:0}.description-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;text-align:left}.duplicate-warning{font-size:.875rem;color:#d97706;font-weight:600;white-space:nowrap}.transaction-type-select{font-size:.825rem;padding:.4rem;border:1px solid #d1d5db;border-radius:.25rem;transition:border-color .2s;background-color:#fff;color:#1f2937;min-width:80px;flex-shrink:0}.transaction-type-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1a}.transaction-type-select:disabled{background-color:#f3f4f6;cursor:not-allowed;color:#9ca3af}.transaction-main-category-select,.transaction-sub-category-select{font-size:.825rem;padding:.4rem;border:1px solid #d1d5db;border-radius:.25rem;transition:border-color .2s;background-color:#fff;color:#1f2937;width:100%;max-width:150px;min-width:80px}.transaction-main-category-select:focus,.transaction-sub-category-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1a}.transaction-main-category-select:disabled,.transaction-sub-category-select:disabled{background-color:#f3f4f6;cursor:not-allowed;color:#9ca3af}.import-btn{padding:.5rem 1rem;background-color:#2563eb;color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;width:fit-content;flex-shrink:0}.import-btn:hover:not(:disabled){background-color:#1d4ed8}.import-btn:disabled,.import-btn.disabled{background-color:#d1d5db;cursor:not-allowed;opacity:.6}.import-btn.imported{background-color:#10b981;cursor:default}.error-message{font-size:.75rem;color:#991b1b;font-weight:600;white-space:nowrap}@media(max-width:768px){.import-container,.import-section{padding:1rem}.transaction-card{grid-template-columns:auto auto auto auto 1fr auto auto;gap:.3rem;padding:.5rem;font-size:.65rem}.transaction-date{font-size:.65rem;min-width:60px}.transaction-type-select{min-width:50px;flex-shrink:0;font-size:.725rem;padding:.2rem .3rem}.transaction-main-category-select,.transaction-sub-category-select{width:100%;max-width:90px;min-width:60px;font-size:.725rem;padding:.2rem .3rem}.transaction-description{font-size:.775rem;min-width:0}.description-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.transaction-amount{font-size:.775rem;min-width:50px;text-align:right}.import-btn{padding:.3rem .5rem;font-size:.7rem;min-width:45px}}.receipt-input-section{margin-bottom:1.5rem;padding:1.5rem;background:#f9fafb;border-radius:.5rem}.receipt-input-section label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:1rem}.receipt-upload-area{border:2px dashed #d1d5db;border-radius:.5rem;padding:2rem;text-align:center;cursor:pointer;transition:all .2s;background:#fff;margin-bottom:1rem}.receipt-upload-area:hover{border-color:#2563eb;background:#eff6ff}.upload-placeholder{pointer-events:none}.upload-icon{font-size:2.5rem;margin-bottom:.5rem}.upload-placeholder p{margin:.5rem 0;color:#374151;font-size:.9rem;font-weight:500}.upload-placeholder small{color:#6b7280;display:block;font-size:.8rem}.receipt-file-info{pointer-events:none;padding:1rem}.file-icon{font-size:2rem;margin-bottom:.5rem}.file-name{color:#1f2937;font-weight:500;word-break:break-all;margin-bottom:.25rem}.file-size{color:#6b7280;font-size:.875rem;margin-bottom:1rem}.remove-file-btn{pointer-events:all;padding:.5rem 1rem;background:#ef4444;color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background .2s}.remove-file-btn:hover{background:#dc2626}.receipt-error{padding:.75rem 1rem;background:#fee2e2;border-left:4px solid #ef4444;color:#991b1b;border-radius:.375rem;font-size:.875rem;margin-bottom:1rem}.parse-receipt-btn{width:100%;padding:.75rem 1rem;background:#2563eb;color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s}.parse-receipt-btn:hover:not(:disabled){background:#1d4ed8}.parse-receipt-btn:disabled{background:#d1d5db;cursor:not-allowed}.category-input-group{display:flex;flex-direction:column;gap:.5rem;flex:1}.new-category-input{display:flex;gap:.5rem;align-items:center;padding:.5rem;background-color:#eff6ff;border:1px solid #93c5fd;border-radius:.375rem;animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;max-height:0}to{opacity:1;max-height:100px}}.new-category-input input{flex:1;padding:.4rem .5rem;border:1px solid #93c5fd;border-radius:.25rem;font-size:.825rem;background-color:#fff;color:#1f2937;transition:border-color .2s}.new-category-input input::placeholder{color:#9ca3af}.new-category-input input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1a}.create-category-btn{padding:.4rem .75rem;background-color:#10b981;color:#fff;border:none;border-radius:.25rem;font-size:.75rem;font-weight:600;cursor:pointer;transition:background-color .2s;white-space:nowrap;flex-shrink:0}.create-category-btn:hover:not(:disabled){background-color:#059669}.create-category-btn:disabled{background-color:#d1d5db;cursor:not-allowed;color:#9ca3af}.cancel-category-btn{padding:.4rem .75rem;background-color:#ef4444;color:#fff;border:none;border-radius:.25rem;font-size:.75rem;font-weight:600;cursor:pointer;transition:background-color .2s;white-space:nowrap;flex-shrink:0}.cancel-category-btn:hover{background-color:#dc2626}#root{width:100%;height:100%;padding:0;margin:0;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
