:root{--primary-color:#3498db;--primary-dark:#2980b9;--secondary-color:#2ecc71;--secondary-dark:#27ae60;--text-color:#333333;--text-light:#666666;--text-lighter:#999999;--background-color:#f8f9fa;--white:#ffffff;--light-gray:#f1f3f5;--gray:#e0e0e0;--dark-gray:#bdbdbd;--border-color:#e1e4e8;--success-color:#27ae60;--error-color:#e74c3c;--warning-color:#f39c12;--info-color:#3498db;--color-cash:#4CAF50;--color-savings:#2196F3;--color-stock:#9C27B0;--color-crypto:#FF9800;--color-realestate:#795548;--color-gold:#FFC107;--color-other:#607D8B;--color-loan:#F44336;--color-credit-card:#E91E63;--color-mortgage:#9C27B0;--color-student-loan:#673AB7;--color-tax:#3F51B5;--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,"Open Sans","Helvetica Neue",sans-serif;--font-size-base:16px;--line-height-base:1.5;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-xxl:3rem;--border-radius-sm:0.25rem;--border-radius-md:0.5rem;--border-radius-lg:1rem;--shadow-sm:0 1px 3px rgba(0,0,0,0.12);--shadow-md:0 4px 6px rgba(0,0,0,0.1);--shadow-lg:0 10px 15px -3px rgba(0,0,0,0.1);--transition-fast:150ms ease;--transition-normal:300ms ease;--transition-slow:500ms ease;--z-index-dropdown:1000;--z-index-sticky:1020;--z-index-fixed:1030;--z-index-modal-backdrop:1040;--z-index-modal:1050;--z-index-tooltip:1060}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body,html{font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-base);color:var(--text-color);background-color:var(--background-color);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:100%;height:100%;overflow-x:hidden}a{color:var(--primary-color);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-dark);text-decoration:underline}img{max-width:100%;height:auto;display:block}button{cursor:pointer;font-family:inherit}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.layout{display:flex;flex-direction:column;min-height:100vh}.header{background-color:var(--white);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:var(--z-index-sticky);display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-xl)}.logo h1{font-size:1.5rem;font-weight:700;color:var(--primary-color);margin:0}.nav ul{display:flex;list-style:none;gap:var(--spacing-lg)}.nav a{color:var(--text-color);font-weight:500;padding:var(--spacing-sm) 0;border-bottom:2px solid transparent;transition:all var(--transition-fast)}.nav a.active,.nav a:hover{color:var(--primary-color);border-bottom-color:var(--primary-color);text-decoration:none}.user-actions{display:flex;align-items:center;gap:var(--spacing-md)}.user-email{color:var(--text-light)}.main-content{flex:1;padding:var(--spacing-xl) var(--spacing-xl)}.footer{background-color:var(--white);border-top:1px solid var(--border-color);padding:var(--spacing-lg) 0;text-align:center;color:var(--text-light)}.footer-links{display:flex;justify-content:center;gap:var(--spacing-lg);margin-top:var(--spacing-md)}.footer-links a{color:var(--text-light);font-size:.9rem}.auth-button,.button,button.action-button,button.add-button,button.delete-button,button.edit-button,button.logout-button,button.view-all-button{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;font-size:1rem;font-weight:500;border-radius:var(--border-radius-md);transition:all var(--transition-fast);border:none;background-color:var(--primary-color);color:var(--white)}.auth-button:hover,.button:hover,button.action-button:hover,button.add-button:hover,button.edit-button:hover,button.view-all-button:hover{background-color:var(--primary-dark);transform:translateY(-1px)}.auth-button:active,.button:active,button.action-button:active,button.add-button:active,button.edit-button:active,button.view-all-button:active{transform:translateY(0)}.auth-button:disabled,.button:disabled,button.action-button:disabled,button.add-button:disabled,button.delete-button:disabled,button.edit-button:disabled,button.view-all-button:disabled{opacity:.6;cursor:not-allowed}.button.secondary,button.edit-button,button.secondary{background-color:var(--white);color:var(--primary-color);border:1px solid var(--primary-color)}.button.secondary:hover,button.edit-button:hover,button.secondary:hover{background-color:var(--light-gray)}button.delete-button{background-color:var(--white);color:var(--error-color);border:1px solid var(--error-color)}button.delete-button:hover{background-color:var(--error-color);color:var(--white)}button.action-button{display:flex;gap:.5rem;padding:.75rem 1.5rem}.button-icon{font-size:1.25rem}.text-button{background:none;border:none;color:var(--primary-color);font-size:inherit;text-decoration:underline;padding:0}.text-button:hover{color:var(--primary-dark)}.form-group,.form-row{margin-bottom:var(--spacing-md)}.form-row{display:flex;gap:var(--spacing-md)}.form-row .form-group{flex:1;margin-bottom:0}label{margin-bottom:var(--spacing-xs);color:var(--text-color)}input[type=date],input[type=email],input[type=number],input[type=password],input[type=text],select,textarea{width:100%;padding:.75rem;font-size:1rem;border:1px solid var(--border-color);border-radius:var(--border-radius-md);background-color:var(--white);transition:border-color var(--transition-fast)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(52,152,219,.2)}select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='6' viewBox='0 0 8 6'%3E%3Cpath fill='%23666' d='M0 0l4 6 4-6z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}textarea{min-height:100px;resize:vertical}.form-actions{gap:var(--spacing-md);margin-top:var(--spacing-lg)}.error-message{color:var(--error-color);background-color:rgba(231,76,60,.1);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-md)}.auth-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background-color:var(--background-color);padding:var(--spacing-md)}.auth-card{background-color:var(--white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-xl);width:100%;max-width:450px}.auth-header{text-align:center;margin-bottom:var(--spacing-xl)}.auth-header h1{font-size:1.75rem;margin-bottom:var(--spacing-sm);color:var(--primary-color)}.auth-header p{color:var(--text-light)}.auth-tabs{display:flex;margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.auth-tab{flex:1;background:none;padding:var(--spacing-sm) 0;font-size:1rem;font-weight:500;color:var(--text-light);border:none;border-bottom:2px solid transparent;transition:all var(--transition-fast)}.auth-tab.active{border-bottom-color:var(--primary-color)}.auth-tab.active,.auth-tab:hover{color:var(--primary-color)}.auth-form{margin-bottom:var(--spacing-md)}.auth-button{width:100%;margin-top:var(--spacing-md);padding:.75rem}.auth-helper-text{text-align:center;font-size:.9rem;color:var(--text-light)}.auth-error{margin-bottom:var(--spacing-md);color:var(--error-color);background-color:rgba(231,76,60,.1);padding:var(--spacing-sm);border-radius:var(--border-radius-sm);text-align:center}.dashboard-container{padding:var(--spacing-md);background-color:var(--background-color)}.loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;background-color:rgba(255,255,255,.7);border-radius:var(--border-radius-lg);padding:var(--spacing-xl)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.dashboard-title{font-size:1.75rem;font-weight:700;color:var(--text-color);margin:0;position:relative}.dashboard-quick-actions{display:flex;gap:var(--spacing-sm)}.quick-action-button{display:flex;align-items:center;gap:var(--spacing-xs);background-color:var(--white);color:var(--primary-color);border:1px solid var(--primary-color);border-radius:var(--border-radius-md);padding:.4rem .8rem;font-weight:500;font-size:.9rem;transition:all var(--transition-fast)}.quick-action-button:hover{background-color:var(--primary-color);color:var(--white)}.quick-action-button .icon{font-size:1rem;font-weight:700}.dashboard-summary{background-color:var(--white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-xl);overflow:hidden}.summary-tabs{display:flex;border-bottom:1px solid var(--border-color);background-color:var(--light-gray)}.summary-tab{padding:var(--spacing-md) var(--spacing-lg);background:transparent;font-weight:500;color:var(--text-light);cursor:pointer;transition:all var(--transition-fast);border:none;border-bottom:2px solid transparent}.summary-tab.active,.summary-tab:hover{color:var(--primary-color)}.summary-tab.active{border-bottom-color:var(--primary-color);background-color:var(--white)}.summary-content{padding:var(--spacing-lg)}.tab-content{animation:fadeIn .3s ease}.summary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.summary-header h2{font-size:1.25rem;font-weight:600;margin:0}.total-value{font-size:1.25rem}.chart-analysis-container{display:flex;gap:var(--spacing-xl);margin-top:var(--spacing-lg)}.chart-container{min-height:300px;border:1px solid var(--border-color);background-color:var(--white)}.analysis-list,.chart-container{flex:1;border-radius:var(--border-radius-md);padding:var(--spacing-md)}.analysis-list{background-color:var(--light-gray)}.analysis-list h3{font-size:1rem;font-weight:600;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--border-color)}.category-list{list-style:none;padding:0;margin:0}.category-item{display:flex;align-items:center;padding:var(--spacing-xs) 0;margin-bottom:var(--spacing-xs);border-bottom:1px solid rgba(0,0,0,.05)}.category-color{width:12px;height:12px;border-radius:50%;margin-right:var(--spacing-sm)}.category-label{flex:2;font-weight:500}.category-value{flex:1;text-align:right;font-weight:600}.category-percent{min-width:45px;text-align:right;font-size:.85rem;color:var(--text-light);margin-left:var(--spacing-sm)}.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.stat-card{background-color:var(--light-gray);border-radius:var(--border-radius-md);padding:var(--spacing-md);text-align:center}.stat-title{font-size:.9rem;color:var(--text-light);margin-bottom:var(--spacing-xs)}.stat-value{font-size:1.5rem;color:var(--text-color)}.liabilities-chart{margin-top:var(--spacing-lg);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:var(--spacing-md);background-color:var(--white)}.dashboard-panels{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl);margin-top:var(--spacing-xl)}.dashboard-panel{background-color:var(--white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);background-color:var(--light-gray)}.panel-header h2{font-size:1.1rem;font-weight:600;margin:0}.modern-table-container{overflow-x:auto}.modern-table{width:100%;border-collapse:collapse;font-size:.95rem}.modern-table th{text-align:left;background-color:var(--white);color:var(--text-light);font-weight:600}.modern-table td,.modern-table th{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modern-table td{color:var(--text-color)}.modern-table tr:last-child td{border-bottom:none}.modern-table tr:hover td{background-color:rgba(0,0,0,.02)}.asset-type-indicator,.liability-type-indicator{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:8px}.empty-chart{height:200px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.balance-summary-modern{background-color:var(--white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-lg);animation:fadeIn .5s ease}.balance-summary-modern .summary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.balance-summary-modern h2{font-size:1.5rem;font-weight:600;margin:0;color:var(--text-color)}.financial-health-indicator{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-md);background-color:var(--light-gray)}.health-label{font-size:.85rem;color:var(--text-light)}.health-status{font-weight:600;font-size:.9rem}.summary-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.summary-card{background-color:var(--white);border-radius:var(--border-radius-md);padding:var(--spacing-md);box-shadow:var(--shadow-sm);text-align:center;transition:transform .3s ease,box-shadow .3s ease}.summary-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.summary-card h3{font-size:.95rem;font-weight:500;margin-bottom:var(--spacing-sm);color:var(--text-light)}.summary-card .amount{font-size:1.5rem;font-weight:700}.summary-card.assets{background:linear-gradient(to bottom right,#ffffff,#e8f5e9);border-left:4px solid var(--color-cash)}.summary-card.liabilities{background:linear-gradient(to bottom right,#ffffff,#ffebee);border-left:4px solid var(--color-loan)}.summary-card.net-worth{background:linear-gradient(to bottom right,#ffffff,#e3f2fd);border-left:4px solid var(--primary-color)}.net-worth-header{display:flex;justify-content:center;align-items:center;gap:var(--spacing-sm)}.change-indicator{font-size:.75rem;font-weight:600;padding:1px 5px;border-radius:3px}.change-indicator.positive{background-color:rgba(46,204,113,.1);color:var(--success-color)}.change-indicator.negative{background-color:rgba(231,76,60,.1);color:var(--error-color)}.summary-card.net-worth .amount.positive{color:var(--success-color)}.summary-card.net-worth .amount.negative{color:var(--error-color)}.finance-overview-container{display:flex;gap:var(--spacing-xl);margin-top:var(--spacing-lg)}.finance-overview-chart{flex:1.5;background-color:var(--white);box-shadow:var(--shadow-sm)}.finance-overview-chart,.finance-overview-stats{border-radius:var(--border-radius-md);padding:var(--spacing-md)}.finance-overview-stats{flex:1;background-color:var(--light-gray)}.finance-overview-stats h3{font-size:1.1rem;font-weight:600;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--border-color);color:var(--text-color)}.stat-item{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid rgba(0,0,0,.05)}.stat-info,.stat-item{display:flex;flex-direction:column}.stat-info{margin-bottom:var(--spacing-xs)}.stat-label{color:var(--text-color);font-weight:500;font-size:.95rem}.hint-text{color:var(--text-light);font-size:.8rem;margin-top:2px}.stat-value-container{display:flex;align-items:center;gap:var(--spacing-md)}.stat-value{font-weight:700;font-size:1.1rem;min-width:50px}.progress-bar-container{flex:1;background-color:var(--gray);overflow:hidden}.progress-bar{transition:width 1s ease-out}.finance-actions{margin-top:var(--spacing-lg);display:flex;justify-content:center}.finance-action-button{display:flex;align-items:center;gap:var(--spacing-xs);background-color:var(--white);color:var(--primary-color);border:1px solid var(--primary-color);border-radius:var(--border-radius-md);padding:.6rem 1rem;font-weight:500;transition:all var(--transition-fast)}.finance-action-button:hover{background-color:var(--primary-color);color:var(--white);transform:translateY(-2px)}.action-icon{font-size:1.1rem}.empty-chart{height:280px;display:flex;align-items:center;justify-content:center;background-color:var(--light-gray);border-radius:var(--border-radius-md);color:var(--text-light);font-style:italic}@media (max-width:768px){.finance-overview-container{flex-direction:column}.summary-cards{grid-template-columns:1fr}.summary-card{margin-bottom:var(--spacing-sm)}}.table-container{margin-top:var(--spacing-md);overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table td,.data-table th{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--border-color)}.data-table th{background-color:var(--light-gray);font-weight:600;cursor:pointer}.data-table th:hover{background-color:var(--gray)}.data-table tbody tr:hover{background-color:var(--light-gray)}.data-table .amount{text-align:right;font-weight:500}.data-table .actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.sort-indicator{margin-left:var(--spacing-xs)}.item-row{cursor:pointer}.modern-container{padding:var(--spacing-md);background-color:var(--background-color)}.page-header{margin-bottom:var(--spacing-lg)}.header-title{display:flex;flex-direction:column;gap:var(--spacing-xs)}.header-title h1{font-size:1.75rem;font-weight:700;margin:0;color:var(--text-color)}.asset-summary{color:var(--text-light);font-size:.95rem}.total-value{font-weight:700;color:var(--success-color);font-size:1.1rem}.total-value.liability-color{color:var(--error-color)}.header-actions{gap:var(--spacing-md);align-items:center}.view-toggle{display:flex;background-color:var(--light-gray);border-radius:var(--border-radius-md);overflow:hidden}.view-toggle-button{display:flex;align-items:center;gap:var(--spacing-xs);padding:.5rem .75rem;background:transparent;border:none;color:var(--text-light);font-weight:500;transition:all var(--transition-fast)}.view-toggle-button.active{background-color:var(--white);color:var(--primary-color);box-shadow:var(--shadow-sm)}.view-icon{font-size:1rem}.modern-button{display:flex;align-items:center;gap:var(--spacing-xs);background-color:var(--primary-color);color:var(--white);border:none;border-radius:var(--border-radius-md);padding:.6rem 1rem;font-weight:500;transition:all var(--transition-fast)}.modern-button:hover{background-color:var(--primary-dark);transform:translateY(-2px)}.modern-filters{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);background-color:var(--white);padding:.75rem var(--spacing-md);border-radius:var(--border-radius-md);box-shadow:var(--shadow-sm)}.search-box{flex:1;max-width:300px;position:relative}.search-box input{padding:.6rem .75rem;border-radius:var(--border-radius-md);border:1px solid var(--border-color);width:100%;font-size:.9rem;transition:all var(--transition-fast)}.search-box input:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px rgba(52,152,219,.2)}.asset-count{color:var(--text-light);font-size:.9rem}.asset-name,.asset-type,.liability-name,.liability-type{display:flex;align-items:center;gap:var(--spacing-xs)}.asset-icon,.liability-icon{font-size:1.1rem;margin-right:var(--spacing-xs)}.modern-action-button{background:none;border:none;font-size:1.1rem;padding:.3rem;border-radius:var(--border-radius-sm);transition:all var(--transition-fast);color:var(--text-light)}.modern-action-button.edit-button:hover{background-color:rgba(52,152,219,.1);color:var(--primary-color)}.modern-action-button.delete-button:hover{background-color:rgba(231,76,60,.1);color:var(--error-color)}.chart-view{display:flex;flex-direction:column;gap:var(--spacing-xl)}.chart-section{background-color:var(--white);border-radius:var(--border-radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.chart-section h3{font-size:1.1rem;font-weight:600;margin:0 0 var(--spacing-md) 0;color:var(--text-color)}.charts-row{display:flex;gap:var(--spacing-xl)}.chart-col{flex:1}.liability-type-list{background-color:var(--light-gray);border-radius:var(--border-radius-md);padding:var(--spacing-md)}.top-liabilities-chart{height:300px}.due-date{display:flex;align-items:center;gap:var(--spacing-sm)}.due-status{font-size:.75rem;font-weight:600;padding:.1rem .3rem;border-radius:3px}.due-status.overdue{background-color:rgba(231,76,60,.1);color:var(--error-color)}.due-date-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.due-date-item{justify-content:space-between;padding:var(--spacing-sm);background-color:var(--light-gray);border-radius:var(--border-radius-md);border-left:3px solid var(--primary-color)}.due-date-item,.due-date-name{display:flex;align-items:center}.due-date-name{gap:var(--spacing-xs);font-weight:500}.due-date-info{text-align:right}.due-date-amount{font-weight:600}.due-date-status{font-size:.8rem;color:var(--text-light)}.due-date-status.overdue{color:var(--error-color);font-weight:600}.due-date-status.upcoming{color:var(--text-light)}.modern-empty-state{text-align:center;padding:var(--spacing-xl);background-color:var(--white);border-radius:var(--border-radius-lg);margin-top:var(--spacing-md);box-shadow:var(--shadow-sm)}.empty-icon{font-size:3rem;margin-bottom:var(--spacing-md);color:var(--text-lighter)}.modern-empty-state h3{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--text-color)}.modern-empty-state p{margin-bottom:var(--spacing-lg);color:var(--text-light)}.category-info{flex:2}.category-info,.category-stats{display:flex;align-items:center}.category-stats{gap:var(--spacing-md);justify-content:flex-end;flex:1}@media (max-width:768px){.header-actions{align-items:stretch}.charts-row,.header-actions,.modern-filters{flex-direction:column}.modern-filters{gap:var(--spacing-sm)}.search-box{max-width:100%}}.asset-form-container,.liability-form-container{background-color:var(--white);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-sm);max-width:800px;margin:0 auto}.asset-form-container h2,.liability-form-container h2{margin-bottom:var(--spacing-lg);font-size:1.5rem;font-weight:600}.empty-state{text-align:center;padding:var(--spacing-xl);background-color:var(--white);border-radius:var(--border-radius-md);margin-top:var(--spacing-md)}.empty-state p{margin-bottom:var(--spacing-md);color:var(--text-light)}.loading-container{min-height:100vh;background-color:var(--background-color)}.initializing,.loading,.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center}.initializing,.loading{padding:var(--spacing-xl);color:var(--text-light)}.loading-spinner,.spinner{border:3px solid rgba(0,0,0,.1);border-radius:50%;border-top:3px solid var(--primary-color);width:30px;height:30px;animation:spin 1s linear infinite;margin-bottom:var(--spacing-md)}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-container{text-align:center;padding:var(--spacing-xl)}.landing-page{min-height:100vh;background-color:var(--white)}.landing-header{padding:var(--spacing-md) 0;background-color:var(--white);position:fixed;top:0;width:100%;z-index:var(--z-index-sticky);box-shadow:var(--shadow-sm)}.landing-header .container{display:flex;justify-content:space-between;align-items:center}.landing-header .logo{font-size:1.5rem;font-weight:700;color:var(--primary-color)}.login-button{padding:.5rem 1.25rem;background-color:var(--primary-color);color:var(--white);border-radius:var(--border-radius-md);font-weight:500;transition:all var(--transition-fast)}.login-button:hover{background-color:var(--primary-dark);text-decoration:none}.hero{padding:10rem 0 5rem;background-color:var(--background-color)}.hero-content{max-width:700px;margin:0 auto;text-align:center}.hero h1{font-size:3rem;font-weight:800;margin-bottom:var(--spacing-md);line-height:1.2}.hero-description{font-size:1.25rem;line-height:1.6;color:var(--text-light);margin-bottom:var(--spacing-xl)}.hero-actions{display:flex;gap:var(--spacing-md);justify-content:center}.cta-button{padding:.75rem 1.5rem;font-size:1.125rem;font-weight:600;background-color:var(--primary-color);color:var(--white);border-radius:var(--border-radius-md);transition:all var(--transition-fast)}.cta-button:hover{background-color:var(--primary-dark);transform:translateY(-2px);text-decoration:none}.secondary-button{padding:.75rem 1.5rem;font-size:1.125rem;font-weight:600;background-color:var(--white);color:var(--primary-color);border:2px solid var(--primary-color);border-radius:var(--border-radius-md);transition:all var(--transition-fast)}.secondary-button:hover{background-color:var(--light-gray);text-decoration:none}.section-title{text-align:center;font-size:2rem;font-weight:700;margin-bottom:var(--spacing-xl)}.features,.how-it-works{padding:var(--spacing-xxl) 0}.features{background-color:var(--white)}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-xl)}.feature-card{background-color:var(--light-gray);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);text-align:center;transition:transform var(--transition-normal)}.feature-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}.feature-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.feature-card h3{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-sm)}.feature-card p{color:var(--text-light)}.steps{display:flex;justify-content:space-between;gap:var(--spacing-lg);max-width:900px;margin:0 auto}.step{flex:1;text-align:center;position:relative}.step:not(:last-child):after{content:"";position:absolute;top:2rem;right:-4rem;width:8rem;height:2px;background-color:var(--border-color)}.step-number{width:4rem;height:4rem;background-color:var(--primary-color);color:var(--white);font-size:1.5rem;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--spacing-md)}.step h3{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-sm)}.step p{color:var(--text-light)}.landing-footer{background-color:var(--background-color);padding:var(--spacing-xl) 0;text-align:center}@media (max-width:768px){.summary-cards{grid-template-columns:1fr;gap:var(--spacing-sm)}.stats-container{flex-direction:column}.stats{padding-right:0;padding-bottom:var(--spacing-md)}.recent-items{grid-template-columns:1fr}.steps{flex-direction:column}.step:not(:last-child):after{width:2px;height:2rem;top:auto;right:auto;bottom:-3rem;left:50%;transform:translateX(-50%)}.step{margin-bottom:var(--spacing-xl)}.feature-grid{grid-template-columns:1fr}.nav ul{gap:var(--spacing-md)}.header{flex-direction:column;padding:var(--spacing-sm);align-items:flex-start;gap:var(--spacing-sm)}.logo h1{font-size:1.2rem;margin:0;white-space:nowrap}.nav{width:100%;overflow-x:auto;margin:0}.nav ul{gap:var(--spacing-md);white-space:nowrap;flex-wrap:nowrap;justify-content:space-between;padding:var(--spacing-xs) var(--spacing-sm)}.nav li{border-radius:var(--border-radius-sm);background-color:rgba(255,255,255,.8);box-shadow:0 1px 3px rgba(0,0,0,.1);border:1px solid #e0e0e0;margin:0 4px}.nav a{font-size:.9rem;padding:var(--spacing-xs) var(--spacing-md);display:block;text-align:center;margin:0;font-weight:600;color:#666}.nav a,.nav a.active{border-radius:var(--border-radius-sm)}.nav a.active{background-color:var(--primary-color);color:white;border:none;box-shadow:0 2px 4px rgba(52,152,219,.3)}.user-actions{width:100%;justify-content:space-between;font-size:.85rem;padding-top:var(--spacing-xs)}.user-email{font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.logout-button{font-size:.85rem;padding:.25rem .5rem}.main-content{padding:var(--spacing-md) var(--spacing-sm)}.dashboard-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.dashboard-quick-actions{width:100%}.quick-action-button{font-size:.85rem;padding:.3rem .6rem}.summary-tabs{display:flex;overflow-x:auto;justify-content:space-between;background-color:#f5f5f5;padding:var(--spacing-xs) var(--spacing-sm)}.summary-tab,.summary-tabs{border-radius:var(--border-radius-sm)}.summary-tab{padding:var(--spacing-sm) var(--spacing-md);font-size:.9rem;white-space:nowrap;flex:1;text-align:center;margin:0 3px;background-color:rgba(255,255,255,.95);box-shadow:0 1px 3px rgba(0,0,0,.1);border:1px solid #e0e0e0;color:#666}.summary-tab.active{background-color:var(--primary-color);color:white;border:1px solid var(--primary-dark);font-weight:600;box-shadow:0 2px 4px rgba(52,152,219,.3)}.tab-text{display:block;padding:var(--spacing-xs) var(--spacing-sm);font-weight:600}.chart-analysis-container{flex-direction:column;gap:var(--spacing-md)}.dashboard-panels{grid-template-columns:1fr;gap:var(--spacing-md)}.modern-table td,.modern-table th{padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem}.summary-cards{grid-template-columns:1fr;gap:var(--spacing-sm)}.finance-overview-container{flex-direction:column;gap:var(--spacing-md)}.stat-cards{grid-template-columns:1fr;gap:var(--spacing-sm)}.auth-button,.button,button.action-button,button.add-button,button.delete-button,button.edit-button,button.logout-button,button.view-all-button{padding:.4rem .8rem;font-size:.9rem}.form-row{flex-direction:column;gap:var(--spacing-sm)}.dashboard-container{padding:var(--spacing-sm)}.summary-content{padding:var(--spacing-md)}.modern-table-container{max-width:100%;overflow-x:auto}.balance-summary-modern{padding:var(--spacing-sm)}.balance-summary-modern .summary-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.balance-summary-modern h2{font-size:1.2rem;margin-bottom:var(--spacing-xs)}.financial-health-indicator{font-size:.85rem}.finance-overview-chart{padding:var(--spacing-xs);max-height:250px}.recharts-responsive-container{height:220px!important}.finance-overview-container{margin-top:var(--spacing-md)}.finance-action-button{padding:.4rem .8rem;font-size:.85rem}.stat-item{margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-xs)}.stat-info{margin-bottom:2px}.stat-label{font-size:.9rem}.hint-text{font-size:.7rem}.stat-value{font-size:1rem}}@media (max-width:480px){.logo h1{font-size:1.1rem}.dashboard-title{font-size:1.4rem}.nav ul{gap:var(--spacing-sm)}.nav a{font-size:.85rem;padding:var(--spacing-xs) var(--spacing-sm)}.summary-content{padding:var(--spacing-sm)}.panel-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.quick-action-button,.view-all-button{font-size:.8rem;padding:.25rem .5rem}.summary-cards{gap:var(--spacing-xs)}.summary-card{padding:var(--spacing-xs)}.summary-card h3{font-size:.85rem}.summary-card .amount{font-size:1.2rem}.recharts-responsive-container{height:200px!important}.recharts-legend-wrapper{font-size:.8rem}.dashboard-panel{margin-bottom:var(--spacing-xs)}.modern-table td,.modern-table th{padding:var(--spacing-xs) var(--spacing-xs);font-size:.8rem}.dashboard-title{font-size:1.2rem}}.goals-container{padding:20px}.goals-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.goals-title{font-size:24px;font-weight:600;color:var(--color-text-primary);margin:0}.create-goal-button{display:flex;align-items:center;background-color:var(--color-primary,#1976d2);color:white;border:none;border-radius:4px;padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .3s}.create-goal-button:hover{background-color:var(--color-primary-dark,#1565c0)}.create-goal-button .icon{margin-right:8px;font-size:16px}.goals-section{margin-bottom:40px}.section-title{font-size:18px;font-weight:500;color:var(--color-text-secondary,#666);margin-bottom:15px}.goals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.goal-card{background-color:var(--color-background-light,#fff);border-radius:8px;padding:20px;box-shadow:0 1px 3px rgba(0,0,0,.1);transition:transform .3s,box-shadow .3s;cursor:pointer}.goal-card:hover{transform:translateY(-3px);box-shadow:0 4px 6px rgba(0,0,0,.1)}.goal-card.achieved{background-color:var(--color-success-bg,#e8f5e9)}.achieved-goals{opacity:.9}.goal-progress-container{width:100%}.goal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.goal-name{font-size:16px;font-weight:500;color:var(--color-text-primary,#333);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.goal-actions{display:flex;gap:10px}.action-button{background-color:#f5f5f5;border:1px solid #ddd;cursor:pointer;padding:4px 8px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background-color .2s;color:#333}.action-button:hover{background-color:#e0e0e0}.delete-button,.edit-button{color:var(--color-text-secondary,#666);min-width:30px;min-height:30px;font-size:16px}.edit-button:hover{color:var(--color-primary,#1976d2);background-color:rgba(25,118,210,.1)}.delete-button:hover{color:var(--color-danger,#d32f2f);background-color:rgba(211,47,47,.1)}.progress-bar-container{width:100%;height:8px;background-color:#e9ecef;border-radius:4px;margin-bottom:12px;position:relative}.progress-bar{height:100%;border-radius:4px;transition:width .5s ease;background-color:var(--color-primary,#1976d2)}.progress-label{position:absolute;top:-20px;right:0;font-size:12px;font-weight:600;color:var(--color-text-secondary,#666)}.goal-amounts{display:flex;justify-content:space-between;margin-bottom:16px}.current-amount,.target-amount{display:flex;flex-direction:column}.amount-label{font-size:12px;color:var(--color-text-secondary,#666);margin-bottom:4px}.amount-value{font-size:14px;font-weight:500;color:var(--color-text-primary,#333)}.goal-details{padding-top:12px;border-top:1px solid #eaeaea}.detail-item{display:flex;justify-content:space-between;margin-bottom:8px}.detail-label{font-size:12px;color:var(--color-text-secondary,#666)}.detail-value{font-size:12px;font-weight:500;color:var(--color-text-primary,#333)}.growth-indicator{font-weight:600}.goal-description{margin-top:12px;font-size:12px;color:var(--color-text-secondary,#666);line-height:1.4}.goal-form{max-width:600px;margin:0 auto}.form-group,.form-row{margin-bottom:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}label{display:block;font-size:14px;font-weight:500;color:var(--color-text-primary,#333);margin-bottom:8px}input,textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background-color:white;transition:border-color .3s}input:focus,textarea:focus{outline:none;border-color:var(--color-primary,#1976d2)}input.error,textarea.error{border-color:var(--color-danger,#d32f2f)}.error-message{color:var(--color-danger,#d32f2f)}.error-message,.hint-text{font-size:12px;margin-top:4px}.hint-text{color:var(--color-text-secondary,#666)}.goal-preview{background-color:#f5f5f5;border-radius:8px;padding:16px;margin-bottom:20px}.goal-preview h3{font-size:14px;font-weight:500;color:var(--color-text-primary,#333);margin-top:0;margin-bottom:12px}.preview-item{display:flex;justify-content:space-between;margin-bottom:8px;font-size:14px}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:30px}.cancel-button,.submit-button{padding:10px 20px;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}.cancel-button{background-color:#f5f5f5;color:var(--color-text-secondary,#666);border:1px solid #ddd}.cancel-button:hover{background-color:#e0e0e0}.submit-button{background-color:var(--color-primary,#1976d2);color:white;border:none}.submit-button:hover{background-color:var(--color-primary-dark,#1565c0)}.page-container{padding:20px}.page-header{justify-content:space-between;margin-bottom:30px}.back-button,.page-header{display:flex;align-items:center}.back-button{background-color:#f5f5f5;border:1px solid #ddd;color:var(--color-text-secondary,#666);font-size:14px;cursor:pointer;padding:8px 12px;border-radius:4px}.back-button:hover{background-color:#e0e0e0;color:var(--color-primary,#1976d2)}.back-button .icon{margin-right:8px}.back-button:before{content:"←";margin-right:5px}.header-actions{display:flex;gap:10px}.header-actions .action-button{display:flex;align-items:center;padding:8px 12px;border-radius:4px;font-size:14px;min-width:100px;justify-content:center;transition:all .3s}.mark-achieved-button{background-color:var(--color-success,#4caf50);color:white;border:none}.mark-achieved-button:hover{background-color:var(--color-success-dark,#388e3c)}.edit-button{background-color:var(--color-primary,#1976d2);color:white;border:none}.edit-button:hover{background-color:var(--color-primary-dark,#1565c0)}.delete-button{background-color:var(--color-danger,#d32f2f);color:white;border:none}.delete-button:hover{background-color:var(--color-danger-dark,#b71c1c)}.header-actions .action-button .icon{margin-right:8px}.mark-achieved-button:before{content:"✓";margin-right:5px}.edit-button:before{content:"✎";margin-right:5px}.delete-button:before{content:"×";margin-right:5px}.goal-title{font-size:24px;font-weight:600;color:var(--color-text-primary,#333);margin-bottom:20px}.goal-progress-section{margin-bottom:30px}.goal-details-section,.goal-progress-section{background-color:white;border-radius:8px;padding:24px;box-shadow:0 1px 3px rgba(0,0,0,.1)}.details-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px;margin-bottom:20px}.achievement-status .achieved{color:var(--color-success,#4caf50);font-weight:600}.goals-grid .goal-card .action-button{background-color:rgba(0,0,0,.05);border:1px solid #ddd;padding:6px 10px;font-size:16px;border-radius:4px}.goals-grid .goal-card .edit-button:hover{background-color:rgba(25,118,210,.2)}.goals-grid .goal-card .delete-button:hover{background-color:rgba(211,47,47,.2)}.add-button{background-color:var(--color-primary,#1976d2);color:white;border:none;border-radius:4px;padding:10px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}.add-button:hover{background-color:var(--color-primary-dark,#1565c0)}.view-all-button{background-color:transparent;color:var(--color-primary,#1976d2);border:1px solid var(--color-primary,#1976d2);border-radius:4px;padding:6px 12px;font-size:13px;font-weight:500;cursor:pointer;transition:all .3s}.view-all-button:hover{background-color:rgba(25,118,210,.1)}.goals-overview{display:flex;flex-direction:column;gap:20px}.overview-goals-section{margin-top:30px;background-color:white;border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.1);padding:20px}.overview-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.overview-section-header h3{font-size:18px;font-weight:600;margin:0;color:var(--color-text-primary,#333)}.overview-goals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:15px}.overview-goal-card{background-color:#f9f9f9;border-radius:8px;padding:15px;transition:transform .2s,box-shadow .2s;cursor:pointer;border:1px solid #eee}.overview-goal-card:hover{transform:translateY(-2px);box-shadow:0 3px 5px rgba(0,0,0,.08);background-color:#f5f5f5}.overview-goal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.overview-goal-name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:65%;color:var(--color-text-primary,#333)}.overview-goal-progress-badge{background-color:var(--color-primary,#1976d2);color:white;font-size:11px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:30px;text-align:center}.overview-goal-progress-bar-container{width:100%;height:5px;background-color:#f0f0f0;border-radius:3px;margin-bottom:12px;overflow:hidden}.overview-goal-progress-bar{height:100%;border-radius:3px;transition:width .3s ease}.overview-goal-metrics{display:flex;flex-direction:column;gap:6px;font-size:12px}.overview-goal-metric{display:flex;justify-content:space-between;align-items:center}.overview-goal-metric-label{color:var(--color-text-secondary,#666)}.overview-goal-metric-value{font-weight:500;color:var(--color-text-primary,#333)}.overview-empty-goals{text-align:center;padding:15px 0}.overview-empty-goals p{margin:0 0 12px;font-size:14px;color:var(--color-text-secondary,#666)}.create-goal-button-small{background-color:var(--color-primary,#1976d2);color:white;border:none;border-radius:4px;padding:8px 16px;font-size:13px;font-weight:500;cursor:pointer;display:inline-block}.create-goal-button-small:hover{background-color:var(--color-primary-dark,#1565c0)}@media (max-width:768px){.overview-goals-grid{grid-template-columns:1fr}}.active-goals{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.dashboard-goal-card{background-color:white;border-radius:8px;box-shadow:0 1px 3px rgba(0,0,0,.1);padding:16px;cursor:pointer;transition:transform .2s,box-shadow .2s}.dashboard-goal-card:hover{transform:translateY(-3px);box-shadow:0 4px 6px rgba(0,0,0,.1)}.goal-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.goal-card-header h3{font-size:16px;font-weight:600;margin:0;color:var(--color-text-primary,#333)}.goal-progress-badge{background-color:var(--color-primary,#1976d2);color:white;font-size:12px;font-weight:600;padding:3px 8px;border-radius:12px;min-width:40px;text-align:center}.goal-progress-bar-container{width:100%;height:6px;background-color:#f0f0f0;border-radius:3px;margin-bottom:16px;overflow:hidden}.goal-progress-bar{height:100%;border-radius:3px;transition:width .3s ease}.goal-metrics{display:flex;justify-content:space-between;margin-bottom:12px}.goal-metric{display:flex;flex-direction:column}.goal-metric-label{font-size:12px;color:var(--color-text-secondary,#666);margin-bottom:4px}.goal-metric-value{font-weight:500;font-size:14px}.goal-info{display:flex;flex-direction:column;gap:8px;font-size:13px;border-top:1px solid #eee;padding-top:12px}.goal-remaining,.goal-time{display:flex;justify-content:space-between}.goal-remaining-label,.goal-time-label{color:var(--color-text-secondary,#666)}.goal-remaining-value,.goal-time-value{font-weight:500}.empty-goals{text-align:center;padding:40px 0}.empty-goals p{margin:0 0 10px;font-size:16px;color:var(--color-text-secondary,#666)}.empty-goals-tip{font-size:14px!important;margin-bottom:24px!important}.start-goal-button{background-color:var(--color-primary,#1976d2);color:white;border:none;border-radius:4px;padding:10px 24px;font-size:14px;font-weight:500;cursor:pointer;display:inline-block}.completed-goals-section{margin-top:24px}.completed-goals-section h3{font-size:16px;margin-bottom:16px;color:var(--color-text-secondary,#666)}.completed-goals{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px}.completed-goal-card{background-color:var(--color-success-bg,#e8f5e9);border-radius:8px;padding:12px;cursor:pointer;display:flex;flex-direction:column;gap:4px}.completed-goal-name{font-weight:500;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.completed-goal-amount{font-size:13px;color:var(--color-text-secondary,#666)}.completed-badge{align-self:flex-start;background-color:var(--color-success,#4caf50);color:white;font-size:11px;padding:2px 6px;border-radius:10px;margin-top:4px}@media (max-width:768px){.active-goals,.completed-goals,.form-row,.goals-grid{grid-template-columns:1fr}.form-row{gap:15px}.details-grid{grid-template-columns:1fr}.header-actions{flex-direction:column}}