.login-container{align-items:center;background:var(--gray-100);min-height:100vh;padding:2rem 1rem}.login-card,.login-container{display:flex;justify-content:center}.login-card{background:var(--white);border:1px solid var(--border-color);border-radius:24px;box-shadow:var(--shadow-lg);flex-direction:column;max-width:520px;min-height:600px;padding:3.5rem 3rem;transition:transform .3s ease,box-shadow .3s ease;width:100%}.login-card:hover{box-shadow:0 20px 30px #00000026;transform:translateY(-2px)}.login-header{margin-bottom:2.5rem;text-align:center}.login-logo{flex-direction:column;gap:1rem;margin-bottom:1rem}.login-logo,.logo-icon{align-items:center;display:flex}.logo-icon{background:var(--black);border-radius:18px;box-shadow:0 4px 12px #00000026;color:var(--white);height:72px;justify-content:center;transition:transform .3s ease;width:72px}.logo-icon:hover{transform:scale(1.05)}.logo-text{color:var(--text-primary);font-size:2rem;font-weight:700;letter-spacing:-.02em;margin:0}.login-subtitle{color:var(--text-secondary);font-size:.9375rem;font-weight:400;line-height:1.5;margin:0}.login-form{gap:1.5rem}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:.625rem}.form-label{color:var(--text-primary);font-size:.9375rem;font-weight:600;letter-spacing:.01em;margin-bottom:0}.input-wrapper{position:relative;width:100%}.form-input{border:1.5px solid var(--border-color);border-radius:12px;color:var(--text-primary);font-family:inherit;font-size:.9375rem;line-height:1.5;padding:1rem;transition:all .2s ease}.form-input::placeholder{color:var(--gray-400);font-weight:400}.form-input:hover{border-color:var(--gray-400)}.form-input:focus{background:var(--white);border-color:var(--black);box-shadow:0 0 0 4px var(--gray-200)}.form-input.error{background:#dc262605;border-color:var(--expense-red)}.form-input.error:focus{box-shadow:0 0 0 4px #dc26261a}.password-toggle{align-items:center;background:none;border:none;border-radius:6px;color:var(--gray-500);cursor:pointer;display:flex;justify-content:center;padding:.375rem;position:absolute;right:1rem;top:50%;transform:translateY(-50%);transition:all .2s ease}.password-toggle:hover{background:var(--gray-100);color:var(--text-primary)}.password-toggle:active{transform:translateY(-50%) scale(.95)}.password-toggle:disabled{cursor:not-allowed;opacity:.4}.form-options{justify-content:space-between;margin:.5rem 0}.checkbox-label,.form-options{align-items:center;display:flex}.checkbox-label{color:var(--text-primary);cursor:pointer;font-size:.9375rem;gap:.625rem;transition:color .2s ease;-webkit-user-select:none;user-select:none}.checkbox-label:hover{color:var(--text-secondary)}.checkbox-label input[type=checkbox]{accent-color:var(--black);cursor:pointer;height:18px;margin:0;width:18px}.forgot-link{border-radius:6px;color:var(--text-secondary);font-size:.9375rem;font-weight:500;padding:.25rem .5rem;text-decoration:none;transition:all .2s ease}.forgot-link:hover{background:var(--gray-100);color:var(--text-primary);text-decoration:none}.error-message{align-items:center;color:var(--expense-red);display:flex;font-size:.875rem;font-weight:500;gap:.375rem;margin-top:.375rem}.error-message:before{content:"⚠";font-size:.875rem}.general-error{background:#dc26260d;border:1px solid #dc262633;border-radius:10px;justify-content:center;padding:1rem;text-align:center}.login-button{align-items:center;background:var(--black);border:none;border-radius:12px;box-shadow:0 2px 8px #0000001a;color:var(--white);cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.625rem;justify-content:center;letter-spacing:.01em;margin-top:.75rem;padding:1rem 1.5rem;transition:all .2s ease;width:100%}.login-button:hover:not(:disabled){box-shadow:0 4px 12px #00000026;opacity:.95;transform:translateY(-1px)}.login-button:active:not(:disabled){box-shadow:0 2px 4px #0000001a;transform:translateY(0)}.login-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.login-button.loading{opacity:.8}.spinner{animation:spin .8s linear infinite;border:2.5px solid #ffffff4d;border-radius:50%;border-top-color:initial;height:18px;width:18px}@keyframes spin{to{transform:rotate(1turn)}}.login-footer{margin-top:2rem;text-align:center}.toggle-mode{background:var(--gray-100);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;transition:all .2s ease}.toggle-mode:hover{background:var(--gray-50);border-color:var(--gray-300)}.toggle-mode p{color:var(--text-secondary);font-size:.9375rem;font-weight:400;line-height:1.6;margin:0}.toggle-link{background:none;border:none;color:var(--text-primary);cursor:pointer;font-weight:700;letter-spacing:.01em;padding:0 .25rem;text-decoration:none;transition:all .2s ease}.toggle-link:hover:not(:disabled){opacity:.7;text-decoration:underline;text-underline-offset:2px}.toggle-link:disabled{cursor:not-allowed;opacity:.5}.demo-credentials{background:var(--gray-100);border:1px solid var(--border-color);border-radius:8px;padding:1rem}.demo-credentials p{color:var(--text-secondary);font-size:.875rem;margin:0}[data-theme=dark] .login-container{background:var(--gray-50)}[data-theme=dark] .login-card{background:var(--gray-100);border:1px solid var(--gray-300);box-shadow:0 20px 40px #0009}[data-theme=dark] .login-card:hover{box-shadow:0 24px 48px #000000b3}[data-theme=dark] .logo-icon{background:var(--white);box-shadow:0 4px 12px #ffffff1a;color:var(--black)}[data-theme=dark] .logo-text{color:var(--text-primary)}[data-theme=dark] .login-subtitle{color:var(--text-secondary)}[data-theme=dark] .form-label{color:var(--text-primary)}[data-theme=dark] .form-input{background:var(--gray-200);border-color:var(--gray-300);color:var(--text-primary)}[data-theme=dark] .form-input::placeholder{color:var(--gray-500)}[data-theme=dark] .form-input:hover{border-color:var(--gray-400)}[data-theme=dark] .form-input:focus{background:var(--gray-200);border-color:var(--white);box-shadow:0 0 0 4px var(--gray-300)}[data-theme=dark] .form-input.error{background:#dc26260d;border-color:var(--expense-red)}[data-theme=dark] .form-input.error:focus{box-shadow:0 0 0 4px #dc262626}[data-theme=dark] .password-toggle{color:var(--gray-500)}[data-theme=dark] .password-toggle:hover{background:var(--gray-300);color:var(--text-primary)}[data-theme=dark] .checkbox-label{color:var(--text-primary)}[data-theme=dark] .checkbox-label:hover{color:var(--text-secondary)}[data-theme=dark] .checkbox-label input[type=checkbox]{accent-color:var(--white)}[data-theme=dark] .forgot-link{color:var(--text-secondary)}[data-theme=dark] .forgot-link:hover{background:var(--gray-300);color:var(--text-primary)}[data-theme=dark] .general-error{background:#dc26261a;border-color:#dc26264d}[data-theme=dark] .login-button{background:var(--white);box-shadow:0 2px 8px #ffffff1a;color:var(--black)}[data-theme=dark] .login-button:hover:not(:disabled){box-shadow:0 4px 12px #ffffff26;opacity:.95}[data-theme=dark] .toggle-mode{background:var(--gray-200);border-color:var(--gray-300)}[data-theme=dark] .toggle-mode:hover{background:var(--gray-300);border-color:var(--gray-400)}[data-theme=dark] .toggle-mode p{color:var(--text-secondary)}[data-theme=dark] .toggle-link{color:var(--text-primary)}[data-theme=dark] .demo-credentials{background:var(--gray-200);border-color:var(--gray-300)}[data-theme=dark] .demo-credentials p{color:var(--text-secondary)}@media (max-width:480px){.login-container{padding:1.5rem 1rem}.login-card{border-radius:20px;max-width:100%;min-height:560px;padding:2.5rem 2rem}.logo-icon{border-radius:16px;height:64px;width:64px}.logo-text{font-size:1.75rem}.form-input,.form-label,.login-subtitle{font-size:.875rem}.form-input{border-radius:10px;padding:.9375rem}.login-button{border-radius:10px;font-size:.9375rem;padding:.9375rem 1.25rem}.toggle-mode{border-radius:10px;padding:1.25rem}.checkbox-label,.forgot-link,.toggle-mode p{font-size:.875rem}}@media (min-width:481px) and (max-width:768px){.login-card{max-width:500px;min-height:580px;padding:3rem 2.5rem}}:root{--black:#000;--white:#fff;--gray-50:#fafafa;--gray-100:#f5f5f5;--gray-200:#e5e5e5;--gray-300:#d4d4d4;--gray-400:#a3a3a3;--gray-500:#737373;--gray-600:#525252;--gray-700:#404040;--gray-800:#262626;--gray-900:#171717;--income-green:#059669;--expense-red:#dc2626;--chart-primary:#dc2626;--chart-secondary:#16a34a;--chart-accent:#f59e0b;--chart-light:#6b7280;--bg-primary:var(--white);--bg-secondary:var(--gray-100);--text-primary:var(--gray-900);--text-secondary:var(--gray-700);--border-color:var(--gray-200);--font-primary:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;--font-mono:"JetBrains Mono",monospace;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px #00000012;--shadow-lg:0 10px 15px #0000001a;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem}[data-theme=dark]{--white:#1a1a1a;--gray-50:#0f0f0f;--gray-100:#1a1a1a;--gray-200:#333;--gray-300:#404040;--gray-400:#525252;--gray-500:#737373;--gray-600:#e5e5e5;--gray-700:#f5f5f5;--gray-800:#fff;--gray-900:#fff;--bg-primary:var(--gray-100);--bg-secondary:var(--gray-200);--text-primary:var(--gray-900);--text-secondary:var(--gray-700);--border-color:var(--gray-300)}[data-theme=dark] body{background:#fafafa!important;background:var(--gray-50)!important;color:#171717!important;color:var(--gray-900)!important}[data-theme=dark] .main-content{color:#171717;color:var(--gray-900)}[data-theme=dark] .app,[data-theme=dark] .main-content{background:#fafafa;background:var(--gray-50)}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fafafa;background:var(--gray-50);color:#171717;color:var(--gray-900);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font-primary);line-height:1.6}[data-theme=dark] body{background:#171717;background:var(--gray-900);color:#f5f5f5;color:var(--gray-100)}.app{display:flex;flex-direction:column;min-height:100vh}.main-layout{display:flex;flex:1 1;min-height:calc(100vh - 64px)}.header{background:#fff;background:var(--white);border-bottom:1px solid #e5e5e5;border-bottom:1px solid var(--gray-200);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);height:64px;justify-content:space-between;overflow:visible;padding:0 1.5rem;padding:0 var(--space-lg);position:-webkit-sticky;position:sticky;top:0;z-index:100}.header,.header-left{align-items:center;display:flex}.header-left{gap:1.5rem;gap:var(--space-lg)}.logo{align-items:center;color:#171717;color:var(--gray-900);display:flex;font-size:1.25rem;font-weight:700;gap:.5rem;gap:var(--space-sm);text-decoration:none}.nav-links{display:flex;gap:1.5rem;gap:var(--space-lg);list-style:none}.nav-link{border-radius:.5rem;border-radius:var(--radius-md);color:#404040;color:var(--gray-700);font-weight:500;padding:.5rem 1rem;padding:var(--space-sm) var(--space-md);text-decoration:none;transition:all .2s}.nav-link:hover{background:#f5f5f5;background:var(--gray-100);color:#171717;color:var(--gray-900)}.nav-link.active{background:#171717;background:var(--gray-900);color:#fff;color:var(--white)}[data-theme=dark] .nav-link.active{background:#f5f5f5;background:var(--gray-100);color:#171717;color:var(--gray-900)}.header-right{align-items:center;display:flex;gap:1rem;gap:var(--space-md);overflow:visible}.theme-toggle{background:#f5f5f5;background:var(--gray-100);border:1px solid #e5e5e5;border:1px solid var(--gray-200);border-radius:.5rem;border-radius:var(--radius-md);color:#404040;color:var(--gray-700);cursor:pointer;font-size:1.25rem;padding:.5rem;padding:var(--space-sm);transition:all .2s}.theme-toggle:hover{background:#171717;background:var(--gray-900);color:#fff;color:var(--white)}.sidebar{background:#fff;background:var(--white);border-right:1px solid #e5e5e5;border-right:1px solid var(--gray-200);overflow-y:auto;padding:1.5rem;padding:var(--space-lg);width:280px}.sidebar-nav{list-style:none}.sidebar-item{margin-bottom:.25rem;margin-bottom:var(--space-xs)}.sidebar-link{align-items:center;border-radius:.5rem;border-radius:var(--radius-md);color:#404040;color:var(--gray-700);display:flex;font-weight:500;gap:1rem;gap:var(--space-md);padding:1rem;padding:var(--space-md);text-decoration:none;transition:all .2s}.sidebar-link:hover{background:#f5f5f5;background:var(--gray-100);color:#171717;color:var(--gray-900)}.sidebar-link.active{background:#171717;background:var(--gray-900);color:#fff;color:var(--white)}[data-theme=dark] .sidebar-link.active{background:#f5f5f5;background:var(--gray-100);color:#171717;color:var(--gray-900)}.sidebar-icon{font-size:1.25rem}.main-content{flex:1 1;overflow-y:auto;padding:2rem;padding:var(--space-xl)}.card{word-wrap:break-word;background:#fff;background:var(--white);border:1px solid #e5e5e5;border:1px solid var(--gray-200);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);overflow:hidden;padding:1.5rem;padding:var(--space-lg)}.stats-grid{grid-gap:1.5rem;grid-gap:var(--space-lg);display:grid;gap:1.5rem;gap:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:2rem;margin-bottom:var(--space-xl)}@media (max-width:640px){.stats-grid{gap:1rem;gap:var(--space-md);grid-template-columns:1fr}}.stat-card{word-wrap:break-word;background:#fff;background:var(--white);border:1px solid #e5e5e5;border:1px solid var(--gray-200);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);overflow:hidden;padding:1.5rem;padding:var(--space-lg);transition:all .2s}.stat-card:hover{box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem;margin-bottom:var(--space-md)}.stat-title{color:#737373;color:var(--gray-500);font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.stat-icon{color:#525252;color:var(--gray-600);font-size:1.5rem}.stat-value{color:#171717;color:var(--gray-900);font-size:2rem;font-weight:700;line-height:1.2;margin-bottom:.5rem;margin-bottom:var(--space-sm);max-width:100%;overflow-wrap:break-word;word-break:break-word}.stat-change{color:#525252;color:var(--gray-600)}.btn,.stat-change{font-size:.875rem;font-weight:500}.btn{align-items:center;border:none;border-radius:.5rem;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;gap:.5rem;gap:var(--space-sm);padding:.5rem 1rem;padding:var(--space-sm) var(--space-md);text-decoration:none;transition:all .2s}.btn-primary{background:#171717;background:var(--gray-900);color:#fff;color:var(--white)}.btn-primary:hover{background:#262626;background:var(--gray-800)}.btn-secondary{background:#f5f5f5;background:var(--gray-100);color:#404040;color:var(--gray-700)}.btn-secondary:hover{background:#e5e5e5;background:var(--gray-200)}.form-group{margin-bottom:1.5rem;margin-bottom:var(--space-lg)}.form-label{color:#404040;color:var(--gray-700);display:block;font-weight:500;margin-bottom:.5rem;margin-bottom:var(--space-sm)}.form-input{background:#fff;background:var(--white);border:1px solid #d4d4d4;border:1px solid var(--gray-300);border-radius:.5rem;border-radius:var(--radius-md);color:#171717;color:var(--gray-900);font-size:1rem;height:auto;line-height:1.4;padding:.5rem 1rem;padding:var(--space-sm) var(--space-md);transition:all .2s;width:100%}.form-input:focus{border-color:#525252;border-color:var(--gray-600);box-shadow:0 0 0 3px #0000001a;outline:none}select.form-input{height:36px;line-height:1.3;padding:.25rem 1rem;padding:var(--space-xs) var(--space-md)}.mobile-nav{background:#fff;background:var(--white);border-top:1px solid #e5e5e5;border-top:1px solid var(--gray-200);bottom:0;display:none;left:0;padding:.5rem;padding:var(--space-sm);position:fixed;right:0;z-index:100}.mobile-nav-list{display:flex;justify-content:space-around;list-style:none}.mobile-nav-link{align-items:center;border-radius:.375rem;border-radius:var(--radius-sm);color:#737373;color:var(--gray-500);display:flex;flex-direction:column;font-size:.75rem;font-weight:500;gap:.25rem;gap:var(--space-xs);min-height:48px;min-width:48px;min-width:44px;padding:.5rem;padding:var(--space-sm);text-decoration:none;transition:all .2s ease}.mobile-nav-link.active{color:#171717;color:var(--gray-900)}[data-theme=dark] .mobile-nav-link.active{color:#f5f5f5;color:var(--gray-100)}.mobile-nav-icon{font-size:1.25rem}.settings-grid{grid-gap:2rem;grid-gap:var(--space-xl);display:grid;gap:2rem;gap:var(--space-xl);grid-template-columns:280px 1fr}.categories-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr}@media (max-width:768px){.settings-grid{gap:1rem;gap:var(--space-md);grid-template-columns:1fr}.categories-grid{gap:1.5rem;grid-template-columns:1fr}}.section-header{gap:1rem;gap:var(--space-md);justify-content:space-between}.profile-hero,.section-header{align-items:center;display:flex;flex-wrap:wrap}.profile-hero{background:#f5f5f5;background:var(--bg-secondary);border:1px solid #e5e5e5;border:1px solid var(--border-color);border-radius:12px;gap:2rem;margin-bottom:2rem;padding:1.5rem}.form-grid-2{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr}.phone-row{display:flex;gap:.5rem}.phone-row select{max-width:140px;min-width:120px}@media (max-width:820px){.form-grid-2{grid-template-columns:1fr}.profile-hero{gap:1.25rem}.phone-row{flex-direction:column}.phone-row select{width:100%}.section-header{align-items:flex-start;flex-direction:column}}[data-theme=dark] .form-input{background:#f5f5f5;background:var(--gray-100);border-color:#e5e5e5;border-color:var(--gray-200);color:#171717;color:var(--gray-900)}[data-theme=dark] .form-input:focus{background:#f5f5f5;background:var(--gray-100);border-color:#a3a3a3;border-color:var(--gray-400)}[data-theme=dark] .form-input::placeholder{color:#525252;color:var(--gray-600)}[data-theme=dark] .card,[data-theme=dark] .stat-card{background:#f5f5f5;background:var(--gray-100);border-color:#e5e5e5;border-color:var(--gray-200);color:#171717;color:var(--gray-900)}[data-theme=dark] .stat-title{color:#525252;color:var(--gray-600)}[data-theme=dark] .stat-value{color:#171717;color:var(--gray-900)}[data-theme=dark] .stat-change{color:#404040;color:var(--gray-700)}[data-theme=dark] .btn-secondary{background:#e5e5e5;background:var(--gray-200);border-color:#d4d4d4;border-color:var(--gray-300);color:#171717;color:var(--gray-900)}[data-theme=dark] .btn-secondary:hover{background:#d4d4d4;background:var(--gray-300)}[data-theme=dark] .btn-primary{background:#171717;background:var(--gray-900);color:#fafafa;color:var(--gray-50)}[data-theme=dark] .btn-primary:hover{background:#262626;background:var(--gray-800)}[data-theme=dark] .nav-link{color:#404040;color:var(--gray-700)}[data-theme=dark] .nav-link:hover{background:#e5e5e5;background:var(--gray-200);color:#171717;color:var(--gray-900)}[data-theme=dark] .sidebar-link{color:#404040;color:var(--gray-700)}[data-theme=dark] .sidebar-link:hover{background:#e5e5e5;background:var(--gray-200);color:#171717;color:var(--gray-900)}[data-theme=dark] .header,[data-theme=dark] .mobile-nav,[data-theme=dark] .sidebar{background:#f5f5f5;background:var(--gray-100);border-color:#e5e5e5;border-color:var(--gray-200)}.delete-account-btn{background:#000;color:#fff}[data-theme=dark] .delete-account-btn{background:#fff;color:#000}.data-management-btn{background:#fff!important;color:#000!important}[data-theme=dark] .data-management-btn{background:#f3f4f6!important;color:#000!important}@media (max-width:1024px){.sidebar{width:240px}.main-content{padding:1.5rem;padding:var(--space-lg)}}.two-col-grid{grid-gap:1.5rem;grid-gap:var(--space-lg);display:grid;gap:1.5rem;gap:var(--space-lg);grid-template-columns:1fr 1fr}.two-col-grid.large-gap{gap:2rem;gap:var(--space-xl)}@media (max-width:900px){.two-col-grid{grid-template-columns:1fr}}@media (max-width:768px){.card{margin-bottom:1rem;margin-bottom:var(--space-md)}.stats-grid{gap:1rem;gap:var(--space-md)}}.responsive-table-wrapper{overflow-x:auto}.responsive-table-wrapper table{min-width:600px}@media (max-width:768px){.nav-links,.sidebar{display:none}.main-content{padding:1rem;padding:var(--space-md);padding-bottom:calc(1rem + 80px);padding-bottom:calc(var(--space-md) + 80px)}.mobile-nav{display:block}.stats-grid{gap:1rem;gap:var(--space-md);grid-template-columns:1fr}.header{padding:0 1rem;padding:0 var(--space-md)}.card{margin-bottom:1rem;margin-bottom:var(--space-md)}.card,.stat-card{padding:1rem;padding:var(--space-md)}}@media (max-width:480px){.main-content{padding:.5rem;padding:var(--space-sm);padding-bottom:calc(.5rem + 80px);padding-bottom:calc(var(--space-sm) + 80px)}.stat-value{font-size:1.5rem}.header{padding:0 .5rem;padding:0 var(--space-sm)}.card,.stat-card{padding:.5rem;padding:var(--space-sm)}h1{font-size:1.5rem!important}h2{font-size:1.25rem!important}h3{font-size:1.125rem!important}.btn{min-height:44px;padding:1rem;padding:var(--space-md)}.mobile-nav-link{min-height:44px;min-width:44px}h1{font-size:1.375rem!important}h2{font-size:1.125rem!important}.stat-value{font-size:1.375rem;line-height:1.3;overflow-wrap:break-word;word-break:break-word}.two-col-grid.large-gap{gap:1.5rem;gap:var(--space-lg)}.two-col-grid{gap:1rem;gap:var(--space-md)}}body{overflow-x:hidden}.settings-tabs{background:#f5f5f5;background:var(--bg-secondary);border-radius:.75rem;border-radius:var(--radius-lg);padding:.5rem}.tabs-nav{background:#fff;background:var(--white);border-radius:.5rem;border-radius:var(--radius-md);display:flex;flex-wrap:wrap;gap:.25rem;padding:.25rem}.tab-btn{align-items:center;background:#0000;border:none;border-radius:.375rem;border-radius:var(--radius-sm);color:#525252;color:var(--gray-600);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.625rem 1rem;transition:all .2s ease;white-space:nowrap}.tab-btn:hover{background:#f5f5f5;background:var(--gray-100);color:#171717;color:var(--gray-900)}.tab-btn.active{background:#171717;background:var(--gray-900);box-shadow:0 1px 3px #0000001a;color:#fff;color:var(--white)}[data-theme=dark] .tabs-nav{background:#e5e5e5;background:var(--gray-200)}[data-theme=dark] .tab-btn{color:#525252;color:var(--gray-600)}[data-theme=dark] .tab-btn:hover{background:#d4d4d4;background:var(--gray-300);color:#171717;color:var(--gray-900)}[data-theme=dark] .tab-btn.active{background:#f5f5f5;background:var(--gray-100);box-shadow:0 1px 3px #00000026;color:#171717;color:var(--gray-900)}.tab-icon{display:flex;font-size:1.125rem}.tab-label{line-height:1}@media (max-width:768px){.tabs-nav{-ms-overflow-style:none;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.tabs-nav::-webkit-scrollbar{display:none}.tab-btn{flex:0 0 auto}}@media (max-width:600px){.tab-btn{font-size:.8125rem;padding:.5rem .875rem}.tab-icon{font-size:1rem}}.transaction-header{gap:1rem;justify-content:space-between}.transaction-actions,.transaction-header{align-items:center;display:flex;flex-wrap:wrap}.transaction-actions{gap:.75rem}.transaction-item-actions{display:flex;flex-shrink:0;gap:.5rem}.period-selector{font-size:.875rem;font-weight:500;height:32px;line-height:1.3;min-width:150px;padding:.25rem 1rem!important;padding:var(--space-xs) var(--space-md)!important;width:auto}@media (min-width:769px){.transaction-actions button,.transaction-actions select{flex:0 0 auto}.period-selector{min-width:150px}}@media (max-width:768px){.transaction-header{align-items:flex-start;flex-direction:column}.transaction-actions{gap:.5rem;width:100%}.transaction-actions button,.transaction-actions select{flex:1 1;min-width:0}.transaction-actions button{justify-content:center}.period-selector{width:100%}}@media (max-width:600px){.transaction-item-actions{flex-direction:column;gap:.25rem;width:100%}.transaction-item-actions button{padding:.375rem .75rem;text-align:center;width:100%}.transaction-actions.modal-actions{flex-direction:column-reverse}.transaction-actions.modal-actions button{width:100%}}.card svg{height:auto;max-width:100%}button.mobile-nav-link.as-button{min-height:44px}.auto-grid-min200{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.auto-grid-min250{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.auto-grid-min350{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.grid-two-tight{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:1fr 1fr}.grid-3{grid-gap:1rem;grid-template-columns:1fr 1fr 1fr;text-align:center}.grid-3,.grid-form-4{display:grid;gap:1rem}.grid-form-4{grid-gap:1rem;align-items:end;grid-template-columns:1fr 1fr 1fr auto}@media (max-width:900px){.grid-form-4{grid-template-columns:1fr 1fr}}@media (max-width:768px){.grid-3{grid-template-columns:1fr}}.dashboard-grid{grid-template-columns:1fr 1fr}@media (max-width:1024px){.dashboard-grid{gap:1.25rem;grid-template-columns:1fr}}@media (max-width:600px){.grid-form-4,.grid-two-tight{grid-template-columns:1fr}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.card:hover{box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md);transition:box-shadow .2s ease}.loading-skeleton{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#e5e5e5 25%,#d4d4d4 50%,#e5e5e5 75%);background:linear-gradient(90deg,var(--gray-200) 25%,var(--gray-300) 50%,var(--gray-200) 75%);background-size:200% 100%}.form-input:focus,button:focus,select:focus{outline:2px solid #525252;outline:2px solid var(--gray-600);outline-offset:2px}.toast-container{display:flex;flex-direction:column;gap:12px;max-width:400px;pointer-events:none;position:fixed;right:20px;top:20px;z-index:10000}.toast{background:var(--bg-white);border:1px solid #e5e5e5;border:1px solid var(--gray-200);border-radius:8px;box-shadow:0 8px 32px #0000001f;max-width:380px;min-width:320px;opacity:0;overflow:hidden;pointer-events:auto;transform:translateX(100%);transition:all .3s cubic-bezier(.4,0,.2,1)}.toast-enter{opacity:1;transform:translateX(0)}.toast-exit{opacity:0;transform:translateX(100%)}.toast-content{gap:12px;padding:16px;position:relative}.toast-content,.toast-icon{align-items:center;display:flex}.toast-icon{flex-shrink:0;height:20px;justify-content:center;width:20px}.toast-message{color:#171717;color:var(--gray-900);flex:1 1;font-size:14px;font-weight:500;line-height:1.4}.toast-close{align-items:center;background:none;border:none;border-radius:4px;color:#a3a3a3;color:var(--gray-400);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:4px;transition:all .2s}.toast-close:hover{background:#f5f5f5;background:var(--gray-100);color:#525252;color:var(--gray-600)}.toast-success{border-left:4px solid #22c55e}.toast-success .toast-icon{color:#22c55e}.toast-error{border-left:4px solid #ef4444}.toast-error .toast-icon{color:#ef4444}.toast-warning{border-left:4px solid #f59e0b}.toast-warning .toast-icon{color:#f59e0b}.toast-info{border-left:4px solid #3b82f6}.toast-info .toast-icon{color:#3b82f6}[data-theme=dark] .toast{background:#f5f5f5;background:var(--bg-secondary);border-color:#404040;border-color:var(--gray-700);box-shadow:0 8px 32px #0000004d}[data-theme=dark] .toast-message{color:#171717;color:var(--text-primary)}[data-theme=dark] .toast-close{color:#a3a3a3;color:var(--gray-400)}[data-theme=dark] .toast-close:hover{background:#404040;background:var(--gray-700);color:#d4d4d4;color:var(--gray-300)}@media (max-width:480px){.toast-container{left:16px;max-width:none;right:16px;top:16px}.toast{max-width:none;min-width:auto}}.profile-dropdown{display:inline-block;margin-left:12px;position:relative;z-index:10000}.profile-button{align-items:center;background:none;border:none;border-radius:8px;color:#171717;color:var(--text-primary);cursor:pointer;display:flex;gap:8px;padding:8px 12px;transition:all .2s}.profile-button:hover{background:#f5f5f5;background:var(--gray-100)}.profile-avatar{align-items:center;background:#e5e5e5;background:var(--gray-200);border:2px solid #d4d4d4;border:2px solid var(--gray-300);border-radius:50%;display:flex;height:32px;justify-content:center;overflow:hidden;width:32px}.profile-avatar img{height:100%;object-fit:cover;width:100%}.profile-avatar svg{color:#525252;color:var(--gray-600)}.dropdown-arrow{color:#737373;color:var(--gray-500);transition:transform .2s}.dropdown-arrow.open{transform:rotate(180deg)}.dropdown-menu{animation:dropdownFadeIn .2s ease-out;background:#fff;border:1px solid #e5e5e5;border:1px solid var(--gray-200);border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 0 0 1px #0000000d;isolation:isolate;margin-top:8px;min-width:180px;padding:8px 0;position:absolute;right:0;top:100%;transform:translateZ(0);will-change:transform;z-index:10001}.dropdown-item{align-items:center;background:none;border:none;color:#171717;color:var(--text-primary);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:12px 16px;text-align:left;text-decoration:none;transition:background .2s;width:100%}.dropdown-item:hover{background:#fafafa;background:var(--gray-50)}.dropdown-item svg{color:#737373;color:var(--gray-500);flex-shrink:0}.logout-item{border-top:1px solid #f5f5f5;border-top:1px solid var(--gray-100);margin-top:4px}.logout-item,.logout-item svg{color:#dc2626;color:var(--expense-red)}.logout-item:hover{background:#ef44440d}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}[data-theme=dark] .profile-avatar,[data-theme=dark] .profile-button:hover{background:#404040;background:var(--gray-700)}[data-theme=dark] .profile-avatar{border-color:#525252;border-color:var(--gray-600)}[data-theme=dark] .profile-avatar svg{color:#a3a3a3;color:var(--gray-400)}[data-theme=dark] .dropdown-menu{background:#f5f5f5;background:var(--bg-secondary);border-color:#404040;border-color:var(--gray-700);box-shadow:0 8px 32px #0000004d}[data-theme=dark] .dropdown-item:hover{background:#404040;background:var(--gray-700)}[data-theme=dark] .logout-item{border-top-color:#404040;border-top-color:var(--gray-700)}[data-theme=dark] .logout-item:hover{background:#ef44441a}@media (max-width:768px){.profile-dropdown{margin-left:8px}.profile-button{padding:6px 8px}.profile-avatar{height:28px;width:28px}.dropdown-menu{min-width:160px;right:-8px}}.chart-container{background:#fff;background:var(--bg-primary);border-radius:.75rem;border-radius:var(--radius-lg);overflow:hidden;position:relative;width:100%}.dashboard-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-bottom:2rem}@media (max-width:768px){.dashboard-grid{gap:1rem;grid-template-columns:1fr}}.chart-interactive:hover{box-shadow:0 10px 15px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px);transition:all .2s ease}.chart-title{color:#171717;color:var(--text-primary);font-size:1.125rem;font-weight:600;margin-bottom:.25rem}.chart-subtitle{margin:0}.chart-legend,.chart-subtitle{color:#404040;color:var(--text-secondary);font-size:.875rem}.chart-legend{align-items:center;display:flex;gap:1.5rem;margin-bottom:1rem}.chart-legend-item{align-items:center;display:flex;gap:.5rem}.chart-legend-color{border-radius:50%;flex-shrink:0;height:12px;width:12px}.health-score-excellent{color:#059669;color:var(--income-green)}.health-score-good{color:#f59e0b}.health-score-poor{color:#dc2626;color:var(--expense-red)}@keyframes chartFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chart-animate-in{animation:chartFadeIn .6s ease-out}.scrollable-chart-container{background:#fff;background:var(--bg-primary);border:1px solid #e5e5e5;border:1px solid var(--border-color);border-radius:.5rem;border-radius:var(--radius-md);overflow-x:auto;overflow-y:hidden;position:relative}.scrollable-chart-container::-webkit-scrollbar{height:8px}.scrollable-chart-container::-webkit-scrollbar-track{background:#f5f5f5;background:var(--gray-100);border-radius:4px}.scrollable-chart-container::-webkit-scrollbar-thumb{background:#a3a3a3;background:var(--gray-400);border-radius:4px}.scrollable-chart-container::-webkit-scrollbar-thumb:hover{background:#737373;background:var(--gray-500)}@media (max-width:640px){.chart-title{font-size:1rem}.chart-legend,.chart-subtitle{font-size:.8rem}.chart-legend{flex-wrap:wrap;gap:1rem}}.heat-map-cell{transition:all .2s ease}.heat-map-cell:hover{stroke:#525252;stroke:var(--gray-600);stroke-width:2;filter:brightness(1.1)}.progress-ring{transition:stroke-dashoffset .8s cubic-bezier(.4,0,.2,1)}.chart-tooltip{background:#171717;background:var(--gray-900);border-radius:.375rem;border-radius:var(--radius-sm);color:#fff;color:var(--white);font-size:.8rem;font-weight:500;opacity:0;padding:.5rem .75rem;pointer-events:none;position:absolute;transform:translate(-50%,-100%);transition:opacity .2s ease;z-index:1000}.chart-tooltip.visible{opacity:1}.chart-gradient-income{background:linear-gradient(135deg,#059669,#0596691a);background:linear-gradient(135deg,var(--income-green),#0596691a)}.chart-gradient-expense{background:linear-gradient(135deg,#dc2626,#dc26261a);background:linear-gradient(135deg,var(--expense-red),#dc26261a)}.chart-element:focus{outline:2px solid #059669;outline:2px solid var(--income-green);outline-offset:2px}.chart-section{margin-bottom:2rem}.chart-section:last-child{margin-bottom:0}.ai-assistant-layout{grid-gap:2rem;align-items:start;display:grid;gap:2rem;grid-template-columns:1fr}@media (min-width:1025px){.ai-assistant-layout{grid-template-columns:2fr 1fr}.ai-assistant-sidebar{display:flex!important;flex-direction:column;gap:1.5rem}}.ai-assistant-sidebar{display:none}@media (max-width:320px){.main-content{padding:.25rem;padding:var(--space-xs);padding-bottom:calc(.25rem + 80px);padding-bottom:calc(var(--space-xs) + 80px)}.stats-grid{gap:.5rem;gap:var(--space-sm);grid-template-columns:1fr}.stat-card{min-width:0;padding:.5rem;padding:var(--space-sm)}.stat-value{font-size:1.25rem;word-break:break-all}h1{font-size:1.25rem!important}h2{font-size:1rem!important}h3{font-size:.875rem!important}}@media (max-width:768px){.categories-grid,.stats-grid,.two-col-grid{gap:1rem;gap:var(--space-md);grid-template-columns:1fr}.grid-two-tight{grid-template-columns:1fr}.form-row,.grid-two-tight{gap:.5rem;gap:var(--space-sm)}.form-row{flex-direction:column}.form-input{box-sizing:border-box;width:100%}.btn{justify-content:center;min-height:44px;padding:1rem;padding:var(--space-md);width:100%}.btn-group{flex-direction:column;gap:.5rem;gap:var(--space-sm)}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}table{font-size:.875rem;min-width:600px}td,th{padding:.5rem;padding:var(--space-sm);white-space:nowrap}.card{border-radius:.5rem;border-radius:var(--radius-md);margin:0 0 1rem;margin:0 0 var(--space-md) 0}.header{flex-wrap:wrap;gap:.5rem;gap:var(--space-sm);padding:.5rem;padding:var(--space-sm)}.header-title{flex:1 1;min-width:200px}.header-actions{flex-wrap:wrap;gap:.5rem;gap:var(--space-sm)}.settings-nav{-webkit-overflow-scrolling:touch;overflow-x:auto;padding-bottom:.5rem;padding-bottom:var(--space-sm);white-space:nowrap}.settings-nav button{margin-right:.5rem;margin-right:var(--space-sm);min-width:-webkit-max-content;min-width:max-content}.settings-content{padding:.5rem;padding:var(--space-sm)}}@media (max-width:600px){.form-group{margin-bottom:1rem;margin-bottom:var(--space-md)}.form-label{font-size:.875rem;margin-bottom:.25rem;margin-bottom:var(--space-xs)}.form-input{font-size:1rem;padding:.5rem;padding:var(--space-sm)}select.form-input{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem}}@media (max-width:480px){.quick-add-form{padding:.5rem;padding:var(--space-sm)}.quick-add-form .form-row{flex-direction:column}.quick-add-form .form-input{margin-bottom:.5rem;margin-bottom:var(--space-sm);width:100%}.recent-transactions,.transaction-item{padding:.5rem;padding:var(--space-sm)}.transaction-item{flex-wrap:wrap;gap:.25rem;gap:var(--space-xs)}.transaction-details{flex:1 1;min-width:100%}.transaction-amount{align-self:flex-end}.login-container{padding:.5rem;padding:var(--space-sm)}.login-card{border-radius:.75rem;border-radius:var(--radius-lg);max-width:none;padding:1rem;padding:var(--space-md);width:100%}.login-logo{flex-direction:column;gap:.5rem;gap:var(--space-sm);text-align:center}.logo-text{font-size:1.5rem}}@media (max-width:600px){.chart-container{height:200px!important;margin:.5rem 0;margin:var(--space-sm) 0}.chart-legend{flex-direction:column;gap:.25rem;gap:var(--space-xs);text-align:center}}@media (max-width:768px){.ai-chat-container{flex-direction:column;height:calc(100vh - 140px)}.ai-chat-messages{flex:1 1;overflow-y:auto}.ai-chat-input,.ai-chat-messages{padding:.5rem;padding:var(--space-sm)}.ai-chat-input{border-top:1px solid #e5e5e5;border-top:1px solid var(--border-color)}.ai-message{border-radius:.5rem;border-radius:var(--radius-md);margin-bottom:.5rem;margin-bottom:var(--space-sm);padding:.5rem;padding:var(--space-sm)}.reports-filters{flex-direction:column;gap:.5rem;gap:var(--space-sm)}.reports-filter-group{width:100%}.goals-grid,.reports-grid{gap:1rem;gap:var(--space-md);grid-template-columns:1fr}.goal-card{padding:1rem;padding:var(--space-md)}.goal-progress{margin:.5rem 0;margin:var(--space-sm) 0}.transactions-header{flex-direction:column;gap:.5rem;gap:var(--space-sm)}.transactions-filters{flex-wrap:wrap;gap:.5rem;gap:var(--space-sm)}.transactions-table{display:block;overflow-x:auto;white-space:nowrap}}.mobile-hide{display:block}.mobile-show{display:none}@media (max-width:768px){.mobile-hide{display:none!important}.mobile-show{display:block!important}.mobile-flex{display:flex!important}}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-wrap-mobile{overflow-wrap:break-word;word-break:break-word}.spacing-mobile-compact{margin:.25rem 0!important;margin:var(--space-xs) 0!important;padding:.5rem!important;padding:var(--space-sm)!important}@media (max-width:480px){.spacing-mobile-compact{margin:.25rem 0!important;margin:var(--space-xs) 0!important;padding:.25rem!important;padding:var(--space-xs)!important}}input,select,textarea{-webkit-appearance:none;appearance:none;font-size:16px}@media (max-width:768px){input,select,textarea{box-sizing:border-box;width:100%}}.container-responsive{margin:0 auto;max-width:1200px;padding:0 1rem;padding:0 var(--space-md);width:100%}@media (max-width:768px){.container-responsive{padding:0 .5rem;padding:0 var(--space-sm)}}@media (max-width:480px){.container-responsive{padding:0 .25rem;padding:0 var(--space-xs)}}
/*# sourceMappingURL=main.42b27501.css.map*/